+ handle boundary pixels in x/y gradients
This commit is contained in:
parent
0542994c4d
commit
bd25a9af92
1 changed files with 14 additions and 4 deletions
|
@ -410,6 +410,16 @@ void x_gradient_impl(Src const& src_view, Dst const& dst_view)
|
|||
typename Src::x_iterator src_it = src_view.row_begin(y);
|
||||
typename Dst::x_iterator dst_it = dst_view.row_begin(y);
|
||||
|
||||
dst_it[0][0] = 127 + (src_it[0][0] - src_it[1][0]) / 2;
|
||||
dst_it[0][1] = 127 + (src_it[0][1] - src_it[1][1]) / 2;
|
||||
dst_it[0][2] = 127 + (src_it[0][2] - src_it[1][2]) / 2;
|
||||
|
||||
dst_it[dst_view.width()-1][0] = 127 + (src_it[src_view.width()-2][0] - src_it[src_view.width()-1][0]) / 2;
|
||||
dst_it[dst_view.width()-1][1] = 127 + (src_it[src_view.width()-2][1] - src_it[src_view.width()-1][1]) / 2;
|
||||
dst_it[dst_view.width()-1][2] = 127 + (src_it[src_view.width()-2][2] - src_it[src_view.width()-1][2]) / 2;
|
||||
|
||||
dst_it[0][3] = dst_it[src_view.width()-1][3] = 255;
|
||||
|
||||
for (int x=1; x<src_view.width()-1; ++x)
|
||||
{
|
||||
dst_it[x][0] = 127 + (src_it[x-1][0] - src_it[x+1][0]) / 2;
|
||||
|
|
Loading…
Reference in a new issue