]> git.lyx.org Git - lyx.git/blobdiff - src/CoordCache.h
* add PreBabelPreamble to Language definition (fixes #4786).
[lyx.git] / src / CoordCache.h
index 2b63e6d340a2c5430c45c217355aa28febe62792..a666a4ecb025bb291b1eecc6ec8d3f5b5c279107 100644 (file)
@@ -3,7 +3,7 @@
  * This file is part of LyX, the document processor.
  * Licence details can be found in the file COPYING.
  *
- * \author André Pönitz
+ * \author André Pönitz
  *
  * Full author contact details are available in file CREDITS.
  */
@@ -29,18 +29,6 @@ class Paragraph;
 
 void lyxbreaker(void const * data, const char * hint, int size);
 
-class Point {
-public:
-       Point()
-               : x_(0), y_(0)
-       {}
-
-       Point(int x, int y);
-
-       int x_, y_;
-};
-
-
 struct Geometry {
        Point pos;
        Dimension dim;
@@ -52,6 +40,25 @@ struct Geometry {
                        && y >= pos.y_ - dim.asc
                        && y <= pos.y_ + dim.des;
        }
+
+       int squareDistance(int x, int y) const
+       {
+               int xx = 0;
+               int yy = 0;
+
+               if (x < pos.x_)
+                       xx = pos.x_ - x;
+               else if (x > pos.x_ + dim.wid)
+                       xx = x - pos.x_ - dim.wid;
+
+               if (y < pos.y_ - dim.asc)
+                       yy = pos.y_ - dim.asc - y;
+               else if (y > pos.y_ + dim.des)
+                       yy = y - pos.y_ - dim.des;
+
+               // Optimisation: We avoid to compute the sqrt on purpose.
+               return xx*xx + yy*yy;
+       }
 };
 
 
@@ -77,6 +84,12 @@ public:
                data_[thing].dim = dim;
        }
 
+       Geometry const & geometry(T const * thing) const
+       {
+               check(thing, "geometry");
+               return data_.find(thing)->second;
+       }
+
        Dimension const & dim(T const * thing) const
        {
                check(thing, "dim");
@@ -108,10 +121,18 @@ public:
 
        bool covers(T const * thing, int x, int y) const
        {
-               cache_type::const_iterator it = data_.find(thing);
+               typename cache_type::const_iterator it = data_.find(thing);
                return it != data_.end() && it->second.covers(x, y);
        }
 
+       int squareDistance(T const * thing, int x, int y) const
+       {
+               typename cache_type::const_iterator it = data_.find(thing);
+               if (it == data_.end())
+                       return 1000000;
+               return it->second.squareDistance(x, y);
+       }
+
 private:
        friend class CoordCache;