[gimp/soc-2012-unified-transformation: 15/51] transformtool: Make rotation axis behave as spec



commit a532c77bca16ec3687c4667997599b5081100b13
Author: Mikael Magnusson <mikachu src gnome org>
Date:   Thu Jun 14 09:51:54 2012 +0200

    transformtool: Make rotation axis behave as spec

 app/tools/gimpunifiedtransformtool.c |   43 ++++++++++++++++++++++++++++++++-
 1 files changed, 41 insertions(+), 2 deletions(-)
---
diff --git a/app/tools/gimpunifiedtransformtool.c b/app/tools/gimpunifiedtransformtool.c
index 73aaeb8..1c251d1 100644
--- a/app/tools/gimpunifiedtransformtool.c
+++ b/app/tools/gimpunifiedtransformtool.c
@@ -719,7 +719,7 @@ gimp_unified_transform_tool_motion (GimpTransformTool *transform_tool)
 {
   gdouble diff_x = transform_tool->curx - transform_tool->lastx,
           diff_y = transform_tool->cury - transform_tool->lasty;
-  gdouble *x[4], *y[4], px[4], py[4], *pivot_x, *pivot_y;
+  gdouble *x[4], *y[4], px[5], py[5], *pivot_x, *pivot_y, ppivot_x, ppivot_y;
   gint i;
   gboolean horizontal = FALSE;
   GimpTransformOptions *options = GIMP_TRANSFORM_TOOL_GET_OPTIONS (transform_tool);
@@ -735,7 +735,7 @@ gimp_unified_transform_tool_motion (GimpTransformTool *transform_tool)
   y[1] = &transform_tool->trans_info[Y1];
   y[2] = &transform_tool->trans_info[Y2];
   y[3] = &transform_tool->trans_info[Y3];
-  
+
   px[0] = (*transform_tool->prev_trans_info)[X0];
   px[1] = (*transform_tool->prev_trans_info)[X1];
   px[2] = (*transform_tool->prev_trans_info)[X2];
@@ -745,9 +745,15 @@ gimp_unified_transform_tool_motion (GimpTransformTool *transform_tool)
   py[2] = (*transform_tool->prev_trans_info)[Y2];
   py[3] = (*transform_tool->prev_trans_info)[Y3];
 
+  px[4] = (px[0] + px[1] + px[2] + px[3]) / 4.;
+  py[4] = (py[0] + py[1] + py[2] + py[3]) / 4.;
+  
   pivot_x = &transform_tool->trans_info[PIVOT_X];
   pivot_y = &transform_tool->trans_info[PIVOT_Y];
 
+  ppivot_x = (*transform_tool->prev_trans_info)[PIVOT_X];
+  ppivot_y = (*transform_tool->prev_trans_info)[PIVOT_Y];
+
   if (function == TRANSFORM_HANDLE_CENTER)
     {
       gdouble dx = transform_tool->curx - transform_tool->mousex;
@@ -801,6 +807,39 @@ gimp_unified_transform_tool_motion (GimpTransformTool *transform_tool)
       }
     }
 
+  if (function == TRANSFORM_HANDLE_PIVOT)
+    {
+      gdouble dx = transform_tool->curx - transform_tool->mousex;
+      gdouble dy = transform_tool->cury - transform_tool->mousey;
+
+      gint screenx, screeny;
+
+      if (constrain)
+        {
+          /* snap to corner points and center */
+          gint closest;
+          gdouble closest_dist = G_MAXDOUBLE, dist;
+          for (i = 0; i < 5; i++)
+            {
+              dist = norm (vectorsubtract ((GimpVector2){transform_tool->curx, transform_tool->cury}, (GimpVector2){px[i], py[i]}));
+              if (dist < closest_dist)
+                {
+                  closest_dist = dist;
+                  closest = i;
+                }
+            }
+          if (closest_dist * gimp_display_get_shell (GIMP_TOOL (transform_tool)->display)->scale_x < 50)
+            {
+              *pivot_x = px[closest];
+              *pivot_y = py[closest];
+
+              return;
+            }
+        }
+      *pivot_x = ppivot_x + dx;
+      *pivot_y = ppivot_y + dy;
+    }
+
   /* old code below */
 #if 0
   if (options->alternate)



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]