Code

First version of feOffset support. Contains some rendering glitches.
[inkscape.git] / src / display / nr-filter-offset.cpp
1 /*
2  * feOffset filter primitive renderer
3  *
4  * Authors:
5  *   Niko Kiirala <niko@kiirala.com>
6  *
7  * Copyright (C) 2007 authors
8  *
9  * Released under GNU GPL, read the file 'COPYING' for more information
10  */
12 #include "display/nr-filter-offset.h"
13 #include "display/nr-filter-slot.h"
14 #include "libnr/nr-blit.h"
15 #include "libnr/nr-matrix.h"
16 #include "libnr/nr-pixblock.h"
17 #include "libnr/nr-point.h"
18 #include "libnr/nr-point-matrix-ops.h"
19 #include "libnr/nr-rect-l.h"
21 namespace NR {
23 FilterOffset::FilterOffset() :
24     dx(0), dy(0)
25 {}
27 FilterPrimitive * FilterOffset::create() {
28     return new FilterOffset();
29 }
31 FilterOffset::~FilterOffset()
32 {}
34 int FilterOffset::render(FilterSlot &slot, Matrix const &trans) {
35     NRPixBlock *in = slot.get(_input);
36     NRPixBlock *out = new NRPixBlock;
38     Point offset(dx, dy);
39     offset *= trans;
40     offset[X] -= trans[4];
41     offset[Y] -= trans[5];
43     nr_pixblock_setup_fast(out, in->mode,
44                            in->area.x0, in->area.y0, in->area.x1, in->area.y1,
45                            true);
46     nr_blit_pixblock_pixblock(out, in);
48     out->area.x0 += static_cast<NR::ICoord>(offset[X]);
49     out->area.y0 += static_cast<NR::ICoord>(offset[Y]);
50     out->area.x1 += static_cast<NR::ICoord>(offset[X]);
51     out->area.y1 += static_cast<NR::ICoord>(offset[Y]);
52     out->visible_area = out->area;
54     out->empty = FALSE;
55     slot.set(_output, out);
57     return 0;
58 }
60 void FilterOffset::set_dx(double amount) {
61     dx = amount;
62 }
64 void FilterOffset::set_dy(double amount) {
65     dy = amount;
66 }
68 void FilterOffset::area_enlarge(NRRectL &area, Matrix const &trans)
69 {
70     Point offset(dx, dy);
71     offset *= trans;
72     offset[X] -= trans[4];
73     offset[Y] -= trans[5];
75     area.x0 -= static_cast<NR::ICoord>(offset[X]);
76     area.x1 -= static_cast<NR::ICoord>(offset[X]);
77     area.y0 -= static_cast<NR::ICoord>(offset[Y]);
78     area.y1 -= static_cast<NR::ICoord>(offset[Y]);
79 }
81 } /* namespace NR */
83 /*
84   Local Variables:
85   mode:c++
86   c-file-style:"stroustrup"
87   c-file-offsets:((innamespace . 0)(inline-open . 0)(case-label . +))
88   indent-tabs-mode:nil
89   fill-column:99
90   End:
91 */
92 // vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=99 :