summaryrefslogtreecommitdiff
path: root/src/corelib/render/software/agg-demos/compositing2.dpr
diff options
context:
space:
mode:
Diffstat (limited to 'src/corelib/render/software/agg-demos/compositing2.dpr')
-rw-r--r--src/corelib/render/software/agg-demos/compositing2.dpr672
1 files changed, 336 insertions, 336 deletions
diff --git a/src/corelib/render/software/agg-demos/compositing2.dpr b/src/corelib/render/software/agg-demos/compositing2.dpr
index e07e3136..3f9376fe 100644
--- a/src/corelib/render/software/agg-demos/compositing2.dpr
+++ b/src/corelib/render/software/agg-demos/compositing2.dpr
@@ -1,336 +1,336 @@
-//
-// AggPas 2.4 RM3 Demo application
-// Note: Press F1 key on run to see more info about this demo
-//
-// Paths: ..;..\ctrl;..\svg;..\util;..\platform\win;expat-wrap
-//
-program
- compositing2 ;
-
-uses
- agg_basics ,
- agg_color ,
- agg_platform_support ,
- agg_ctrl ,
- agg_slider_ctrl ,
- agg_rbox_ctrl ,
- agg_rendering_buffer ,
- agg_rasterizer_scanline_aa ,
- agg_scanline_u ,
- agg_renderer_base ,
- agg_renderer_scanline ,
- agg_render_scanlines ,
- agg_rounded_rect ,
- agg_pixfmt ,
- agg_pixfmt_rgba ,
- agg_span_allocator ,
- agg_span_gradient ,
- agg_gsv_text ,
- agg_span_interpolator_linear ,
- agg_array ,
- agg_trans_affine ,
- agg_ellipse ,
- agg_conv_transform ;
-
-{$I agg_mode.inc }
-
-const
- flip_y = true;
-
-type
- the_application = object(platform_support )
- private
- m_alpha_dst ,
- m_alpha_src : slider_ctrl;
- m_comp_op : rbox_ctrl;
-
- m_ramp1 ,
- m_ramp2 : pod_auto_array;
-
- m_ras : rasterizer_scanline_aa;
- m_sl : scanline_u8;
-
- public
- constructor Construct(format_ : pix_format_e; flip_y_ : boolean );
- destructor Destruct;
-
- procedure radial_shape(
- rbase : renderer_base_ptr;
- colors : array_base_ptr;
- x1 ,y1 ,x2 ,y2 : double );
-
- procedure render_scene(rb : renderer_base_ptr );
-
- procedure on_draw; virtual;
-
- procedure on_key(x ,y : int; key ,flags : unsigned ); virtual;
-
- end;
-
-{ CONSTRUCT }
-constructor the_application.Construct;
-begin
- inherited Construct(format_ ,flip_y_ );
-
- m_alpha_dst.Construct(5 ,5 ,400 ,11 ,not flip_y_ );
- m_alpha_src.Construct(5 ,5 + 15 ,400 ,11 + 15 ,not flip_y_ );
- m_comp_op.Construct (420 ,5.0 ,420 + 170.0 ,395.0 ,not flip_y_ );
-
- m_ramp1.Construct(256 ,sizeof(aggclr ) );
- m_ramp2.Construct(256 ,sizeof(aggclr ) );
-
- m_ras.Construct;
- m_sl.Construct;
-
- m_alpha_dst.label_('Dst Alpha=%.2f' );
- m_alpha_dst.value_(1.0 );
-
- add_ctrl(@m_alpha_dst );
-
- m_alpha_src.label_('Src Alpha=%.2f' );
- m_alpha_src.value_(1.0 );
-
- add_ctrl(@m_alpha_src );
-
- m_comp_op.text_size_(6.8 );
- m_comp_op.add_item ('clear' );
- m_comp_op.add_item ('src' );
- m_comp_op.add_item ('dst' );
- m_comp_op.add_item ('src-over' );
- m_comp_op.add_item ('dst-over' );
- m_comp_op.add_item ('src-in' );
- m_comp_op.add_item ('dst-in' );
- m_comp_op.add_item ('src-out' );
- m_comp_op.add_item ('dst-out' );
- m_comp_op.add_item ('src-atop' );
- m_comp_op.add_item ('dst-atop' );
- m_comp_op.add_item ('xor' );
- m_comp_op.add_item ('plus' );
- m_comp_op.add_item ('minus' );
- m_comp_op.add_item ('multiply' );
- m_comp_op.add_item ('screen' );
- m_comp_op.add_item ('overlay' );
- m_comp_op.add_item ('darken' );
- m_comp_op.add_item ('lighten' );
- m_comp_op.add_item ('color-dodge' );
- m_comp_op.add_item ('color-burn' );
- m_comp_op.add_item ('hard-light' );
- m_comp_op.add_item ('soft-light' );
- m_comp_op.add_item ('difference' );
- m_comp_op.add_item ('exclusion' );
- m_comp_op.add_item ('contrast' );
- m_comp_op.add_item ('invert' );
- m_comp_op.add_item ('invert-rgb' );
- m_comp_op.cur_item_ (3 );
-
- add_ctrl(@m_comp_op );
-
-end;
-
-{ DESTRUCT }
-destructor the_application.Destruct;
-begin
- inherited Destruct;
-
- m_alpha_dst.Destruct;
- m_alpha_src.Destruct;
- m_comp_op.Destruct;
-
- m_ramp1.Destruct;
- m_ramp2.Destruct;
-
- m_ras.Destruct;
- m_sl.Destruct;
-
-end;
-
-{ RADIAL_SHAPE }
-procedure the_application.radial_shape;
-var
- gradient_func : gradient_radial;
- gradient_mtx : trans_affine;
- span_interpolator : span_interpolator_linear;
- span_allocator_ : span_allocator;
- span_gradient_ : span_gradient;
-
- cx ,cy ,r : double;
-
- tas : trans_affine_scaling;
- tat : trans_affine_translation;
-
- ell : ellipse;
-
- trans : conv_transform;
-
- rg : renderer_scanline_aa;
-
-begin
- gradient_func.Construct;
- gradient_mtx.Construct;
- span_interpolator.Construct(@gradient_mtx );
- span_allocator_.Construct;
- span_gradient_.Construct(
- @span_allocator_ ,
- @span_interpolator ,
- @gradient_func ,
- colors ,
- 0 ,100 );
-
- cx:=(x1 + x2 ) / 2.0;
- cy:=(y1 + y2 ) / 2.0;
-
- if (x2 - x1 ) < (y2 - y1 ) then
- r:=0.5 * (x2 - x1 )
- else
- r:=0.5 * (y2 - y1 );
-
- tas.Construct (r / 100.0 );
- gradient_mtx.multiply(@tas );
- tat.Construct (cx ,cy );
- gradient_mtx.multiply(@tat );
- gradient_mtx.multiply(_trans_affine_resizing );
- gradient_mtx.invert;
-
- ell.Construct (cx ,cy ,r ,r ,100 );
- trans.Construct(@ell ,_trans_affine_resizing );
-
- m_ras.add_path(@trans );
- rg.Construct (rbase ,@span_gradient_ );
-
- render_scanlines(@m_ras ,@m_sl ,@rg );
-
- span_allocator_.Destruct;
- span_gradient_.Destruct;
-
-end;
-
-{ RENDER_SCENE }
-procedure the_application.render_scene;
-var
- pixf : pixel_formats;
- ren : renderer_base;
-
- cx ,cy : double;
-
-begin
- pixfmt_custom_blend_rgba(pixf ,rbuf_window ,@comp_op_adaptor_rgba ,bgra_order );
-
- ren.Construct(@pixf );
-
- pixf.comp_op_(unsigned(comp_op_difference ) );
- radial_shape (@ren ,@m_ramp1 ,50 ,50 ,50 + 320 ,50 + 320 );
-
- pixf.comp_op_(m_comp_op._cur_item );
-
- cx:=50;
- cy:=50;
-
- radial_shape(@ren ,@m_ramp2 ,cx + 120 - 70 ,cy + 120 - 70 ,cx + 120 + 70 ,cy + 120 + 70 );
- radial_shape(@ren ,@m_ramp2 ,cx + 200 - 70 ,cy + 120 - 70 ,cx + 200 + 70 ,cy + 120 + 70 );
- radial_shape(@ren ,@m_ramp2 ,cx + 120 - 70 ,cy + 200 - 70 ,cx + 120 + 70 ,cy + 200 + 70 );
- radial_shape(@ren ,@m_ramp2 ,cx + 200 - 70 ,cy + 200 - 70 ,cx + 200 + 70 ,cy + 200 + 70 );
-
-end;
-
-{ generate_color_ramp }
-procedure generate_color_ramp(c : pod_auto_array_ptr; c1 ,c2 ,c3 ,c4 : aggclr_ptr );
-var
- i : unsigned;
-
-begin
- i:=0;
-
- while i < 85 do
- begin
- aggclr_ptr(c.array_operator(i ) )^:=c1.gradient(c2 ,i / 85.0 );
-
- inc(i );
-
- end;
-
- while i < 170 do
- begin
- aggclr_ptr(c.array_operator(i ) )^:=c2.gradient(c3 ,(i - 85 ) / 85.0 );
-
- inc(i );
-
- end;
-
- while i < 256 do
- begin
- aggclr_ptr(c.array_operator(i ) )^:=c3.gradient(c4 ,(i - 170 ) / 85.0 );
-
- inc(i );
-
- end;
-
-end;
-
-{ ON_DRAW }
-procedure the_application.on_draw;
-var
- pixf : pixel_formats;
- rgba : aggclr;
-
- rb : renderer_base;
- rs : renderer_scanline_aa_solid;
-
- c1 ,c2 ,c3 ,c4 : aggclr;
-
-begin
-// Initialize structures
-// pixfmt_alpha_blend_rgba(pixf ,rbuf_window ,bgra_order ); {!}
- pixfmt_bgra32(pixf ,rbuf_window );
-
- rb.Construct(@pixf );
- rs.Construct(@rb );
-
- rgba.ConstrInt(255 ,255 ,255 );
- rb.clear (@rgba );
-
-// Render
- c1.ConstrDbl(0 ,0 ,0 ,m_alpha_dst._value );
- c2.ConstrDbl(0 ,0 ,1 ,m_alpha_dst._value );
- c3.ConstrDbl(0 ,1 ,0 ,m_alpha_dst._value );
- c4.ConstrDbl(1 ,0 ,0 ,0 );
-
- generate_color_ramp(@m_ramp1 ,@c1 ,@c2 ,@c3 ,@c4 );
-
- c1.ConstrDbl(0 ,0 ,0 ,m_alpha_src._value );
- c2.ConstrDbl(0 ,0 ,1 ,m_alpha_src._value );
- c3.ConstrDbl(0 ,1 ,0 ,m_alpha_src._value );
- c4.ConstrDbl(1 ,0 ,0 ,0 );
-
- generate_color_ramp(@m_ramp2 ,@c1 ,@c2 ,@c3 ,@c4 );
-
- render_scene(@rb );
-
-// Render the controls
- render_ctrl(@m_ras ,@m_sl ,@rs ,@m_alpha_dst );
- render_ctrl(@m_ras ,@m_sl ,@rs ,@m_alpha_src );
- render_ctrl(@m_ras ,@m_sl ,@rs ,@m_comp_op );
-
-end;
-
-{ ON_KEY }
-procedure the_application.on_key;
-begin
- if key = key_f1 then
- message_(
- 'Another demo example with extended compositing modes. ' );
-
-end;
-
-VAR
- app : the_application;
-
-BEGIN
- app.Construct(pix_format_bgra32 ,flip_y );
- app.caption_ ('AGG Example. Compositing Modes (F1-Help)' );
-
- if app.init(600 ,400 ,window_resize or window_keep_aspect_ratio ) then
- app.run;
-
- app.Destruct;
-
-END. \ No newline at end of file
+//
+// AggPas 2.4 RM3 Demo application
+// Note: Press F1 key on run to see more info about this demo
+//
+// Paths: ..;..\ctrl;..\svg;..\util;..\platform\win;expat-wrap
+//
+program
+ compositing2 ;
+
+uses
+ agg_basics ,
+ agg_color ,
+ agg_platform_support ,
+ agg_ctrl ,
+ agg_slider_ctrl ,
+ agg_rbox_ctrl ,
+ agg_rendering_buffer ,
+ agg_rasterizer_scanline_aa ,
+ agg_scanline_u ,
+ agg_renderer_base ,
+ agg_renderer_scanline ,
+ agg_render_scanlines ,
+ agg_rounded_rect ,
+ agg_pixfmt ,
+ agg_pixfmt_rgba ,
+ agg_span_allocator ,
+ agg_span_gradient ,
+ agg_gsv_text ,
+ agg_span_interpolator_linear ,
+ agg_array ,
+ agg_trans_affine ,
+ agg_ellipse ,
+ agg_conv_transform ;
+
+{$I agg_mode.inc }
+
+const
+ flip_y = true;
+
+type
+ the_application = object(platform_support )
+ private
+ m_alpha_dst ,
+ m_alpha_src : slider_ctrl;
+ m_comp_op : rbox_ctrl;
+
+ m_ramp1 ,
+ m_ramp2 : pod_auto_array;
+
+ m_ras : rasterizer_scanline_aa;
+ m_sl : scanline_u8;
+
+ public
+ constructor Construct(format_ : pix_format_e; flip_y_ : boolean );
+ destructor Destruct;
+
+ procedure radial_shape(
+ rbase : renderer_base_ptr;
+ colors : array_base_ptr;
+ x1 ,y1 ,x2 ,y2 : double );
+
+ procedure render_scene(rb : renderer_base_ptr );
+
+ procedure on_draw; virtual;
+
+ procedure on_key(x ,y : int; key ,flags : unsigned ); virtual;
+
+ end;
+
+{ CONSTRUCT }
+constructor the_application.Construct;
+begin
+ inherited Construct(format_ ,flip_y_ );
+
+ m_alpha_dst.Construct(5 ,5 ,400 ,11 ,not flip_y_ );
+ m_alpha_src.Construct(5 ,5 + 15 ,400 ,11 + 15 ,not flip_y_ );
+ m_comp_op.Construct (420 ,5.0 ,420 + 170.0 ,395.0 ,not flip_y_ );
+
+ m_ramp1.Construct(256 ,sizeof(aggclr ) );
+ m_ramp2.Construct(256 ,sizeof(aggclr ) );
+
+ m_ras.Construct;
+ m_sl.Construct;
+
+ m_alpha_dst.label_('Dst Alpha=%.2f' );
+ m_alpha_dst.value_(1.0 );
+
+ add_ctrl(@m_alpha_dst );
+
+ m_alpha_src.label_('Src Alpha=%.2f' );
+ m_alpha_src.value_(1.0 );
+
+ add_ctrl(@m_alpha_src );
+
+ m_comp_op.text_size_(6.8 );
+ m_comp_op.add_item ('clear' );
+ m_comp_op.add_item ('src' );
+ m_comp_op.add_item ('dst' );
+ m_comp_op.add_item ('src-over' );
+ m_comp_op.add_item ('dst-over' );
+ m_comp_op.add_item ('src-in' );
+ m_comp_op.add_item ('dst-in' );
+ m_comp_op.add_item ('src-out' );
+ m_comp_op.add_item ('dst-out' );
+ m_comp_op.add_item ('src-atop' );
+ m_comp_op.add_item ('dst-atop' );
+ m_comp_op.add_item ('xor' );
+ m_comp_op.add_item ('plus' );
+ m_comp_op.add_item ('minus' );
+ m_comp_op.add_item ('multiply' );
+ m_comp_op.add_item ('screen' );
+ m_comp_op.add_item ('overlay' );
+ m_comp_op.add_item ('darken' );
+ m_comp_op.add_item ('lighten' );
+ m_comp_op.add_item ('color-dodge' );
+ m_comp_op.add_item ('color-burn' );
+ m_comp_op.add_item ('hard-light' );
+ m_comp_op.add_item ('soft-light' );
+ m_comp_op.add_item ('difference' );
+ m_comp_op.add_item ('exclusion' );
+ m_comp_op.add_item ('contrast' );
+ m_comp_op.add_item ('invert' );
+ m_comp_op.add_item ('invert-rgb' );
+ m_comp_op.cur_item_ (3 );
+
+ add_ctrl(@m_comp_op );
+
+end;
+
+{ DESTRUCT }
+destructor the_application.Destruct;
+begin
+ inherited Destruct;
+
+ m_alpha_dst.Destruct;
+ m_alpha_src.Destruct;
+ m_comp_op.Destruct;
+
+ m_ramp1.Destruct;
+ m_ramp2.Destruct;
+
+ m_ras.Destruct;
+ m_sl.Destruct;
+
+end;
+
+{ RADIAL_SHAPE }
+procedure the_application.radial_shape;
+var
+ gradient_func : gradient_radial;
+ gradient_mtx : trans_affine;
+ span_interpolator : span_interpolator_linear;
+ span_allocator_ : span_allocator;
+ span_gradient_ : span_gradient;
+
+ cx ,cy ,r : double;
+
+ tas : trans_affine_scaling;
+ tat : trans_affine_translation;
+
+ ell : ellipse;
+
+ trans : conv_transform;
+
+ rg : renderer_scanline_aa;
+
+begin
+ gradient_func.Construct;
+ gradient_mtx.Construct;
+ span_interpolator.Construct(@gradient_mtx );
+ span_allocator_.Construct;
+ span_gradient_.Construct(
+ @span_allocator_ ,
+ @span_interpolator ,
+ @gradient_func ,
+ colors ,
+ 0 ,100 );
+
+ cx:=(x1 + x2 ) / 2.0;
+ cy:=(y1 + y2 ) / 2.0;
+
+ if (x2 - x1 ) < (y2 - y1 ) then
+ r:=0.5 * (x2 - x1 )
+ else
+ r:=0.5 * (y2 - y1 );
+
+ tas.Construct (r / 100.0 );
+ gradient_mtx.multiply(@tas );
+ tat.Construct (cx ,cy );
+ gradient_mtx.multiply(@tat );
+ gradient_mtx.multiply(_trans_affine_resizing );
+ gradient_mtx.invert;
+
+ ell.Construct (cx ,cy ,r ,r ,100 );
+ trans.Construct(@ell ,_trans_affine_resizing );
+
+ m_ras.add_path(@trans );
+ rg.Construct (rbase ,@span_gradient_ );
+
+ render_scanlines(@m_ras ,@m_sl ,@rg );
+
+ span_allocator_.Destruct;
+ span_gradient_.Destruct;
+
+end;
+
+{ RENDER_SCENE }
+procedure the_application.render_scene;
+var
+ pixf : pixel_formats;
+ ren : renderer_base;
+
+ cx ,cy : double;
+
+begin
+ pixfmt_custom_blend_rgba(pixf ,rbuf_window ,@comp_op_adaptor_rgba ,bgra_order );
+
+ ren.Construct(@pixf );
+
+ pixf.comp_op_(unsigned(comp_op_difference ) );
+ radial_shape (@ren ,@m_ramp1 ,50 ,50 ,50 + 320 ,50 + 320 );
+
+ pixf.comp_op_(m_comp_op._cur_item );
+
+ cx:=50;
+ cy:=50;
+
+ radial_shape(@ren ,@m_ramp2 ,cx + 120 - 70 ,cy + 120 - 70 ,cx + 120 + 70 ,cy + 120 + 70 );
+ radial_shape(@ren ,@m_ramp2 ,cx + 200 - 70 ,cy + 120 - 70 ,cx + 200 + 70 ,cy + 120 + 70 );
+ radial_shape(@ren ,@m_ramp2 ,cx + 120 - 70 ,cy + 200 - 70 ,cx + 120 + 70 ,cy + 200 + 70 );
+ radial_shape(@ren ,@m_ramp2 ,cx + 200 - 70 ,cy + 200 - 70 ,cx + 200 + 70 ,cy + 200 + 70 );
+
+end;
+
+{ generate_color_ramp }
+procedure generate_color_ramp(c : pod_auto_array_ptr; c1 ,c2 ,c3 ,c4 : aggclr_ptr );
+var
+ i : unsigned;
+
+begin
+ i:=0;
+
+ while i < 85 do
+ begin
+ aggclr_ptr(c.array_operator(i ) )^:=c1.gradient(c2 ,i / 85.0 );
+
+ inc(i );
+
+ end;
+
+ while i < 170 do
+ begin
+ aggclr_ptr(c.array_operator(i ) )^:=c2.gradient(c3 ,(i - 85 ) / 85.0 );
+
+ inc(i );
+
+ end;
+
+ while i < 256 do
+ begin
+ aggclr_ptr(c.array_operator(i ) )^:=c3.gradient(c4 ,(i - 170 ) / 85.0 );
+
+ inc(i );
+
+ end;
+
+end;
+
+{ ON_DRAW }
+procedure the_application.on_draw;
+var
+ pixf : pixel_formats;
+ rgba : aggclr;
+
+ rb : renderer_base;
+ rs : renderer_scanline_aa_solid;
+
+ c1 ,c2 ,c3 ,c4 : aggclr;
+
+begin
+// Initialize structures
+// pixfmt_alpha_blend_rgba(pixf ,rbuf_window ,bgra_order ); {!}
+ pixfmt_bgra32(pixf ,rbuf_window );
+
+ rb.Construct(@pixf );
+ rs.Construct(@rb );
+
+ rgba.ConstrInt(255 ,255 ,255 );
+ rb.clear (@rgba );
+
+// Render
+ c1.ConstrDbl(0 ,0 ,0 ,m_alpha_dst._value );
+ c2.ConstrDbl(0 ,0 ,1 ,m_alpha_dst._value );
+ c3.ConstrDbl(0 ,1 ,0 ,m_alpha_dst._value );
+ c4.ConstrDbl(1 ,0 ,0 ,0 );
+
+ generate_color_ramp(@m_ramp1 ,@c1 ,@c2 ,@c3 ,@c4 );
+
+ c1.ConstrDbl(0 ,0 ,0 ,m_alpha_src._value );
+ c2.ConstrDbl(0 ,0 ,1 ,m_alpha_src._value );
+ c3.ConstrDbl(0 ,1 ,0 ,m_alpha_src._value );
+ c4.ConstrDbl(1 ,0 ,0 ,0 );
+
+ generate_color_ramp(@m_ramp2 ,@c1 ,@c2 ,@c3 ,@c4 );
+
+ render_scene(@rb );
+
+// Render the controls
+ render_ctrl(@m_ras ,@m_sl ,@rs ,@m_alpha_dst );
+ render_ctrl(@m_ras ,@m_sl ,@rs ,@m_alpha_src );
+ render_ctrl(@m_ras ,@m_sl ,@rs ,@m_comp_op );
+
+end;
+
+{ ON_KEY }
+procedure the_application.on_key;
+begin
+ if key = key_f1 then
+ message_(
+ 'Another demo example with extended compositing modes. ' );
+
+end;
+
+VAR
+ app : the_application;
+
+BEGIN
+ app.Construct(pix_format_bgra32 ,flip_y );
+ app.caption_ ('AGG Example. Compositing Modes (F1-Help)' );
+
+ if app.init(600 ,400 ,window_resize or window_keep_aspect_ratio ) then
+ app.run;
+
+ app.Destruct;
+
+END. \ No newline at end of file