Browse Source

Implement OutSideClick

cl-refactor
yann300 10 years ago
parent
commit
d182406015
  1. 38
      mix/InverseMouseArea.cpp
  2. 9
      mix/InverseMouseArea.h
  3. 42
      mix/qml/LogsPane.qml
  4. 38
      mix/qml/StatesComboBox.qml
  5. 11
      mix/qml/StatusPane.qml
  6. 3
      mix/qml/TransactionLog.qml

38
mix/InverseMouseArea.cpp

@ -30,30 +30,34 @@ using namespace dev::mix;
void InverseMouseArea::itemChange(ItemChange _c, const ItemChangeData& _v) void InverseMouseArea::itemChange(ItemChange _c, const ItemChangeData& _v)
{ {
qDebug() << "itemCHange"; if (!this->m_active)
return;
Q_UNUSED(_v); Q_UNUSED(_v);
if (_c == ItemSceneChange && window())
if (_c == ItemSceneChange)
{
window()->installEventFilter(this); window()->installEventFilter(this);
//this->parentItem()->installEventFilter(this);
}
} }
bool InverseMouseArea::eventFilter(QObject* _obj, QEvent* _ev) bool InverseMouseArea::eventFilter(QObject* _obj, QEvent* _ev)
{ {
qDebug() << _ev->type(); if (!this->m_active)
return false;
Q_UNUSED(_obj); Q_UNUSED(_obj);
if (_ev->type() == QEvent::MouseButtonPress) if (_ev->type() == QEvent::MouseButtonPress && !this->contains(static_cast<QMouseEvent*>(_ev)->pos()))
{
qDebug() << "mouse event";
if (!this->contains(static_cast<QMouseEvent*>(_ev)->pos()))
{
qDebug() << "click outside";
emit clickedOutside(); emit clickedOutside();
}
}
return false; return false;
} }
bool InverseMouseArea::contains(const QPoint& _point) const
{
if (!this->m_active)
return false;
QPointF global = this->parentItem()->mapToItem(0, QPointF(0, 0));
return QRectF(global.x(), global.y(), this->parentItem()->width(), this->parentItem()->height()).contains(_point);
}
void InverseMouseArea::setActive(bool _v)
{
m_active = _v;
if (m_active && window())
window()->installEventFilter(this);
}

9
mix/InverseMouseArea.h

@ -22,6 +22,7 @@
#pragma once #pragma once
#include <QQuickWindow>
#include <QQuickItem> #include <QQuickItem>
namespace dev namespace dev
@ -32,14 +33,20 @@ namespace mix
class InverseMouseArea: public QQuickItem class InverseMouseArea: public QQuickItem
{ {
Q_OBJECT Q_OBJECT
Q_PROPERTY(bool active MEMBER m_active WRITE setActive)
public: public:
InverseMouseArea(QQuickItem* _parent = 0): QQuickItem(_parent) {} InverseMouseArea(QQuickItem* _parent = 0): QQuickItem(_parent) {}
~InverseMouseArea() { /*scene()->removeEventFilter(this);*/ } ~InverseMouseArea() { if (window()) { window()->removeEventFilter(this); } }
void setActive(bool _v);
protected: protected:
void itemChange(ItemChange _c, const ItemChangeData& _v); void itemChange(ItemChange _c, const ItemChangeData& _v);
bool eventFilter(QObject* _obj, QEvent *_ev); bool eventFilter(QObject* _obj, QEvent *_ev);
bool contains(const QPoint& _point) const;
private:
bool m_active;
signals: signals:
void clickedOutside(); void clickedOutside();

42
mix/qml/LogsPane.qml

@ -585,48 +585,6 @@ Rectangle
} }
} }
} }
Rectangle
{
height: logStyle.generic.layout.headerButtonHeight
anchors.verticalCenter: parent.verticalCenter
color: "transparent"
width: 20
Button
{
id: hideButton
action: hideAction
anchors.fill: parent
anchors.verticalCenter: parent.verticalCenter
height: 25
style:
ButtonStyle {
background:
Rectangle {
height: logStyle.generic.layout.headerButtonHeight
implicitHeight: logStyle.generic.layout.headerButtonHeight
color: "transparent"
}
}
}
Image {
id: hideImage
source: "qrc:/qml/img/exit.png"
anchors.centerIn: parent
fillMode: Image.PreserveAspectFit
width: 20
height: 25
}
Action {
id: hideAction
tooltip: qsTr("Exit")
onTriggered: {
logsPane.parent.toggle();
}
}
}
} }
} }

38
mix/qml/StatesComboBox.qml

