[gtk/for-master: 2/3] transform: Coalesce similar transforms



commit 7bfd96f3cf75c48bfa3ad626af00c6692a500b81
Author: Benjamin Otte <otte redhat com>
Date:   Sun Jun 2 14:16:45 2019 +0200

    transform: Coalesce similar transforms
    
    If somebody does a transform like
      scale(5) scale(10) translate(1,1) translate(5,0)
    store it instead as
      scale(50) translate(6,1)
    This way, less memory is consumed and transforms are easier to read.
    
    In particular, this simplifies the typical transforms we do in GTK,
    which are just one translation after another.

 gsk/gsktransform.c                          |  39 ++++++-
 testsuite/gsk/nodeparser/widgetfactory.node | 156 ++++++++++++++--------------
 2 files changed, 114 insertions(+), 81 deletions(-)
---
diff --git a/gsk/gsktransform.c b/gsk/gsktransform.c
index 3baf8bb061..02d05fdb9c 100644
--- a/gsk/gsktransform.c
+++ b/gsk/gsktransform.c
@@ -94,6 +94,13 @@ G_DEFINE_BOXED_TYPE (GskTransform, gsk_transform,
 static gboolean
 gsk_transform_is_identity (GskTransform *self);
 
+static inline gboolean
+gsk_transform_has_class (GskTransform            *self,
+                         const GskTransformClass *transform_class)
+{
+  return self != NULL && self->transform_class == transform_class;
+}
+
 /*< private >
  * gsk_transform_alloc:
  * @transform_class: class structure for this self
@@ -638,6 +645,15 @@ gsk_transform_translate_3d (GskTransform             *next,
 {
   GskTranslateTransform *result;
   
+  if (gsk_transform_has_class (next, &GSK_TRANSLATE_TRANSFORM_CLASS))
+    {
+      GskTranslateTransform *t = (GskTranslateTransform *) next;
+      return gsk_transform_translate_3d (next->next,
+                                         &GRAPHENE_POINT3D_INIT(t->point.x + point->x,
+                                                                t->point.y + point->y,
+                                                                t->point.z + point->z));
+    }
+
   result = gsk_transform_alloc (&GSK_TRANSLATE_TRANSFORM_CLASS,
                                 point->z == 0.0 ? GSK_TRANSFORM_CATEGORY_2D_TRANSLATE
                                                 : GSK_TRANSFORM_CATEGORY_3D,
@@ -777,9 +793,14 @@ GskTransform *
 gsk_transform_rotate (GskTransform *next,
                       float         angle)
 {
-  GskRotateTransform *result = gsk_transform_alloc (&GSK_ROTATE_TRANSFORM_CLASS,
-                                                    GSK_TRANSFORM_CATEGORY_2D,
-                                                    next);
+  GskRotateTransform *result;
+
+  if (gsk_transform_has_class (next, &GSK_ROTATE_TRANSFORM_CLASS))
+    return gsk_transform_rotate (next->next, ((GskRotateTransform *) next)->angle + angle);
+
+  result = gsk_transform_alloc (&GSK_ROTATE_TRANSFORM_CLASS,
+                                GSK_TRANSFORM_CATEGORY_2D,
+                                next);
 
   result->angle = angle;
 
@@ -1083,6 +1104,15 @@ gsk_transform_scale_3d (GskTransform *next,
 {
   GskScaleTransform *result;
   
+  if (gsk_transform_has_class (next, &GSK_SCALE_TRANSFORM_CLASS))
+    {
+      GskScaleTransform *scale = (GskScaleTransform *) next;
+      return gsk_transform_scale_3d (next->next,
+                                     scale->factor_x * factor_x,
+                                     scale->factor_y * factor_y,
+                                     scale->factor_z * factor_z);
+    }
+
   result = gsk_transform_alloc (&GSK_SCALE_TRANSFORM_CLASS,
                                 factor_z != 1.0 ? GSK_TRANSFORM_CATEGORY_3D
                                                 : GSK_TRANSFORM_CATEGORY_2D_AFFINE,
@@ -1200,6 +1230,9 @@ gsk_transform_perspective (GskTransform *next,
 {
   GskPerspectiveTransform *result;
   
+  if (gsk_transform_has_class (next, &GSK_PERSPECTIVE_TRANSFORM_CLASS))
+    return gsk_transform_perspective (next->next, ((GskPerspectiveTransform *) next)->depth + depth);
+
   result = gsk_transform_alloc (&GSK_PERSPECTIVE_TRANSFORM_CLASS,
                                 GSK_TRANSFORM_CATEGORY_ANY,
                                 next);
diff --git a/testsuite/gsk/nodeparser/widgetfactory.node b/testsuite/gsk/nodeparser/widgetfactory.node
index 36b5f1b328..e89375159f 100644
--- a/testsuite/gsk/nodeparser/widgetfactory.node
+++ b/testsuite/gsk/nodeparser/widgetfactory.node
@@ -104,7 +104,7 @@ transform {
                   transform: translate(28, 0);
                 }
               }
-              transform: translate(133, 0) translate(17, 11);
+              transform: translate(150, 11);
             }
             transform {
               child: container {
@@ -129,7 +129,7 @@ transform {
                   transform: translate(28, 0);
                 }
               }
-              transform: translate(266, 0) translate(17, 11);
+              transform: translate(283, 11);
             }
           }
           transform: translate(526, 0);
@@ -156,7 +156,7 @@ transform {
               offset: 0.572549 0.584314 0.584314 0;
             }
           }
-          transform: translate(1367, 0) translate(6, 11);
+          transform: translate(1373, 11);
         }
         transform {
           child: transform {
@@ -168,12 +168,12 @@ transform {
               matrix: matrix3d(-0.372549, 0.235294, -0.105882, 0, 0.388235, -0.109804, -0.584314, 0, 
0.227451, -0.584314, -0.584314, 0, 0, 0, 0, 1);
               offset: 0.572549 0.584314 0.584314 0;
             }
-            transform: translate(7, 0) translate(10, 11);
+            transform: translate(17, 11);
           }
           transform: translate(1409, 0);
         }
       }
-      transform: translate(26, 23) translate(6, 0);
+      transform: translate(32, 23);
     }
     transform {
       child: container {
@@ -245,7 +245,7 @@ transform {
                     offset: 0.572549 0.584314 0.584314 0;
                   }
                 }
-                transform: translate(374, 0) translate(10, 5);
+                transform: translate(384, 5);
               }
             }
             transform {
@@ -298,7 +298,7 @@ transform {
                       offset: 0.831373 0.811765 0.792157 0;
                     }
                   }
-                  transform: translate(374, 0) translate(10, 5);
+                  transform: translate(384, 5);
                 }
               }
               transform: translate(0, 44);
@@ -337,10 +337,10 @@ transform {
                     matrix: matrix3d(-0.454902, 0.152941, -0.188235, 0, 0.305882, -0.192157, -0.666667, 0, 
0.145098, -0.666667, -0.666667, 0, 0, 0, 0, 1);
                     offset: 0.654902 0.666667 0.666667 0;
                   }
-                  transform: translate(370, 0) translate(6, 0);
+                  transform: translate(376, 0);
                 }
               }
-              transform: translate(0, 88) translate(9, 1);
+              transform: translate(9, 89);
             }
             transform {
               child: container {
@@ -365,7 +365,7 @@ transform {
                   clip: 0 0 392 32;
                 }
               }
-              transform: translate(0, 132) translate(9, 1);
+              transform: translate(9, 133);
             }
             transform {
               child: container {
@@ -417,7 +417,7 @@ transform {
                       offset: 0.572549 0.584314 0.584314 0;
                     }
                   }
-                  transform: translate(374, 0) translate(6, 5);
+                  transform: translate(380, 5);
                 }
               }
               transform: translate(0, 176);
@@ -593,7 +593,7 @@ transform {
                             offset: 0.654902 0.666667 0.666667 0;
                           }
                         }
-                        transform: translate(40, 0) translate(6, 0);
+                        transform: translate(46, 0);
                       }
                       transform {
                         child: container {
@@ -611,11 +611,11 @@ transform {
                             offset: 0.654902 0.666667 0.666667 0;
                           }
                         }
-                        transform: translate(75, 0) translate(6, 0);
+                        transform: translate(81, 0);
                       }
                     }
                   }
-                  transform: translate(104, 0) translate(1, 1);
+                  transform: translate(105, 1);
                 }
                 transform {
                   child: container {
@@ -660,7 +660,7 @@ transform {
                             offset: 0.654902 0.666667 0.666667 0;
                           }
                         }
-                        transform: translate(40, 0) translate(6, 0);
+                        transform: translate(46, 0);
                       }
                       transform {
                         child: container {
@@ -685,11 +685,11 @@ transform {
                             offset: 0.654902 0.666667 0.666667 0;
                           }
                         }
-                        transform: translate(75, 0) translate(6, 0);
+                        transform: translate(81, 0);
                       }
                     }
                   }
-                  transform: translate(236, 0) translate(1, 1);
+                  transform: translate(237, 1);
                 }
               }
               transform: translate(0, 265);
@@ -756,7 +756,7 @@ transform {
                       transform: translate(24, 0);
                     }
                   }
-                  transform: translate(0, 29) translate(0, 2);
+                  transform: translate(0, 31);
                 }
                 transform {
                   child: container {
@@ -791,7 +791,7 @@ transform {
                       transform: translate(24, 0);
                     }
                   }
-                  transform: translate(0, 58) translate(0, 2);
+                  transform: translate(0, 60);
                 }
                 transform {
                   child: container {
@@ -826,7 +826,7 @@ transform {
                       transform: translate(24, 0);
                     }
                   }
-                  transform: translate(0, 87) translate(0, 2);
+                  transform: translate(0, 89);
                 }
                 transform {
                   child: container {
@@ -853,7 +853,7 @@ transform {
                       transform: translate(24, 0);
                     }
                   }
-                  transform: translate(0, 116) translate(0, 2);
+                  transform: translate(0, 118);
                 }
                 transform {
                   child: container {
@@ -888,7 +888,7 @@ transform {
                       transform: translate(24, 0);
                     }
                   }
-                  transform: translate(0, 145) translate(0, 2);
+                  transform: translate(0, 147);
                 }
                 transform {
                   child: container {
@@ -918,7 +918,7 @@ transform {
                       transform: translate(24, 0);
                     }
                   }
-                  transform: translate(125, 0) translate(0, 2);
+                  transform: translate(125, 2);
                 }
                 transform {
                   child: container {
@@ -948,7 +948,7 @@ transform {
                       transform: translate(24, 0);
                     }
                   }
-                  transform: translate(125, 29) translate(0, 2);
+                  transform: translate(125, 31);
                 }
                 transform {
                   child: container {
@@ -986,7 +986,7 @@ transform {
                       transform: translate(24, 0);
                     }
                   }
-                  transform: translate(125, 58) translate(0, 2);
+                  transform: translate(125, 60);
                 }
                 transform {
                   child: container {
@@ -1024,7 +1024,7 @@ transform {
                       transform: translate(24, 0);
                     }
                   }
-                  transform: translate(125, 87) translate(0, 2);
+                  transform: translate(125, 89);
                 }
                 transform {
                   child: container {
@@ -1054,7 +1054,7 @@ transform {
                       transform: translate(24, 0);
                     }
                   }
-                  transform: translate(125, 116) translate(0, 2);
+                  transform: translate(125, 118);
                 }
                 transform {
                   child: container {
@@ -1092,7 +1092,7 @@ transform {
                       transform: translate(24, 0);
                     }
                   }
-                  transform: translate(125, 145) translate(0, 2);
+                  transform: translate(125, 147);
                 }
                 transform {
                   child: color-matrix {
@@ -1180,7 +1180,7 @@ transform {
                     offset: 2 17;
                   }
                 }
-                transform: translate(0, 44) translate(17, 5);
+                transform: translate(17, 49);
               }
               transform {
                 child: container {
@@ -1202,7 +1202,7 @@ transform {
                     offset: 2 17;
                   }
                 }
-                transform: translate(0, 88) translate(17, 5);
+                transform: translate(17, 93);
               }
               transform {
                 child: container {
@@ -1224,7 +1224,7 @@ transform {
                     offset: 2 17;
                   }
                 }
-                transform: translate(0, 132) translate(17, 5);
+                transform: translate(17, 137);
               }
               transform {
                 child: transform {
@@ -1427,7 +1427,7 @@ transform {
                     color: rgb(53,132,228);
                   }
                 }
-                transform: translate(0, 396) translate(17, 5);
+                transform: translate(17, 401);
               }
               transform {
                 child: container {
@@ -1456,7 +1456,7 @@ transform {
                     }
                   }
                 }
-                transform: translate(0, 440) translate(37, 1);
+                transform: translate(37, 441);
               }
               transform {
                 child: container {
@@ -1485,7 +1485,7 @@ transform {
                     }
                   }
                 }
-                transform: translate(0, 476) translate(37, 1);
+                transform: translate(37, 477);
               }
             }
             transform: translate(431, 0);
@@ -1527,7 +1527,7 @@ transform {
                           outline: -1 -1 252 4 / 2 1.5 1.5 2;
                         }
                       }
-                      transform: translate(0, -1) translate(0, 1);
+                      transform: translate(0, 0);
                     }
                   }
                   transform: translate(1, 1);
@@ -1560,7 +1560,7 @@ transform {
                             outline: -1 -1 252 4 / 1.5 2 2 1.5;
                           }
                         }
-                        transform: translate(250, -1) translate(0, 1);
+                        transform: translate(250, 0);
                       }
                     }
                     transform: translate(1, 1);
@@ -1605,10 +1605,10 @@ transform {
                               outline: -1 -1 102 4 / 1.5;
                             }
                           }
-                          transform: translate(43, -1) translate(0, 1);
+                          transform: translate(43, 0);
                         }
                       }
-                      transform: translate(0, 16) translate(1, 1);
+                      transform: translate(1, 17);
                     }
                   }
                   transform: translate(0, 20);
@@ -1699,28 +1699,28 @@ transform {
                             outline: -1 -1 97 3 / 1;
                           }
                         }
-                        transform: translate(99, 0) translate(2, 1);
+                        transform: translate(101, 1);
                       }
                       transform {
                         child: border {
                           colors: rgba(146,149,149,0.15);
                           outline: -1 -1 97 3 / 1;
                         }
-                        transform: translate(198, 0) translate(2, 1);
+                        transform: translate(200, 1);
                       }
                       transform {
                         child: border {
                           colors: rgba(146,149,149,0.15);
                           outline: -1 -1 97 3 / 1;
                         }
-                        transform: translate(297, 0) translate(2, 1);
+                        transform: translate(299, 1);
                       }
                       transform {
                         child: border {
                           colors: rgba(146,149,149,0.15);
                           outline: -1 -1 97 3 / 1;
                         }
-                        transform: translate(396, 0) translate(2, 1);
+                        transform: translate(398, 1);
                       }
                     }
                     transform: translate(3, 3);
@@ -1771,10 +1771,10 @@ transform {
                               outline: -1 -1 20 20 / 10;
                             }
                           }
-                          transform: translate(234, 0) translate(-8, -8);
+                          transform: translate(226, -8);
                         }
                       }
-                      transform: translate(0, 3) translate(1, 1);
+                      transform: translate(1, 4);
                     }
                     transform: translate(12, 12);
                   }
@@ -1806,12 +1806,12 @@ transform {
                               outline: -1 -1 20 20 / 10;
                             }
                           }
-                          transform: translate(234, 0) translate(-8, -8);
+                          transform: translate(226, -8);
                         }
                       }
-                      transform: translate(0, 3) translate(1, 1);
+                      transform: translate(1, 4);
                     }
-                    transform: translate(0, 34) translate(12, 12);
+                    transform: translate(12, 46);
                   }
                 }
                 transform: translate(0, 76);
@@ -1856,7 +1856,7 @@ transform {
                         transform: translate(476, 0);
                       }
                     }
-                    transform: translate(0, 4) translate(0, 6);
+                    transform: translate(0, 10);
                   }
                   transform {
                     child: container {
@@ -1876,13 +1876,13 @@ transform {
                           bounds: 1 1 20 25;
                           texture: 
url("
 d9dAyFtf
 
1icuh0FHUXAO1YAXdtn17D6V0UzVaApBIJHJxXZ8IXbp0pBarB/5CNe0XardvkiWJB4DEp0+5mK6/qIetBpbREY/Hs1ew2Tam0+liLBZbFVtr+OtDQ+HrQ0NhAHwj0LryE/8bFCfO1plnAAAAAElFTkSuQmCC");
                         }
-                        transform: translate(237, 0) translate(-10, -10);
+                        transform: translate(227, -10);
                       }
                     }
                     transform: translate(1, 1);
                   }
                 }
-                transform: translate(0, 150) translate(12, 12);
+                transform: translate(12, 162);
               }
               transform {
                 child: container {
@@ -1915,7 +1915,7 @@ transform {
                                 outline: -1 -1 4 182 / 2 2 1.5 1.5;
                               }
                             }
-                            transform: translate(-1, 0) translate(1, 0);
+                            transform: translate(0, 0);
                           }
                         }
                         transform: translate(1, 1);
@@ -1950,7 +1950,7 @@ transform {
                                 outline: -1 -1 4 182 / 1.5 1.5 2 2;
                               }
                             }
-                            transform: translate(-1, 180) translate(1, 0);
+                            transform: translate(0, 180);
                           }
                         }
                         transform: translate(1, 1);
@@ -2008,10 +2008,10 @@ transform {
                                     outline: -1 -1 20 20 / 10;
                                   }
                                 }
-                                transform: translate(0, 151) translate(-8, -8);
+                                transform: translate(-8, 143);
                               }
                             }
-                            transform: translate(39, 28) translate(1, 1);
+                            transform: translate(40, 29);
                           }
                         }
                         transform: translate(28, 12);
@@ -2051,13 +2051,13 @@ transform {
                                     outline: -1 -1 20 20 / 10;
                                   }
                                 }
-                                transform: translate(0, 151) translate(-8, -8);
+                                transform: translate(-8, 143);
                               }
                             }
-                            transform: translate(39, 28) translate(1, 1);
+                            transform: translate(40, 29);
                           }
                         }
-                        transform: translate(129, 0) translate(12, 12);
+                        transform: translate(141, 12);
                       }
                     }
                     transform: translate(251, 0);
@@ -2105,7 +2105,7 @@ transform {
                     offset: 0 15;
                   }
                 }
-                transform: translate(0, 141) translate(1, 1);
+                transform: translate(1, 142);
               }
               transform {
                 child: container {
@@ -2131,7 +2131,7 @@ transform {
                     offset: 0 15;
                   }
                 }
-                transform: translate(0, 282) translate(2, 2);
+                transform: translate(2, 284);
               }
               transform {
                 child: container {
@@ -2157,7 +2157,7 @@ transform {
                     offset: 0 15;
                   }
                 }
-                transform: translate(0, 423) translate(2, 2);
+                transform: translate(2, 425);
               }
             }
             transform: translate(1097, 0);
@@ -2499,7 +2499,7 @@ transform {
                                 offset: 0 17;
                               }
                             }
-                            transform: translate(42, 0) translate(6, 0);
+                            transform: translate(48, 0);
                           }
                           transform {
                             child: container {
@@ -2519,7 +2519,7 @@ transform {
                                 offset: 0 17;
                               }
                             }
-                            transform: translate(82, 0) translate(6, 0);
+                            transform: translate(88, 0);
                           }
                           transform {
                             child: container {
@@ -2539,7 +2539,7 @@ transform {
                                 offset: 0 17;
                               }
                             }
-                            transform: translate(153, 0) translate(6, 0);
+                            transform: translate(159, 0);
                           }
                         }
                         clip: 0 0 210 25;
@@ -2571,7 +2571,7 @@ transform {
                     }
                   }
                 }
-                transform: translate(0, 295) translate(1, 1);
+                transform: translate(1, 296);
               }
             }
             transform: translate(1232, 0);
@@ -2613,7 +2613,7 @@ transform {
                               glyphs: "page 3";
                               offset: 0 20;
                             }
-                            transform: translate(149, 0) translate(16, 3);
+                            transform: translate(165, 3);
                           }
                           transform {
                             child: text {
@@ -2622,7 +2622,7 @@ transform {
                               glyphs: "page 2";
                               offset: 0 20;
                             }
-                            transform: translate(74, 0) translate(16, 3);
+                            transform: translate(90, 3);
                           }
                           transform {
                             child: container {
@@ -2689,7 +2689,7 @@ transform {
                               glyphs: "page 3";
                               offset: 0 20;
                             }
-                            transform: translate(0, 88) translate(12, 7);
+                            transform: translate(12, 95);
                           }
                           transform {
                             child: text {
@@ -2698,7 +2698,7 @@ transform {
                               glyphs: "page 2";
                               offset: 0 20;
                             }
-                            transform: translate(0, 44) translate(12, 7);
+                            transform: translate(12, 51);
                           }
                           transform {
                             child: container {
@@ -2721,11 +2721,11 @@ transform {
                         transform: translate(-2, 3);
                       }
                     }
-                    transform: translate(285, 0) translate(2, 1);
+                    transform: translate(287, 1);
                   }
                 }
               }
-              transform: translate(364, 0) translate(1, 1);
+              transform: translate(365, 1);
             }
             transform {
               child: container {
@@ -2758,7 +2758,7 @@ transform {
                               glyphs: "page 3";
                               offset: 0 20;
                             }
-                            transform: translate(149, 0) translate(16, 4);
+                            transform: translate(165, 4);
                           }
                           transform {
                             child: text {
@@ -2767,7 +2767,7 @@ transform {
                               glyphs: "page 2";
                               offset: 0 20;
                             }
-                            transform: translate(74, 0) translate(16, 4);
+                            transform: translate(90, 4);
                           }
                           transform {
                             child: container {
@@ -2790,11 +2790,11 @@ transform {
                         transform: translate(3, -2);
                       }
                     }
-                    transform: translate(0, 103) translate(1, 2);
+                    transform: translate(1, 105);
                   }
                 }
               }
-              transform: translate(728, 0) translate(1, 1);
+              transform: translate(729, 1);
             }
             transform {
               child: container {
@@ -2823,7 +2823,7 @@ transform {
                               glyphs: "page 3";
                               offset: 0 20;
                             }
-                            transform: translate(0, 88) translate(12, 7);
+                            transform: translate(12, 95);
                           }
                           transform {
                             child: text {
@@ -2832,7 +2832,7 @@ transform {
                               glyphs: "page 2";
                               offset: 0 20;
                             }
-                            transform: translate(0, 44) translate(12, 7);
+                            transform: translate(12, 51);
                           }
                           transform {
                             child: container {
@@ -2866,13 +2866,13 @@ transform {
                   }
                 }
               }
-              transform: translate(1091, 0) translate(1, 1);
+              transform: translate(1092, 1);
             }
           }
           transform: translate(0, 579);
         }
       }
-      transform: translate(26, 70) translate(10, 10);
+      transform: translate(36, 80);
     }
   }
   transform: translate(0, 0);


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