~ubuntu-branches/ubuntu/saucy/lazarus/saucy

« back to all changes in this revision

Viewing changes to components/aggpas/src/agg_vpgen_clip_polygon.pas

  • Committer: Package Import Robot
  • Author(s): Paul Gevers, Abou Al Montacir, Bart Martens, Paul Gevers
  • Date: 2013-06-08 14:12:17 UTC
  • mfrom: (1.1.9)
  • Revision ID: package-import@ubuntu.com-20130608141217-7k0cy9id8ifcnutc
Tags: 1.0.8+dfsg-1
[ Abou Al Montacir ]
* New upstream major release and multiple maintenace release offering many
  fixes and new features marking a new milestone for the Lazarus development
  and its stability level.
  - The detailed list of changes can be found here:
    http://wiki.lazarus.freepascal.org/Lazarus_1.0_release_notes
    http://wiki.lazarus.freepascal.org/Lazarus_1.0_fixes_branch
* LCL changes:
  - LCL is now a normal package.
      + Platform independent parts of the LCL are now in the package LCLBase
      + LCL is automatically recompiled when switching the target platform,
        unless pre-compiled binaries for this target are already installed.
      + No impact on existing projects.
      + Linker options needed by LCL are no more added to projects that do
        not use the LCL package.
  - Minor changes in LCL basic classes behaviour
      + TCustomForm.Create raises an exception if a form resource is not
        found.
      + TNotebook and TPage: a new implementation of these classes was added.
      + TDBNavigator: It is now possible to have focusable buttons by setting
        Options = [navFocusableButtons] and TabStop = True, useful for
        accessibility and for devices with neither mouse nor touch screen.
      + Names of TControlBorderSpacing.GetSideSpace and GetSpace were swapped
        and are now consistent. GetSideSpace = Around + GetSpace.
      + TForm.WindowState=wsFullscreen was added
      + TCanvas.TextFitInfo was added to calculate how many characters will
        fit into a specified Width. Useful for word-wrapping calculations.
      + TControl.GetColorResolvingParent and
        TControl.GetRGBColorResolvingParent were added, simplifying the work
        to obtain the final color of the control while resolving clDefault
        and the ParentColor.
      + LCLIntf.GetTextExtentExPoint now has a good default implementation
        which works in any platform not providing a specific implementation.
        However, Widgetset specific implementation is better, when available.
      + TTabControl was reorganized. Now it has the correct class hierarchy
        and inherits from TCustomTabControl as it should.
  - New unit in the LCL:
      + lazdialogs.pas: adds non-native versions of various native dialogs,
        for example TLazOpenDialog, TLazSaveDialog, TLazSelectDirectoryDialog.
        It is used by widgetsets which either do not have a native dialog, or
        do not wish to use it because it is limited. These dialogs can also be
        used by user applications directly.
      + lazdeviceapis.pas: offers an interface to more hardware devices such
        as the accelerometer, GPS, etc. See LazDeviceAPIs
      + lazcanvas.pas: provides a TFPImageCanvas descendent implementing
        drawing in a LCL-compatible way, but 100% in Pascal.
      + lazregions.pas. LazRegions is a wholly Pascal implementation of
        regions for canvas clipping, event clipping, finding in which control
        of a region tree one an event should reach, for drawing polygons, etc.
      + customdrawncontrols.pas, customdrawndrawers.pas,
        customdrawn_common.pas, customdrawn_android.pas and
        customdrawn_winxp.pas: are the Lazarus Custom Drawn Controls -controls
        which imitate the standard LCL ones, but with the difference that they
        are non-native and support skinning.
  - New APIs added to the LCL to improve support of accessibility software
    such as screen readers.
* IDE changes:
  - Many improvments.
  - The detailed list of changes can be found here:
    http://wiki.lazarus.freepascal.org/New_IDE_features_since#v1.0_.282012-08-29.29
    http://wiki.lazarus.freepascal.org/Lazarus_1.0_release_notes#IDE_Changes
* Debugger / Editor changes:
  - Added pascal sources and breakpoints to the disassembler
  - Added threads dialog.