@ -24,13 +24,15 @@ import QtQuick 2.0
import QtQuick.Controls 1.0 import QtQuick.Controls 1.0
import QtQuick.Layouts 1.1 import QtQuick.Layouts 1.1
import QtGraphicalEffects 1.0 import QtGraphicalEffects 1.0
import org.ethereum.qml.InverseMouseArea 1.0
Rectangle { Rectangle {
id: statesComboBox id: statesComboBox
width: 200 width: 200
height: 23 height: 23
border.width: 2
border.color: "red"
Component.onCompleted: { Component.onCompleted: {
var top = dropDownList var top = dropDownList
while (top.parent) { while (top.parent) {
@ -62,6 +64,12 @@ Rectangle {
chosenItemText.text = statesComboBox.items.get(index).title chosenItemText.text = statesComboBox.items.get(index).title
} }
function hideDropDown()
{
if (statesComboBox.state === "dropDown")
statesComboBox.state = "";
}
signal comboClicked signal comboClicked
property variant colorItem property variant colorItem
@ -76,14 +84,13 @@ Rectangle {
{ {
id: boldFont id: boldFont
} }
smooth: true smooth: true
Rectangle { Rectangle {
id: chosenItem id: chosenItem
width: parent.width width: parent.width
height: statesComboBox.height height: statesComboBox.height
color: statesComboBox.color color: statesComboBox.color
Text { Text {
id: chosenItemText id: chosenItemText
anchors.left: parent.left anchors.left: parent.left
@ -97,7 +104,13 @@ Rectangle {
MouseArea { MouseArea {
anchors.fill: parent anchors.fill: parent
onClicked: { onClicked: {
statesComboBox.state = statesComboBox.state === "dropDown" ? "" : "dropDown" if (outsideClick.trigerred)
{
outsideClick.trigerred = false;
return;
}
if (statesCombo.state === "")
statesCombo.state = "dropDown";
} }
} }
} }
@ -124,8 +137,21 @@ Rectangle {
anchors.topMargin: 23 anchors.topMargin: 23
color: statesComboBox.color color: statesComboBox.color
InverseMouseArea
{
property bool trigerred: false
id: outsideClick
anchors.fill: parent
active: false
onClickedOutside: {
trigerred = true;
statesCombo.hideDropDown()
}
}
ColumnLayout { ColumnLayout {
spacing: 2 spacing: 2
TableView { TableView {
id: listView id: listView
height: 20 height: 20
@ -256,5 +282,9 @@ Rectangle {
height: 20 height: 20
implicitHeight: (statesComboBox.rowHeight * (statesComboBox.items.count)) implicitHeight: (statesComboBox.rowHeight * (statesComboBox.items.count))
} }
PropertyChanges {
target: outsideClick
active: true
}
} }
} }

11
mix/qml/StatusPane.qml

@ -252,13 +252,9 @@ Rectangle {
{ {
id: outsideClick id: outsideClick
anchors.fill: parent anchors.fill: parent
} active: false
Connections
{
target: outsideClick
onClickedOutside: { onClickedOutside: {
toggle(); logsContainer.toggle();
} }
} }
@ -309,11 +305,14 @@ Rectangle {
State { State {
name: "opened"; name: "opened";
PropertyChanges { target: logsContainer; height: 500; visible: true } PropertyChanges { target: logsContainer; height: 500; visible: true }
PropertyChanges { target: outsideClick; active: true }
}, },
State { State {
name: "closed"; name: "closed";
PropertyChanges { target: logsContainer; height: 0; visible: false } PropertyChanges { target: logsContainer; height: 0; visible: false }
PropertyChanges { target: statusContainer; width: 600; height: 30 } PropertyChanges { target: statusContainer; width: 600; height: 30 }
PropertyChanges { target: outsideClick; active: false }
} }
] ]
transitions: Transition { transitions: Transition {

3
mix/qml/TransactionLog.qml

@ -4,6 +4,7 @@ import QtQuick.Controls.Styles 1.1
import QtQuick.Dialogs 1.1 import QtQuick.Dialogs 1.1
import QtQuick.Layouts 1.1 import QtQuick.Layouts 1.1
import org.ethereum.qml.RecordLogEntry 1.0 import org.ethereum.qml.RecordLogEntry 1.0
import org.ethereum.qml.InverseMouseArea 1.0
Item { Item {
property ListModel fullModel: ListModel{} property ListModel fullModel: ListModel{}
@ -60,7 +61,7 @@ Item {
target: projectModel.stateListModel target: projectModel.stateListModel
onStateRun: { onStateRun: {
if (statesCombo.selectedIndex !== index) if (statesCombo.selectedIndex !== index)
statesCombo.setSelectedIndex( index ); statesCombo.setSelectedIndex(index)
} }
} }
} }

Loading…
Cancel
Save