QGCMouseArea.qml 1.43 KB
Newer Older
1 2
import QtQuick 2.3

3 4
import QGroundControl               1.0
import QGroundControl.ScreenTools   1.0
5

6 7 8
/// Works just like a regular MouseArea except:
///     1) It supports the ability to show touch extents based on QGroundControl.showTouchAreas
///     2) You can specify fillItem and it will automatically fill to the size and adjust touch areas on mobile
9
MouseArea {
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
    anchors.leftMargin:     fillItem ? -_touchMarginHorizontal : 0
    anchors.rightMargin:    fillItem ? -_touchMarginHorizontal : 0
    anchors.topMargin:      fillItem ? -_touchMarginVertical : 0
    anchors.bottomMargin:   fillItem ? -_touchMarginVertical : 0
    anchors.fill:           fillItem ? fillItem : undefined

    property var fillItem

    property real _itemWidth:               fillItem ? fillItem.width : width
    property real _itemHeight:              fillItem ? fillItem.height : height
    property real _touchWidth:              Math.max(_itemWidth, ScreenTools.minTouchPixels)
    property real _touchHeight:             Math.max(_itemHeight, ScreenTools.minTouchPixels)
    property real _touchMarginHorizontal:   ScreenTools.isMobile ? (_touchWidth - _itemWidth) / 2 : 0
    property real _touchMarginVertical:     ScreenTools.isMobile ? (_touchHeight - _itemHeight) / 2 : 0

25 26 27
    Rectangle {
        anchors.fill:   parent
        border.color:   "red"
28
        border.width:   QGroundControl.corePlugin.showTouchAreas ? 1 : 0
29 30 31
        color:          "transparent"
    }
}