[Kst] extragear/graphics/kst/src/libkstapp
Andrew Walker
arwalker at sumusltd.com
Thu Jun 22 19:18:09 CEST 2006
SVN commit 553965 by arwalker:
CCBUG:111239 Make everything suitably fuzzy for axes condensation so that the user can be off by a few pixels when aligning plots and still have the axes condense as expected.
M +76 -15 ksttoplevelview.cpp
--- trunk/extragear/graphics/kst/src/libkstapp/ksttoplevelview.cpp #553964:553965
@@ -1256,15 +1256,20 @@
KstApp::inst()->document()->setModified();
Kst2DPlotList plots;
Kst2DPlotList plotsProcess;
+ KstAspectRatio aspect;
+ KstAspectRatio aspectItem;
QRect geom;
+ QRect geomItem;
bool processed = false;
-
+ const double close = 0.02;
+
// create a list of all plot objects in this view
plots = kstObjectSubList<KstViewObject, Kst2DPlot>(_selectionList);
while (plots.count() > 1) {
plotsProcess.clear();
plotsProcess.append(plots.first());
+ aspect = plots.first()->aspectRatio();
geom = plots.first()->geometry();
plots.pop_front();
bool added = true;
@@ -1274,22 +1279,46 @@
added = false;
for (Kst2DPlotList::ConstIterator i = plots.begin(); i != plots.end(); ++i) {
- if ((*i)->geometry().left() == geom.left() && (*i)->geometry().right() == geom.right()) {
- if (geom.top() - (*i)->geometry().bottom() == 1) {
- geom = geom.unite((*i)->geometry());
+ aspectItem = (*i)->aspectRatio();
+ geomItem = (*i)->geometry();
+
+ if ((geomItem.left() == geom.left() && geomItem.right() == geom.right()) ||
+ (fabs(aspectItem.x - aspect.x) < close && fabs(aspectItem.w - aspect.w) < close)) {
+ if (geom.top() - geomItem.bottom() == 1) {
+ geom = geom.unite(geomItem);
plotsProcess.append(*i);
plots.remove(*i);
added = true;
break;
- } else if ((*i)->geometry().top() - geom.bottom() == 1) {
- geom = geom.unite((*i)->geometry());
+ } else if (geomItem.top() - geom.bottom() == 1) {
plotsProcess.prepend(*i);
- plots.remove(*i);
+ plots.remove(*i);
added = true;
break;
+ } else if (fabs(aspect.y - (aspectItem.y + aspectItem.h)) < close) {
+ plotsProcess.append(*i);
+ plots.remove(*i);
+ added = true;
+ break;
+ } else if (fabs(aspectItem.y - (aspect.y + aspect.h)) < close) {
+ plotsProcess.prepend(*i);
+ plots.remove(*i);
+ added = true;
+ break;
}
}
}
+
+ if (added) {
+ geom = geom.unite(geomItem);
+
+ if (aspect.y < aspectItem.y) {
+ aspect.y = aspectItem.y;
+ }
+ if (aspect.y + aspect.h > aspectItem.y + aspectItem.h) {
+ aspect.h = (aspectItem.y + aspectItem.h) - aspect.y;
+ }
+ }
}
// modify the plot properties appropriately
@@ -1324,15 +1353,20 @@
KstApp::inst()->document()->setModified();
Kst2DPlotList plots;
Kst2DPlotList plotsProcess;
+ KstAspectRatio aspect;
+ KstAspectRatio aspectItem;
QRect geom;
+ QRect geomItem;
bool processed = false;
-
+ const double close = 0.02;
+
// create a list of all plot objects
plots = kstObjectSubList<KstViewObject, Kst2DPlot>(_selectionList);
while (plots.count() > 1) {
plotsProcess.clear();
plotsProcess.append(plots.first());
+ aspect = plots.first()->aspectRatio();
geom = plots.first()->geometry();
plots.pop_front();
bool added = true;
@@ -1342,40 +1376,67 @@
added = false;
for (Kst2DPlotList::ConstIterator i = plots.begin(); i != plots.end(); ++i) {
- if ((*i)->geometry().top() == geom.top() && (*i)->geometry().bottom() == geom.bottom()) {
- if (geom.left() - (*i)->geometry().right() == 1) {
- geom = geom.unite((*i)->geometry());
+ aspectItem = (*i)->aspectRatio();
+ geomItem = (*i)->geometry();
+
+ if ((geomItem.top() == geom.top() && geomItem.bottom() == geom.bottom()) ||
+ (fabs(aspectItem.y - aspect.y) < close && fabs(aspectItem.h - aspect.h) < close)) {
+ if (geom.left() - geomItem.right() == 1) {
plotsProcess.append(*i);
plots.remove(*i);
added = true;
break;
- } else if ((*i)->geometry().left() - geom.right() == 1) {
- geom = geom.unite((*i)->geometry());
+ } else if (geomItem.left() - geom.right() == 1) {
plotsProcess.prepend(*i);
plots.remove(*i);
added = true;
break;
+ } else if (fabs(aspect.x - (aspectItem.x + aspectItem.w)) < close) {
+ plotsProcess.append(*i);
+ plots.remove(*i);
+ added = true;
+ break;
+ } else if (fabs(aspectItem.x - (aspect.x + aspect.w)) < close) {
+ plotsProcess.prepend(*i);
+ plots.remove(*i);
+ added = true;
+ break;
}
}
}
+
+ if (added) {
+ geom = geom.unite(geomItem);
+
+ if (aspect.x < aspectItem.x) {
+ aspect.x = aspectItem.x;
+ }
+ if (aspect.x + aspect.w > aspectItem.x + aspectItem.w) {
+ aspect.w = (aspectItem.x + aspectItem.w) - aspect.x;
+ }
+ }
}
// modify the plot properties appropriately
if (plotsProcess.count() > 1) {
plotsProcess.first()->setSuppressLeft(true);
+ plotsProcess.first()->setDirty();
plotsProcess.pop_front();
+
plotsProcess.last()->setSuppressRight(true);
+ plotsProcess.last()->setDirty();
plotsProcess.pop_back();
-
+
for (Kst2DPlotList::Iterator i = plotsProcess.begin(); i != plotsProcess.end(); ++i) {
(*i)->setSuppressLeft(true);
(*i)->setSuppressRight(true);
+ (*i)->setDirty();
}
processed = true;
}
}
-
+
if (processed) {
widget()->paint(QRegion());
}
More information about the Kst
mailing list