Add check when building padding table.

This commit is contained in:
Fabien Freling 2014-08-06 23:11:42 +02:00
parent f2234dea1f
commit 7ac7522908

View file

@ -211,21 +211,42 @@ uint16_t* generate_padding_table(Image const& rotated,
padding_table[i] = max(x_range, y_range); padding_table[i] = max(x_range, y_range);
{ Point border(src_rotated_origin.x + padding_table[i] * qdx.x,
Point test(src_rotated_origin.x + padding_table[i] * qdx.x,
src_rotated_origin.y + padding_table[i] * qdx.y); src_rotated_origin.y + padding_table[i] * qdx.y);
if (test.x < 0 || test.y < 0 if (border.x < 0 || border.y < 0
|| test.x >= src_qwidth || test.y >= src_qheight) || border.x >= src_qwidth || border.y >= src_qheight)
{ {
cout << "Padding issue at line " << i << endl; if (false)
cout << " src: " << src_rotated_origin << endl; {
cout << " test: " << test << endl; LOG << "Padding issue at line " << i << endl;
cout << " q dim: " << src_qwidth << " x " << src_qheight << endl; LOG << " origin: " << src_rotated_origin << endl;
cout << " " << padding_table[i] << " x " << qdx << endl; LOG << " border: " << border << endl;
cout << " x diff = " << src_rotated_origin.x - src_qwidth + 1 << endl; LOG << " q dim: " << src_qwidth << " x " << src_qheight << endl;
cout << " x coef = " << (float) (src_rotated_origin.x - src_qwidth + 1) / (float) (-qdx.x) << endl; LOG << " " << padding_table[i] << " x " << qdx << endl;
LOG << " X range" << endl;
LOG << " x diff = " << src_rotated_origin.x - src_qwidth + 1 << endl;
LOG << " x coef = " << (float) (src_rotated_origin.x - src_qwidth + 1) / (float) (-qdx.x) << endl;
LOG << " Y range" << endl;
if (src_rotated_origin.y < 0)
{
LOG << " y < 0" << endl;
LOG << " y diff = " << (-src_rotated_origin.y) << endl;
LOG << " y coef = " << (-src_rotated_origin.y) / (float) qdx.y << endl;
}
else if (src_rotated_origin.y >= src_qheight)
{
LOG << " y < height" << endl;
LOG << " y diff = " << src_rotated_origin.x - src_qwidth + 1 << endl;
LOG << " y coef = " << (float) (src_rotated_origin.x - src_qwidth + 1) / (float) (-qdx.x) << endl;
}
else
{
LOG << " in bounds" << endl;
}
abort(); abort();
} }
padding_table[i] = rotated.width;
} }
src_rotated_origin += qdy; src_rotated_origin += qdy;