[Kst] extragear/graphics/kst/src/libkstapp
    George Staikos 
    staikos at kde.org
       
    Mon May 29 18:47:40 CEST 2006
    
    
  
SVN commit 546280 by staikos:
back out 544672 again until it's done without piling view handling into
KstViewObject
 M  +43 -10    ksttoplevelview.cpp  
 M  +0 -39     kstviewobject.cpp  
 M  +0 -2      kstviewobject.h  
--- trunk/extragear/graphics/kst/src/libkstapp/ksttoplevelview.cpp #546279:546280
@@ -703,21 +703,54 @@
   r.moveTopLeft(topLeft);
   _moveOffsetSticky = QPoint(0, 0);
       
-  int xMin = STICKY_THRESHOLD;
-  int yMin = STICKY_THRESHOLD;
+  int iXMin = STICKY_THRESHOLD;
+  int iYMin = STICKY_THRESHOLD;
 
-  snapToBorders(&xMin, &yMin, _selectionList, _pressTarget, r);
+  // check for "sticky" borders
+  for (KstViewObjectList::Iterator i = _children.begin(); i != _children.end(); ++i) {
+    if (_selectionList.find(*i) == _selectionList.end() && _pressTarget != *i) {           
+      const QRect rect((*i)->geometry());
 
-  if (labs(xMin) < STICKY_THRESHOLD) {
-    _moveOffsetSticky.setX(xMin);
-    topLeft.setX(topLeft.x() - xMin);
+      int overlapLo = r.top() > rect.top() ? r.top() : rect.top();
+      int overlapHi = r.bottom() < rect.bottom() ? r.bottom() : rect.bottom();
+      if (overlapHi - overlapLo > 0) {
+        if (labs(r.left() - rect.left()) < labs(iXMin)) {
+          iXMin = r.left() - rect.left();
+        } else if (labs(r.left() - rect.right()) < labs(iXMin)) {
+          iXMin = r.left() - rect.right();              
+        } else if (labs(r.right() - rect.left()) < labs(iXMin)) {
+          iXMin = r.right() - rect.left();
+        } else if (labs(r.right() - rect.right()) < labs(iXMin)) {
+          iXMin = r.right() - rect.right();
+        }                 
+      }
+
+      overlapLo = r.left() > rect.left() ? r.left() : rect.left();
+      overlapHi = r.right() < rect.right() ? r.right() : rect.right();
+      if (overlapHi - overlapLo > 0) {
+        if (labs(r.top() - rect.top()) < labs(iYMin)) {
+          iYMin = r.top() - rect.top();
+        } else if (labs(r.top() - rect.bottom()) < labs(iYMin)) {
+          iYMin = r.top() - rect.bottom();              
+        } else if (labs(r.bottom() - rect.top()) < labs(iYMin)) {
+          iYMin = r.bottom() - rect.top();
+        } else if (labs(r.bottom() - rect.bottom()) < labs(iYMin)) {
+          iYMin = r.bottom() - rect.bottom();
+        }
+      }
+    }
   }
-  if (labs(yMin) < STICKY_THRESHOLD) {
-    _moveOffsetSticky.setY(yMin);
-    topLeft.setY(topLeft.y() - yMin);
+
+  if (labs(iXMin) < STICKY_THRESHOLD) {
+    _moveOffsetSticky.setX(iXMin);
+    topLeft.setX(topLeft.x() - iXMin);
   }
+  if (labs(iYMin) < STICKY_THRESHOLD) {
+    _moveOffsetSticky.setY(iYMin);
+    topLeft.setY(topLeft.y() - iYMin);
+  }
 
-  r.moveTopLeft(topLeft);
+  r.moveTopLeft(topLeft);      
 
   if (!_geom.contains(r, true)) {
     slideInto(_geom, r);
--- trunk/extragear/graphics/kst/src/libkstapp/kstviewobject.cpp #546279:546280
@@ -1451,45 +1451,6 @@
 }
 
 
-void KstViewObject::snapToBorders(int *xMin, int *yMin, const KstViewObjectList &selectionList, const KstViewObjectPtr &pressTarget, const QRect &r) const {
-  for (KstViewObjectList::ConstIterator i = _children.begin(); i != _children.end(); ++i) {
-    (*i)->snapToBorders(xMin, yMin, selectionList, pressTarget, r);
-    
-    if (selectionList.find(*i) == selectionList.end() && pressTarget != *i) {
-      const QRect rect((*i)->geometry());
-        
-      int overlapLo = r.top() > rect.top() ? r.top() : rect.top();
-      int overlapHi = r.bottom() < rect.bottom() ? r.bottom() : rect.bottom();
-      if (overlapHi - overlapLo > 0) {
-        if (labs(r.left() - rect.left()) < labs(*xMin)) {
-          *xMin = r.left() - rect.left();
-        } else if (labs(r.left() - rect.right()) < labs(*xMin)) {
-          *xMin = r.left() - rect.right();
-        } else if (labs(r.right() - rect.left()) < labs(*xMin)) {
-          *xMin = r.right() - rect.left();
-        } else if (labs(r.right() - rect.right()) < labs(*xMin)) {
-          *xMin = r.right() - rect.right();
-        }
-      }
-  
-      overlapLo = r.left() > rect.left() ? r.left() : rect.left();
-      overlapHi = r.right() < rect.right() ? r.right() : rect.right();
-      if (overlapHi - overlapLo > 0) {
-        if (labs(r.top() - rect.top()) < labs(*yMin)) {
-          *yMin = r.top() - rect.top();
-        } else if (labs(r.top() - rect.bottom()) < labs(*yMin)) {
-          *yMin = r.top() - rect.bottom();
-        } else if (labs(r.bottom() - rect.top()) < labs(*yMin)) {
-          *yMin = r.bottom() - rect.top();
-        } else if (labs(r.bottom() - rect.bottom()) < labs(*yMin)) {
-          *yMin = r.bottom() - rect.bottom();
-        }
-      }
-    }
-  }
-}
-
-
 bool KstViewObject::isSelected() const {
   return _selected;
 }
--- trunk/extragear/graphics/kst/src/libkstapp/kstviewobject.h #546279:546280
@@ -160,8 +160,6 @@
     virtual void updateSelection(const QRect& region);
     bool isContainer() const;
     
-    virtual void snapToBorders(int *xMin, int *yMin, const KstViewObjectList &selectionList, const KstViewObjectPtr &pressTarget, const QRect &r) const;
-    
     KstViewObjectPtr parent() const;
 
     void recursively(void (KstViewObject::*)(), bool self = false);
    
    
More information about the Kst
mailing list