Commit 0c71e3fa authored by Benjamin Long's avatar Benjamin Long

Fix all the QDoubleSpinBox issues - Close #88

parent 8fdcd1e9
...@@ -39,7 +39,8 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. ...@@ -39,7 +39,8 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#include <QStyleOptionSpinBox> #include <QStyleOptionSpinBox>
pqDoubleSpinBoxEventTranslator::pqDoubleSpinBoxEventTranslator(QObject* p) pqDoubleSpinBoxEventTranslator::pqDoubleSpinBoxEventTranslator(QObject* p)
: pqWidgetEventTranslator(p) : pqWidgetEventTranslator(p),
CurrentObject(0)
{ {
} }
...@@ -56,46 +57,46 @@ bool pqDoubleSpinBoxEventTranslator::translateEvent(QObject* Object, QEvent* Eve ...@@ -56,46 +57,46 @@ bool pqDoubleSpinBoxEventTranslator::translateEvent(QObject* Object, QEvent* Eve
if(!object) if(!object)
return false; return false;
switch(Event->type()) if(Event->type() == QEvent::Enter && Object==object)
{ {
case QEvent::MouseButtonPress: if(this->CurrentObject != Object)
{ {
QMouseEvent* me = static_cast<QMouseEvent*>(Event); if(this->CurrentObject)
if(me->button() == Qt::LeftButton)
{ {
QStyle* style = object->style(); disconnect(this->CurrentObject, 0, this, 0);
QStyleOptionSpinBox option;
option.initFrom(object);
option.subControls = QStyle::SC_All;
QStyle::SubControl sub = style->hitTestComplexControl(
QStyle::CC_SpinBox, &option, me->pos(), object);
if(sub == QStyle::SC_SpinBoxUp)
{
emit recordEvent(object, "spin", "up");
}
else if(sub == QStyle::SC_SpinBoxDown)
{
emit recordEvent(object, "spin", "down");
}
} }
this->CurrentObject = Object;
this->Value = object->value();
connect(object, SIGNAL(valueChanged(double)),this, SLOT(onValueChanged(double)));
connect(object, SIGNAL(destroyed(QObject*)), this, SLOT(onDestroyed(QObject*)));
} }
break; }
case QEvent::KeyRelease:
if(Event->type() == QEvent::KeyRelease && Object==object)
{
QKeyEvent* ke = static_cast<QKeyEvent*>(Event);
QString keyText = ke->text();
if(keyText.length() && keyText.at(0).isLetterOrNumber())
{ {
QKeyEvent* ke = static_cast<QKeyEvent*>(Event); emit recordEvent(object, "set_double", QString("%1").arg(object->value()));
QString keyText = ke->text(); }
if(keyText.length() && keyText.at(0).isLetterOrNumber()) else
{ {
emit recordEvent(object, "set_double", QString("%1").arg(object->value())); emit recordEvent(object, "key", QString("%1").arg(ke->key()));
}
else
{
emit recordEvent(object, "key", QString("%1").arg(ke->key()));
}
} }
default:
break;
} }
return true; return true;
} }
void pqDoubleSpinBoxEventTranslator::onDestroyed(QObject* /*Object*/)
{
this->CurrentObject = 0;
}
void pqDoubleSpinBoxEventTranslator::onValueChanged(double number)
{
QString sens = (number - this->Value > 0) ? "up" : "down";
this->Value = number;
emit recordEvent(this->CurrentObject, "spin", sens);
}
...@@ -55,6 +55,13 @@ private: ...@@ -55,6 +55,13 @@ private:
pqDoubleSpinBoxEventTranslator(const pqDoubleSpinBoxEventTranslator&); pqDoubleSpinBoxEventTranslator(const pqDoubleSpinBoxEventTranslator&);
pqDoubleSpinBoxEventTranslator& operator=(const pqDoubleSpinBoxEventTranslator&); pqDoubleSpinBoxEventTranslator& operator=(const pqDoubleSpinBoxEventTranslator&);
int Value;
QObject* CurrentObject;
private slots:
void onDestroyed(QObject*);
void onValueChanged(double number);
}; };
#endif // !_pqDoubleSpinBoxEventTranslator_h #endif // !_pqDoubleSpinBoxEventTranslator_h
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment