diff options
Diffstat (limited to 'src/corelib/render/software/agg-demos/compositing2.dpr')
-rw-r--r-- | src/corelib/render/software/agg-demos/compositing2.dpr | 672 |
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 |