aboutsummaryrefslogtreecommitdiffstats
path: root/libgnomecanvas
diff options
context:
space:
mode:
Diffstat (limited to 'libgnomecanvas')
-rw-r--r--libgnomecanvas/gnome-canvas-util.c473
-rw-r--r--libgnomecanvas/gnome-canvas-util.h73
2 files changed, 0 insertions, 546 deletions
diff --git a/libgnomecanvas/gnome-canvas-util.c b/libgnomecanvas/gnome-canvas-util.c
index d396db0a1e..1a2e0b2ca3 100644
--- a/libgnomecanvas/gnome-canvas-util.c
+++ b/libgnomecanvas/gnome-canvas-util.c
@@ -44,358 +44,10 @@
#include <math.h>
#include "gnome-canvas.h"
#include "gnome-canvas-util.h"
-#include <libart_lgpl/art_uta.h>
-#include <libart_lgpl/art_svp.h>
-#include <libart_lgpl/art_svp_ops.h>
-#include <libart_lgpl/art_rgb.h>
-#include <libart_lgpl/art_rgb_svp.h>
-#include <libart_lgpl/art_uta_svp.h>
-#include <libart_lgpl/art_rect_svp.h>
-
-/**
- * gnome_canvas_get_miter_points:
- * @x1: X coordinate of the first point
- * @y1: Y coordinate of the first point
- * @x2: X coordinate of the second (angle) point
- * @y2: Y coordinate of the second (angle) point
- * @x3: X coordinate of the third point
- * @y3: Y coordinate of the third point
- * @width: Width of the line
- * @mx1: The X coordinate of the first miter point is returned here.
- * @my1: The Y coordinate of the first miter point is returned here.
- * @mx2: The X coordinate of the second miter point is returned here.
- * @my2: The Y coordinate of the second miter point is returned here.
- *
- * Given three points forming an angle, computes the coordinates of the inside
- * and outside points of the mitered corner formed by a line of a given width at
- * that angle.
- *
- * Return value: FALSE if the angle is less than 11 degrees (this is the same
- * threshold as X uses. If this occurs, the return points are not modified.
- * Otherwise, returns TRUE.
- **/
-gint
-gnome_canvas_get_miter_points (gdouble x1,
- gdouble y1,
- gdouble x2,
- gdouble y2,
- gdouble x3,
- gdouble y3,
- gdouble width,
- gdouble *mx1,
- gdouble *my1,
- gdouble *mx2,
- gdouble *my2)
-{
- gdouble theta1; /* angle of segment p2-p1 */
- gdouble theta2; /* angle of segment p2-p3 */
- gdouble theta; /* angle between line segments */
- gdouble theta3; /* angle that bisects theta1 and theta2 and points to p1 */
- gdouble dist; /* distance of miter points from p2 */
- gdouble dx, dy; /* x and y offsets corresponding to dist */
-
-#define ELEVEN_DEGREES (11.0 * G_PI / 180.0)
-
- if (y2 == y1)
- theta1 = (x2 < x1) ? 0.0 : G_PI;
- else if (x2 == x1)
- theta1 = (y2 < y1) ? G_PI_2 : -G_PI_2;
- else
- theta1 = atan2 (y1 - y2, x1 - x2);
-
- if (y3 == y2)
- theta2 = (x3 > x2) ? 0 : G_PI;
- else if (x3 == x2)
- theta2 = (y3 > y2) ? G_PI_2 : -G_PI_2;
- else
- theta2 = atan2 (y3 - y2, x3 - x2);
-
- theta = theta1 - theta2;
-
- if (theta > G_PI)
- theta -= 2.0 * G_PI;
- else if (theta < -G_PI)
- theta += 2.0 * G_PI;
-
- if ((theta < ELEVEN_DEGREES) && (theta > -ELEVEN_DEGREES))
- return FALSE;
-
- dist = 0.5 * width / sin (0.5 * theta);
- if (dist < 0.0)
- dist = -dist;
-
- theta3 = (theta1 + theta2) / 2.0;
- if (sin (theta3 - (theta1 + G_PI)) < 0.0)
- theta3 += G_PI;
-
- dx = dist * cos (theta3);
- dy = dist * sin (theta3);
-
- *mx1 = x2 + dx;
- *mx2 = x2 - dx;
- *my1 = y2 + dy;
- *my2 = y2 - dy;
-
- return TRUE;
-}
-
-/**
- * gnome_canvas_get_butt_points:
- * @x1: X coordinate of first point in the line
- * @y1: Y cooordinate of first point in the line
- * @x2: X coordinate of second point (endpoint) of the line
- * @y2: Y coordinate of second point (endpoint) of the line
- * @width: Width of the line
- * @project: Whether the butt points should project out by width/2 distance
- * @bx1: X coordinate of first butt point is returned here
- * @by1: Y coordinate of first butt point is returned here
- * @bx2: X coordinate of second butt point is returned here
- * @by2: Y coordinate of second butt point is returned here
- *
- * Computes the butt points of a line segment.
- **/
-void
-gnome_canvas_get_butt_points (gdouble x1, gdouble y1, gdouble x2, gdouble y2,
- gdouble width, gint project,
- gdouble *bx1, gdouble *by1, gdouble *bx2, gdouble *by2)
-{
- gdouble length;
- gdouble dx, dy;
-
- width *= 0.5;
- dx = x2 - x1;
- dy = y2 - y1;
- length = sqrt (dx * dx + dy * dy);
-
- if (length < GNOME_CANVAS_EPSILON) {
- *bx1 = *bx2 = x2;
- *by1 = *by2 = y2;
- } else {
- dx = -width * (y2 - y1) / length;
- dy = width * (x2 - x1) / length;
-
- *bx1 = x2 + dx;
- *bx2 = x2 - dx;
- *by1 = y2 + dy;
- *by2 = y2 - dy;
-
- if (project) {
- *bx1 += dy;
- *bx2 += dy;
- *by1 -= dx;
- *by2 -= dx;
- }
- }
-}
-
-/**
- * gnome_canvas_polygon_to_point:
- * @poly: Vertices of the polygon. X coordinates are in the even indices, and Y
- * coordinates are in the odd indices
- * @num_points: Number of points in the polygon
- * @x: X coordinate of the point
- * @y: Y coordinate of the point
- *
- * Computes the distance between a point and a polygon.
- *
- * Return value: The distance from the point to the polygon, or zero if the
- * point is inside the polygon.
- **/
-gdouble
-gnome_canvas_polygon_to_point (gdouble *poly, gint num_points, gdouble x, gdouble y)
-{
- gdouble best;
- gint intersections;
- gint i;
- gdouble *p;
- gdouble dx, dy;
-
- /* Iterate through all the edges in the polygon, updating best and
- * intersections.
- *
- * When computing intersections, include left X coordinate of line
- * within its range, but not Y coordinate. Otherwise if the point
- * lies exactly below a vertex we'll count it as two intersections. */
-
- best = 1.0e36;
- intersections = 0;
-
- for (i = num_points, p = poly; i > 1; i--, p += 2) {
- gdouble px, py, dist;
-
- /* Compute the point on the current edge closest to the
- * point and update the intersection count. This must be
- * done separately for vertical edges, horizontal edges,
- * and others. */
-
- if (p[2] == p[0]) {
- /* Vertical edge */
-
- px = p[0];
-
- if (p[1] >= p[3]) {
- py = MIN (p[1], y);
- py = MAX (py, p[3]);
- } else {
- py = MIN (p[3], y);
- py = MAX (py, p[1]);
- }
- } else if (p[3] == p[1]) {
- /* Horizontal edge */
-
- py = p[1];
-
- if (p[0] >= p[2]) {
- px = MIN (p[0], x);
- px = MAX (px, p[2]);
-
- if ((y < py) && (x < p[0]) && (x >= p[2]))
- intersections++;
- } else {
- px = MIN (p[2], x);
- px = MAX (px, p[0]);
-
- if ((y < py) && (x < p[2]) && (x >= p[0]))
- intersections++;
- }
- } else {
- gdouble m1, b1, m2, b2;
- gint lower;
-
- /* Diagonal edge. Convert the edge to a line equation (y = m1*x + b1), then
- * compute a line perpendicular to this edge but passing through the point,
- * (y = m2*x + b2).
- */
-
- m1 = (p[3] - p[1]) / (p[2] - p[0]);
- b1 = p[1] - m1 * p[0];
-
- m2 = -1.0 / m1;
- b2 = y - m2 * x;
-
- px = (b2 - b1) / (m1 - m2);
- py = m1 * px + b1;
-
- if (p[0] > p[2]) {
- if (px > p[0]) {
- px = p[0];
- py = p[1];
- } else if (px < p[2]) {
- px = p[2];
- py = p[3];
- }
- } else {
- if (px > p[2]) {
- px = p[2];
- py = p[3];
- } else if (px < p[0]) {
- px = p[0];
- py = p[1];
- }
- }
-
- lower = (m1 * x + b1) > y;
-
- if (lower && (x >= MIN (p[0], p[2])) && (x < MAX (p[0], p[2])))
- intersections++;
- }
-
- /* Compute the distance to the closest point, and see if that is the best so far */
-
- dx = x - px;
- dy = y - py;
- dist = sqrt (dx * dx + dy * dy);
- if (dist < best)
- best = dist;
- }
-
- /* We've processed all the points. If the number of
- * intersections is odd, the point is inside the polygon. */
-
- if (intersections & 0x1)
- return 0.0;
- else
- return best;
-}
/* Here are some helper functions for aa rendering: */
/**
- * gnome_canvas_update_svp:
- * @canvas: the canvas containing the svp that needs updating.
- * @p_svp: a pointer to the existing svp
- * @new_svp: the new svp
- *
- * Sets the svp to the new value, requesting repaint on what's changed. This
- * function takes responsibility for freeing new_svp.
- **/
-void
-gnome_canvas_update_svp (GnomeCanvas *canvas, ArtSVP **p_svp, ArtSVP *new_svp)
-{
- ArtSVP *old_svp;
- ArtSVP *diff G_GNUC_UNUSED;
- ArtUta *repaint_uta;
-
- old_svp = *p_svp;
-
- if (old_svp != NULL) {
- ArtDRect bb;
- art_drect_svp (&bb, old_svp);
- if ((bb.x1 - bb.x0) * (bb.y1 - bb.y0) > (64 * 64)) {
- repaint_uta = art_uta_from_svp (old_svp);
- gnome_canvas_request_redraw_uta (canvas, repaint_uta);
- } else {
- ArtIRect ib;
- art_drect_to_irect (&ib, &bb);
- gnome_canvas_request_redraw (canvas, ib.x0, ib.y0, ib.x1, ib.y1);
- }
- art_svp_free (old_svp);
- }
-
- if (new_svp != NULL) {
- ArtDRect bb;
- art_drect_svp (&bb, new_svp);
- if ((bb.x1 - bb.x0) * (bb.y1 - bb.y0) > (64 * 64)) {
- repaint_uta = art_uta_from_svp (new_svp);
- gnome_canvas_request_redraw_uta (canvas, repaint_uta);
- } else {
- ArtIRect ib;
- art_drect_to_irect (&ib, &bb);
- gnome_canvas_request_redraw (canvas, ib.x0, ib.y0, ib.x1, ib.y1);
- }
- }
-
- *p_svp = new_svp;
-}
-
-/**
- * gnome_canvas_update_svp_clip:
- * @canvas: the canvas containing the svp that needs updating.
- * @p_svp: a pointer to the existing svp
- * @new_svp: the new svp
- * @clip_svp: a clip path, if non-null
- *
- * Sets the svp to the new value, clipping if necessary, and requesting repaint
- * on what's changed. This function takes responsibility for freeing new_svp.
- **/
-void
-gnome_canvas_update_svp_clip (GnomeCanvas *canvas,
- ArtSVP **p_svp,
- ArtSVP *new_svp,
- ArtSVP *clip_svp)
-{
- ArtSVP *clipped_svp;
-
- if (clip_svp != NULL) {
- clipped_svp = art_svp_intersect (new_svp, clip_svp);
- art_svp_free (new_svp);
- } else {
- clipped_svp = new_svp;
- }
- gnome_canvas_update_svp (canvas, p_svp, clipped_svp);
-}
-
-/**
* gnome_canvas_item_reset_bounds:
* @item: A canvas item
*
@@ -411,76 +63,6 @@ gnome_canvas_item_reset_bounds (GnomeCanvasItem *item)
}
/**
- * gnome_canvas_item_update_svp:
- * @item: the canvas item containing the svp that needs updating.
- * @p_svp: a pointer to the existing svp
- * @new_svp: the new svp
- *
- * Sets the svp to the new value, requesting repaint on what's changed. This
- * function takes responsibility for freeing new_svp. This routine also adds the
- * svp's bbox to the item's.
- **/
-void
-gnome_canvas_item_update_svp (GnomeCanvasItem *item, ArtSVP **p_svp, ArtSVP *new_svp)
-{
- ArtDRect bbox;
-
- gnome_canvas_update_svp (item->canvas, p_svp, new_svp);
- if (new_svp) {
- bbox.x0 = item->x1;
- bbox.y0 = item->y1;
- bbox.x1 = item->x2;
- bbox.y1 = item->y2;
- art_drect_svp_union (&bbox, new_svp);
- item->x1 = bbox.x0;
- item->y1 = bbox.y0;
- item->x2 = bbox.x1;
- item->y2 = bbox.y1;
- }
-}
-
-/**
- * gnome_canvas_item_update_svp_clip:
- * @item: the canvas item containing the svp that needs updating.
- * @p_svp: a pointer to the existing svp
- * @new_svp: the new svp
- * @clip_svp: a clip path, if non-null
- *
- * Sets the svp to the new value, clipping if necessary, and requesting repaint
- * on what's changed. This function takes responsibility for freeing new_svp.
- **/
-void
-gnome_canvas_item_update_svp_clip (GnomeCanvasItem *item,
- ArtSVP **p_svp,
- ArtSVP *new_svp,
- ArtSVP *clip_svp)
-{
- ArtSVP *clipped_svp;
-
- if (clip_svp != NULL) {
- clipped_svp = art_svp_intersect (new_svp, clip_svp);
- art_svp_free (new_svp);
- } else {
- clipped_svp = new_svp;
- }
-
- gnome_canvas_item_update_svp (item, p_svp, clipped_svp);
-}
-
-/**
- * gnome_canvas_item_request_redraw_svp
- * @item: the item containing the svp
- * @svp: the svp that needs to be redrawn
- *
- * Request redraw of the svp if in aa mode, or the entire item in in xlib mode.
- **/
-void
-gnome_canvas_item_request_redraw_svp (GnomeCanvasItem *item, const ArtSVP *svp)
-{
- gnome_canvas_request_redraw (item->canvas, item->x1, item->y1, item->x2, item->y2);
-}
-
-/**
* gnome_canvas_update_bbox:
* @item: the canvas item needing update
* @x1: Left coordinate of the new bounding box
@@ -502,61 +84,6 @@ gnome_canvas_update_bbox (GnomeCanvasItem *item, gint x1, gint y1, gint x2, gint
}
/**
- * gnome_canvas_join_gdk_to_art
- * @gdk_join: a join type, represented in GDK format
- *
- * Convert from GDK line join specifier to libart.
- *
- * Return value: The line join specifier in libart format.
- **/
-ArtPathStrokeJoinType
-gnome_canvas_join_gdk_to_art (GdkJoinStyle gdk_join)
-{
- switch (gdk_join) {
- case GDK_JOIN_MITER:
- return ART_PATH_STROKE_JOIN_MITER;
-
- case GDK_JOIN_ROUND:
- return ART_PATH_STROKE_JOIN_ROUND;
-
- case GDK_JOIN_BEVEL:
- return ART_PATH_STROKE_JOIN_BEVEL;
-
- default:
- g_assert_not_reached ();
- return ART_PATH_STROKE_JOIN_MITER; /* shut up the compiler */
- }
-}
-
-/**
- * gnome_canvas_cap_gdk_to_art
- * @gdk_cap: a cap type, represented in GDK format
- *
- * Convert from GDK line cap specifier to libart.
- *
- * Return value: The line cap specifier in libart format.
- **/
-ArtPathStrokeCapType
-gnome_canvas_cap_gdk_to_art (GdkCapStyle gdk_cap)
-{
- switch (gdk_cap) {
- case GDK_CAP_BUTT:
- case GDK_CAP_NOT_LAST:
- return ART_PATH_STROKE_CAP_BUTT;
-
- case GDK_CAP_ROUND:
- return ART_PATH_STROKE_CAP_ROUND;
-
- case GDK_CAP_PROJECTING:
- return ART_PATH_STROKE_CAP_SQUARE;
-
- default:
- g_assert_not_reached ();
- return ART_PATH_STROKE_CAP_BUTT; /* shut up the compiler */
- }
-}
-
-/**
* gnome_canvas_cairo_create_scratch:
*
* Create a scratch #cairo_t. This is useful for measuring purposes or
diff --git a/libgnomecanvas/gnome-canvas-util.h b/libgnomecanvas/gnome-canvas-util.h
index 1a29221f29..bc7dee9c50 100644
--- a/libgnomecanvas/gnome-canvas-util.h
+++ b/libgnomecanvas/gnome-canvas-util.h
@@ -35,90 +35,17 @@
#include <libgnomecanvas/gnome-canvas.h>
-#include <libart_lgpl/art_svp.h>
-#include <libart_lgpl/art_vpath.h>
-#include <libart_lgpl/art_svp_vpath_stroke.h>
-
G_BEGIN_DECLS
-/* Given three points forming an angle, compute the coordinates of the inside and outside points of
- * the mitered corner formed by a line of a given width at that angle.
- *
- * If the angle is less than 11 degrees, then FALSE is returned and the return points are not
- * modified. Otherwise, TRUE is returned.
- */
-gint gnome_canvas_get_miter_points (gdouble x1, gdouble y1, gdouble x2, gdouble y2, gdouble x3, gdouble y3,
- gdouble width,
- gdouble *mx1, gdouble *my1, gdouble *mx2, gdouble *my2);
-
-/* Compute the butt points of a line segment. If project is FALSE, then the results are as follows:
- *
- * -------------------* (bx1, by1)
- * |
- * (x1, y1) *------------------* (x2, y2)
- * |
- * -------------------* (bx2, by2)
- *
- * that is, the line is not projected beyond (x2, y2). If project is TRUE, then the results are as
- * follows:
- *
- * -------------------* (bx1, by1)
- * (x2, y2) |
- * (x1, y1) *-------------* |
- * |
- * -------------------* (bx2, by2)
- */
-void gnome_canvas_get_butt_points (gdouble x1, gdouble y1, gdouble x2, gdouble y2,
- gdouble width, gint project,
- gdouble *bx1, gdouble *by1, gdouble *bx2, gdouble *by2);
-
-/* Calculate the distance from a polygon to a point. The polygon's X coordinates are in the even
- * indices of the poly array, and the Y coordinates are in the odd indices.
- */
-gdouble gnome_canvas_polygon_to_point (gdouble *poly, gint num_points, gdouble x, gdouble y);
-
-/* Sets the svp to the new value, requesting repaint on what's changed. This function takes responsibility for
- * freeing new_svp.
- */
-void gnome_canvas_update_svp (GnomeCanvas *canvas, ArtSVP **p_svp, ArtSVP *new_svp);
-
-/* Sets the svp to the new value, clipping if necessary, and requesting repaint
- * on what's changed. This function takes responsibility for freeing new_svp.
- */
-void gnome_canvas_update_svp_clip (GnomeCanvas *canvas, ArtSVP **p_svp, ArtSVP *new_svp,
- ArtSVP *clip_svp);
-
/* Sets the svp to the new value, requesting repaint on what's changed. This
* function takes responsibility for freeing new_svp. This routine also adds the
* svp's bbox to the item's.
*/
void gnome_canvas_item_reset_bounds (GnomeCanvasItem *item);
-/* Sets the svp to the new value, requesting repaint on what's changed. This function takes responsibility for
- * freeing new_svp. This routine also adds the svp's bbox to the item's.
- */
-void gnome_canvas_item_update_svp (GnomeCanvasItem *item, ArtSVP **p_svp, ArtSVP *new_svp);
-
-/* Sets the svp to the new value, clipping if necessary, and requesting repaint
- * on what's changed. This function takes responsibility for freeing new_svp.
- */
-void gnome_canvas_item_update_svp_clip (GnomeCanvasItem *item, ArtSVP **p_svp, ArtSVP *new_svp,
- ArtSVP *clip_svp);
-
-/* Request redraw of the svp if in aa mode, or the entire item in in xlib
- * mode.
- */
-void gnome_canvas_item_request_redraw_svp (GnomeCanvasItem *item, const ArtSVP *svp);
-
/* Sets the bbox to the new value, requesting full repaint. */
void gnome_canvas_update_bbox (GnomeCanvasItem *item, gint x1, gint y1, gint x2, gint y2);
-/* Convert from GDK line join specifier to libart. */
-ArtPathStrokeJoinType gnome_canvas_join_gdk_to_art (GdkJoinStyle gdk_join);
-
-/* Convert from GDK line cap specifier to libart. */
-ArtPathStrokeCapType gnome_canvas_cap_gdk_to_art (GdkCapStyle gdk_cap);
-
/* Create a scratch cairo_t for measuring purposes */
cairo_t *gnome_canvas_cairo_create_scratch (void);