lazarus/components/aggpas/compositing2.dpr
mattias 36a2b1ea07 added aggpas
git-svn-id: trunk@21942 -
2009-10-01 12:24:32 +00:00

336 lines
7.1 KiB
ObjectPascal

//
// AggPas 2.4 RM3 Demo application
// Note: Press F1 key on run to see more info about this demo
//
// Paths: src;src\ctrl;src\svg;src\util;src\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.