[Kst] extragear/graphics/kst/kst
George Staikos
staikos at kde.org
Mon Nov 28 21:51:17 CET 2005
SVN commit 483949 by staikos:
don't crash when the plot is loaded but the curve is not done yet.
there are more cases to fix.
BUG: 117234
M +56 -14 kstvcurve.cpp
--- trunk/extragear/graphics/kst/kst/kstvcurve.cpp #483948:483949
@@ -268,50 +268,92 @@
void KstVCurve::point(int i, double &x, double &y) const {
- x = _inputVectors[COLOR_XVECTOR]->interpolate(i, NS);
- y = _inputVectors[COLOR_YVECTOR]->interpolate(i, NS);
+ KstVectorPtr xv = xVector();
+ if (xv) {
+ x = xv->interpolate(i, NS);
+ }
+ KstVectorPtr yv = yVector();
+ if (yv) {
+ y = yv->interpolate(i, NS);
+ }
}
void KstVCurve::getEXPoint(int i, double &x, double &y, double &ex) {
- x = _inputVectors[COLOR_XVECTOR]->interpolate(i, NS);
- y = _inputVectors[COLOR_YVECTOR]->interpolate(i, NS);
+ KstVectorPtr xv = xVector();
+ if (xv) {
+ x = xv->interpolate(i, NS);
+ }
+ KstVectorPtr yv = yVector();
+ if (yv) {
+ y = yv->interpolate(i, NS);
+ }
ex = _inputVectors[EXVECTOR]->interpolate(i, NS);
}
void KstVCurve::getEXMinusPoint(int i, double &x, double &y, double &ex) {
- x = _inputVectors[COLOR_XVECTOR]->interpolate(i, NS);
- y = _inputVectors[COLOR_YVECTOR]->interpolate(i, NS);
+ KstVectorPtr xv = xVector();
+ if (xv) {
+ x = xv->interpolate(i, NS);
+ }
+ KstVectorPtr yv = yVector();
+ if (yv) {
+ y = yv->interpolate(i, NS);
+ }
ex = _inputVectors[EXMINUSVECTOR]->interpolate(i, NS);
}
void KstVCurve::getEXPoints(int i, double &x, double &y, double &exminus, double &explus) {
- x = _inputVectors[COLOR_XVECTOR]->interpolate(i, NS);
- y = _inputVectors[COLOR_YVECTOR]->interpolate(i, NS);
+ KstVectorPtr xv = xVector();
+ if (xv) {
+ x = xv->interpolate(i, NS);
+ }
+ KstVectorPtr yv = yVector();
+ if (yv) {
+ y = yv->interpolate(i, NS);
+ }
explus = _inputVectors[EXVECTOR]->interpolate(i, NS);
exminus = _inputVectors[EXMINUSVECTOR]->interpolate(i, NS);
}
void KstVCurve::getEYPoint(int i, double &x, double &y, double &ey) {
- x = _inputVectors[COLOR_XVECTOR]->interpolate(i, NS);
- y = _inputVectors[COLOR_YVECTOR]->interpolate(i, NS);
+ KstVectorPtr xv = xVector();
+ if (xv) {
+ x = xv->interpolate(i, NS);
+ }
+ KstVectorPtr yv = yVector();
+ if (yv) {
+ y = yv->interpolate(i, NS);
+ }
ey = _inputVectors[EYVECTOR]->interpolate(i, NS);
}
void KstVCurve::getEYMinusPoint(int i, double &x, double &y, double &ey) {
- x = _inputVectors[COLOR_XVECTOR]->interpolate(i, NS);
- y = _inputVectors[COLOR_YVECTOR]->interpolate(i, NS);
+ KstVectorPtr xv = xVector();
+ if (xv) {
+ x = xv->interpolate(i, NS);
+ }
+ KstVectorPtr yv = yVector();
+ if (yv) {
+ y = yv->interpolate(i, NS);
+ }
ey = _inputVectors[EYMINUSVECTOR]->interpolate(i, NS);
}
void KstVCurve::getEYPoints(int i, double &x, double &y, double &eyminus, double &eyplus) {
- x = _inputVectors[COLOR_XVECTOR]->interpolate(i, NS);
- y = _inputVectors[COLOR_YVECTOR]->interpolate(i, NS);
+ KstVectorPtr xv = xVector();
+ if (xv) {
+ x = xv->interpolate(i, NS);
+ }
+ KstVectorPtr yv = yVector();
+ if (yv) {
+ y = yv->interpolate(i, NS);
+ }
eyplus = _inputVectors[EYVECTOR]->interpolate(i, NS);
eyminus = _inputVectors[EYMINUSVECTOR]->interpolate(i, NS);
}
More information about the Kst
mailing list