X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=src%2Fseltrans.h;h=8b2810621089b8d4d18ee960df6d452b06d69e4f;hb=9af0d2591bcbc964f2704842dfb2d9a23203c4cd;hp=58a6d5d29b4fb6e1be2ccaa674f1a47448f6b499;hpb=4ee3b5c46c0703d6842247c303f8ec6defd826f4;p=inkscape.git diff --git a/src/seltrans.h b/src/seltrans.h index 58a6d5d29..8b2810621 100644 --- a/src/seltrans.h +++ b/src/seltrans.h @@ -4,9 +4,10 @@ /* * Helper object for transforming selected items * - * Author: + * Authors: * Lauris Kaplinski * Carl Hetherington + * Diederik van Lierop * * Copyright (C) 2006 Johan Engelen * Copyright (C) 1999-2002 Lauris Kaplinski @@ -15,9 +16,9 @@ */ #include -#include -#include -#include +#include <2geom/point.h> +#include <2geom/matrix.h> +#include <2geom/rect.h> #include "knot.h" #include "forward.h" #include "selcue.h" @@ -32,6 +33,8 @@ class SPSelTransHandle; namespace Inkscape { +Geom::Scale calcScaleFactors(Geom::Point const &initial_point, Geom::Point const &new_point, Geom::Point const &origin, bool const skew = false); + namespace XML { class Node; @@ -49,26 +52,26 @@ public: void increaseState(); void resetState(); - void setCenter(NR::Point const &p); - void grab(NR::Point const &p, gdouble x, gdouble y, bool show_handles); - void transform(NR::Matrix const &rel_affine, NR::Point const &norm); + void setCenter(Geom::Point const &p); + void grab(Geom::Point const &p, gdouble x, gdouble y, bool show_handles, bool translating); + void transform(Geom::Matrix const &rel_affine, Geom::Point const &norm); void ungrab(); void stamp(); - void moveTo(NR::Point const &xy, guint state); - void stretch(SPSelTransHandle const &handle, NR::Point &pt, guint state); - void scale(NR::Point &pt, guint state); - void skew(SPSelTransHandle const &handle, NR::Point &pt, guint state); - void rotate(NR::Point &pt, guint state); - gboolean scaleRequest(NR::Point &pt, guint state); - gboolean stretchRequest(SPSelTransHandle const &handle, NR::Point &pt, guint state); - gboolean skewRequest(SPSelTransHandle const &handle, NR::Point &pt, guint state); - gboolean rotateRequest(NR::Point &pt, guint state); - gboolean centerRequest(NR::Point &pt, guint state); - - gboolean handleRequest(SPKnot *knot, NR::Point *position, guint state, SPSelTransHandle const &handle); + void moveTo(Geom::Point const &xy, guint state); + void stretch(SPSelTransHandle const &handle, Geom::Point &pt, guint state); + void scale(Geom::Point &pt, guint state); + void skew(SPSelTransHandle const &handle, Geom::Point &pt, guint state); + void rotate(Geom::Point &pt, guint state); + gboolean scaleRequest(Geom::Point &pt, guint state); + gboolean stretchRequest(SPSelTransHandle const &handle, Geom::Point &pt, guint state); + gboolean skewRequest(SPSelTransHandle const &handle, Geom::Point &pt, guint state); + gboolean rotateRequest(Geom::Point &pt, guint state); + gboolean centerRequest(Geom::Point &pt, guint state); + + gboolean handleRequest(SPKnot *knot, Geom::Point *position, guint state, SPSelTransHandle const &handle); void handleGrab(SPKnot *knot, guint state, SPSelTransHandle const &handle); void handleClick(SPKnot *knot, guint state, SPSelTransHandle const &handle); - void handleNewEvent(SPKnot *knot, NR::Point *position, guint state, SPSelTransHandle const &handle); + void handleNewEvent(SPKnot *knot, Geom::Point *position, guint state, SPSelTransHandle const &handle); enum Show { @@ -83,7 +86,7 @@ public: return _empty; } bool isGrabbed() { - return _grabbed; + return _grabbed; } bool centerIsVisible() { return ( _chandle && SP_KNOT_IS_VISIBLE (_chandle) ); @@ -96,20 +99,28 @@ private: void _selModified(Inkscape::Selection *selection, guint flags); void _showHandles(SPKnot *knot[], SPSelTransHandle const handle[], gint num, gchar const *even_tip, gchar const *odd_tip); + Geom::Point _getGeomHandlePos(Geom::Point const &visual_handle_pos); + Geom::Point _calcAbsAffineDefault(Geom::Scale const default_scale); + Geom::Point _calcAbsAffineGeom(Geom::Scale const geom_scale); + void _keepClosestPointOnly(std::vector &points, const Geom::Point &reference); + void _display_snapsource(); enum State { - STATE_SCALE, - STATE_ROTATE + STATE_SCALE, //scale or stretch + STATE_ROTATE //rotate or skew }; - + SPDesktop *_desktop; - std::vector > _items; - std::vector > _items_centers; - - std::vector _snap_points; - std::vector _bbox_points; - + std::vector _items; + std::vector _items_const; + std::vector _items_affines; + std::vector _items_centers; + + std::vector _snap_points; + std::vector _bbox_points; // the bbox point of the selection as a whole, i.e. max. 4 corners plus optionally some midpoints + std::vector _bbox_points_for_translating; // the bbox points of each selected item, only to be used for translating + Inkscape::SelCue _selcue; Inkscape::Selection *_selection; @@ -122,19 +133,31 @@ private: bool _changed; SPItem::BBoxType _snap_bbox_type; - - NR::Maybe _bbox; - NR::Maybe _approximate_bbox; - gdouble _strokewidth; - NR::Matrix _current; - NR::Point _opposite; ///< opposite point to where a scale is taking place - NR::Point _opposite_for_specpoints; - NR::Point _opposite_for_bboxpoints; - NR::Point _origin_for_specpoints; - NR::Point _origin_for_bboxpoints; + Geom::OptRect _bbox; + Geom::OptRect _approximate_bbox; + Geom::OptRect _geometric_bbox; + gdouble _strokewidth; - NR::Maybe _center; + Geom::Matrix _current_relative_affine; + Geom::Matrix _absolute_affine; + Geom::Matrix _relative_affine; + /* According to Merriam - Webster's online dictionary + * Affine: a transformation (as a translation, a rotation, or a uniform stretching) that carries straight + * lines into straight lines and parallel lines into parallel lines but may alter distance between points + * and angles between lines + */ + + Geom::Point _opposite; ///< opposite point to where a scale is taking place + Geom::Point _opposite_for_specpoints; + Geom::Point _opposite_for_bboxpoints; + Geom::Point _origin_for_specpoints; + Geom::Point _origin_for_bboxpoints; + + gdouble _handle_x; + gdouble _handle_y; + + boost::optional _center; bool _center_is_set; ///< we've already set _center, no need to reread it from items SPKnot *_shandle[8]; @@ -147,11 +170,12 @@ private: guint _sel_modified_id; GSList *_stamp_cache; - NR::Point _origin; ///< position of origin for transforms - NR::Point _point; ///< original position of the knot being used for the current transform + Geom::Point _origin; ///< position of origin for transforms + Geom::Point _point; ///< original position of the knot being used for the current transform + Geom::Point _point_geom; ///< original position of the knot being used for the current transform Inkscape::MessageContext _message_context; - SigC::Connection _sel_changed_connection; - SigC::Connection _sel_modified_connection; + sigc::connection _sel_changed_connection; + sigc::connection _sel_modified_connection; }; }