* Components changes:
  - TAChart: many fixes and new features
  - CodeTool: support Delphi style generics and new syntax extensions.
  - AggPas: removed to honor free licencing. (Closes: Bug#708695)
[Bart Martens]
* New debian/watch file fixing issues with upstream RC release.
[Abou Al Montacir]
* Avoid changing files in .pc hidden directory, these are used by quilt for
  internal purpose and could lead to surprises during build.
[Paul Gevers]
* Updated get-orig-source target and it compinion script orig-tar.sh so that they
  repack the source file, allowing bug 708695 to be fixed.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
//----------------------------------------------------------------------------
2
 
// Anti-Grain Geometry - Version 2.4 (Public License)
3
 
// Copyright (C) 2002-2005 Maxim Shemanarev (http://www.antigrain.com)
4
 
//
5
 
// Anti-Grain Geometry - Version 2.4 Release Milano 3 (AggPas 2.4 RM3)
6
 
// Pascal Port By: Milan Marusinec alias Milano
7
 
//                 milan@marusinec.sk
8
 
//                 http://www.aggpas.org
9
 
// Copyright (c) 2005-2006
10
 
//
11
 
// Permission to copy, use, modify, sell and distribute this software
12
 
// is granted provided this copyright notice appears in all copies.
13
 
// This software is provided "as is" without express or implied
14
 
// warranty, and with no claim as to its suitability for any purpose.
15
 
//
16
 
//----------------------------------------------------------------------------
17
 
// Contact: mcseem@antigrain.com
18
 
//          mcseemagg@yahoo.com
19
 
//          http://www.antigrain.com
20
 
//
21
 
// [Pascal Port History] -----------------------------------------------------
22
 
//
23
 
// 07.02.2006-Milano: Unit port establishment
24
 
//
25
 
{ agg_vpgen_clip_polygon.pas }
26
 
unit
27
 
 agg_vpgen_clip_polygon ;
28
 
 
29
 
INTERFACE
30
 
 
31
 
{$I agg_mode.inc }
32
 
 
33
 
uses
34
 
 agg_basics ,
35
 
 agg_vertex_source ,
36
 
 agg_clip_liang_barsky ;
37
 
 
38
 
{ TYPES DEFINITION }
39
 
type
40
 
 vpgen_clip_polygon_ptr = ^vpgen_clip_polygon;
41
 
 vpgen_clip_polygon = object(vertex_source )
42
 
   m_clip_box : rect_d;
43
 
 
44
 
   m_x1 ,
45
 
   m_y1 : double;
46
 
 
47
 
   m_clip_flags : unsigned;
48
 
 
49
 
   m_x ,
50
 
   m_y : array[0..3 ] of double;
51
 
 
52
 
   m_num_vertices ,
53
 
   m_vertex       ,
54
 
   m_cmd          : unsigned;
55
 
 
56
 
   constructor Construct;
57
 
 
58
 
   procedure clip_box_(x1 ,y1 ,x2 ,y2 : double );
59
 
 
60
 
   function  _x1 : double;
61
 
   function  _y1 : double;
62
 
   function  _x2 : double;
63
 
   function  _y2 : double;
64
 
 
65
 
   function  _auto_close : boolean;
66
 
   function  _auto_unclose : boolean;
67
 
 
68
 
   procedure reset;
69
 
   procedure move_to(x ,y : double );
70
 
   procedure line_to(x ,y : double );
71
 
 
72
 
   function  vertex(x ,y : double_ptr ) : unsigned; virtual;
73
 
 
74
 
   function  clipping_flags(x ,y : double ) : unsigned;
75
 
 
76
 
  end;
77
 
 
78
 
{ GLOBAL VARIABLES & CONSTANTS }
79
 
{ GLOBAL PROCEDURES }
80
 
 
81
 
 
82
 
IMPLEMENTATION
83
 
{ LOCAL VARIABLES & CONSTANTS }
84
 
{ UNIT IMPLEMENTATION }
85
 
{ CONSTRUCT }
86
 
constructor vpgen_clip_polygon.Construct;
87
 
begin
88
 
 m_clip_box.Construct(0 ,0 ,1 ,1 );
89
 
 
90
 
 m_x1:=0;
91
 
 m_y1:=0;
92
 
 
93
 
 m_clip_flags  :=0;
94
 
 m_num_vertices:=0;
95
 
 
96
 
 m_vertex:=0;
97
 
 m_cmd   :=path_cmd_move_to;
98
 
 
99
 
end;
100
 
 
101
 
{ CLIP_BOX_ }
102
 
procedure vpgen_clip_polygon.clip_box_;
103
 
begin
104
 
 m_clip_box.x1:=x1;
105
 
 m_clip_box.y1:=y1;
106
 
 m_clip_box.x2:=x2;
107
 
 m_clip_box.y2:=y2;
108
 
 
109
 
 m_clip_box.normalize;
110
 
 
111
 
end;
112
 
 
113
 
{ _X1 }
114
 
function vpgen_clip_polygon._x1;
115
 
begin
116
 
 result:=m_clip_box.x1;
117
 
 
118
 
end;
119
 
 
120
 
{ _Y1 }
121
 
function vpgen_clip_polygon._y1;
122
 
begin
123
 
 result:=m_clip_box.y1;
124
 
 
125
 
end;
126
 
 
127
 
{ _X2 }
128
 
function vpgen_clip_polygon._x2;
129
 
begin
130
 
 result:=m_clip_box.x2;
131
 
 
132
 
end;
133
 
 
134
 
{ _Y2 }
135
 
function vpgen_clip_polygon._y2;
136
 
begin
137
 
 result:=m_clip_box.y2;
138
 
 
139
 
end;
140
 
 
141
 
{ _AUTO_CLOSE }
142
 
function vpgen_clip_polygon._auto_close;
143
 
begin
144
 
 result:=true;
145
 
 
146
 
end;
147
 
 
148
 
{ _AUTO_UNCLOSE }
149
 
function vpgen_clip_polygon._auto_unclose;
150
 
begin
151
 
 result:=false;
152
 
 
153
 
end;
154
 
 
155
 
{ RESET }
156
 
procedure vpgen_clip_polygon.reset;
157
 
begin
158
 
 m_vertex      :=0;
159
 
 m_num_vertices:=0;
160
 
 
161
 
end;
162
 
 
163
 
{ MOVE_TO }
164
 
procedure vpgen_clip_polygon.move_to;
165
 
begin
166
 
 m_vertex      :=0;
167
 
 m_num_vertices:=0;
168
 
 m_clip_flags  :=clipping_flags(x ,y );
169
 
 
170
 
 if m_clip_flags = 0 then
171
 
  begin
172
 
   m_x[0 ]:=x;
173
 
   m_y[0 ]:=y;
174
 
 
175
 
   m_num_vertices:=1;
176
 
 
177
 
  end;
178
 
 
179
 
 m_x1 :=x;
180
 
 m_y1 :=y;
181
 
 m_cmd:=path_cmd_move_to;
182
 
 
183
 
end;
184
 
 
185
 
{ LINE_TO }
186
 
procedure vpgen_clip_polygon.line_to;
187
 
var
188
 
 flags : unsigned;
189
 
 
190
 
begin
191
 
 m_vertex      :=0;
192
 
 m_num_vertices:=0;
193
 
 
194
 
 flags:=clipping_flags(x ,y );
195
 
 
196
 
 if m_clip_flags = flags then
197
 
  if flags = 0 then
198
 
   begin
199
 
    m_x[0 ]:=x;
200
 
    m_y[0 ]:=y;
201
 
 
202
 
    m_num_vertices:=1;
203
 
 
204
 
   end
205
 
  else
206
 
 else
207
 
  m_num_vertices:=
208
 
   clip_liang_barsky_d(
209
 
    m_x1 ,m_y1 ,x ,y ,@m_clip_box ,@m_x ,@m_y );
210
 
 
211
 
 m_clip_flags:=flags;
212
 
 
213
 
 m_x1:=x;
214
 
 m_y1:=y;
215
 
 
216
 
end;
217
 
 
218
 
{ VERTEX }
219
 
function vpgen_clip_polygon.vertex;
220
 
var
221
 
 cmd : unsigned;
222
 
 
223
 
begin
224
 
 if m_vertex < m_num_vertices then
225
 
  begin
226
 
   x^:=m_x[m_vertex ];
227
 
   y^:=m_y[m_vertex ];
228
 
 
229
 
   inc(m_vertex );
230
 
 
231
 
   cmd  :=m_cmd;
232
 
   m_cmd:=path_cmd_line_to;
233
 
 
234
 
   result:=cmd;
235
 
 
236
 
  end
237
 
 else
238
 
  result:=path_cmd_stop;
239
 
 
240
 
end;
241
 
 
242
 
{ CLIPPING_FLAGS }
243
 
// Determine the clipping code of the vertex according to the 
244
 
// Cyrus-Beck line clipping algorithm
245
 
//
246
 
//        |        |
247
 
//  0110  |  0010  | 0011
248
 
//        |        |
249
 
// -------+--------+-------- clip_box.y2
250
 
//        |        |
251
 
//  0100  |  0000  | 0001
252
 
//        |        |
253
 
// -------+--------+-------- clip_box.y1
254
 
//        |        |
255
 
//  1100  |  1000  | 1001
256
 
//        |        |
257
 
//  clip_box.x1  clip_box.x2
258
 
function vpgen_clip_polygon.clipping_flags;
259
 
begin
260
 
 if x < m_clip_box.x1 then
261
 
  begin
262
 
   if y > m_clip_box.y2 then
263
 
    begin
264
 
     result:=6;
265
 
 
266
 
     exit;
267
 
 
268
 
    end;
269
 
 
270
 
   if y < m_clip_box.y1 then
271
 
    begin
272
 
     result:=12;
273
 
 
274
 
     exit;
275
 
 
276
 
    end;
277
 
 
278
 
   result:=4;
279
 
 
280
 
   exit;
281
 
 
282
 
  end;
283
 
 
284
 
 if x > m_clip_box.x2 then
285
 
  begin
286
 
   if y > m_clip_box.y2 then
287
 
    begin
288
 
     result:=3;
289
 
 
290
 
     exit;
291
 
 
292
 
    end;
293
 
 
294
 
   if y < m_clip_box.y1 then
295
 
    begin
296
 
     result:=9;
297
 
 
298
 
     exit;
299
 
 
300
 
    end;
301
 
 
302
 
   result:=1;
303
 
 
304
 
   exit;
305
 
 
306
 
  end;
307
 
 
308
 
 if y > m_clip_box.y2 then
309
 
  begin
310
 
   result:=2;
311
 
 
312
 
   exit;
313
 
 
314
 
  end;
315
 
 
316
 
 if y < m_clip_box.y1 then
317
 
  begin
318
 
   result:=8;
319
 
 
320
 
   exit;
321
 
 
322
 
  end;
323
 
 
324
 
 result:=0;
325
 
 
326
 
end;
327
 
 
328
 
END.
329