1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- //----------------------------------------------------------------------------
- // Anti-Grain Geometry - Version 2.4
- // Copyright (C) 2002-2005 Maxim Shemanarev (http://www.antigrain.com)
- //
- // Permission to copy, use, modify, sell and distribute this software
- // is granted provided this copyright notice appears in all copies.
- // This software is provided "as is" without express or implied
- // warranty, and with no claim as to its suitability for any purpose.
- //
- //----------------------------------------------------------------------------
- // Contact: mcseem@antigrain.com
- // mcseemagg@yahoo.com
- // http://www.antigrain.com
- //----------------------------------------------------------------------------
- #ifndef AGG_PATH_LENGTH_INCLUDED
- #define AGG_PATH_LENGTH_INCLUDED
- #include "agg_math.h"
- namespace agg
- {
- template<class VertexSource>
- double path_length(VertexSource& vs, unsigned path_id = 0)
- {
- double len = 0.0;
- double start_x = 0.0;
- double start_y = 0.0;
- double x1 = 0.0;
- double y1 = 0.0;
- double x2 = 0.0;
- double y2 = 0.0;
- bool first = true;
- unsigned cmd;
- vs.rewind(path_id);
- while(!is_stop(cmd = vs.vertex(&x2, &y2)))
- {
- if(is_vertex(cmd))
- {
- if(first || is_move_to(cmd))
- {
- start_x = x2;
- start_y = y2;
- }
- else
- {
- len += calc_distance(x1, y1, x2, y2);
- }
- x1 = x2;
- y1 = y2;
- first = false;
- }
- else
- {
- if(is_close(cmd) && !first)
- {
- len += calc_distance(x1, y1, start_x, start_y);
- }
- }
- }
- return len;
- }
- }
- #endif
|