1
0
Fork 0

Launcher: use built-in QQC2 ScrollBar

The built-in has some nice features and generally updates better than
my previous verion.
This commit is contained in:
James Turner 2020-06-18 13:20:02 +01:00
parent 7313f62353
commit cc798bf21a
11 changed files with 35 additions and 161 deletions

View file

@ -1,4 +1,6 @@
import QtQuick 2.4 import QtQuick 2.4
import QtQuick.Controls 2.2
import FlightGear.Launcher 1.0 import FlightGear.Launcher 1.0
import "." import "."
@ -7,7 +9,9 @@ Item {
Flickable { Flickable {
id: flick id: flick
height: parent.height height: parent.height
width: parent.width - scrollbar.width width: parent.width
ScrollBar.vertical: ScrollBar {}
flickableDirection: Flickable.VerticalFlick flickableDirection: Flickable.VerticalFlick
contentHeight: contents.childrenRect.height contentHeight: contents.childrenRect.height
function showDetails(index) function showDetails(index)
@ -296,15 +300,6 @@ Item {
} }
} // of install-tarbal item } // of install-tarbal item
} // of column } // of column
}
Scrollbar {
id: scrollbar
anchors.right: parent.right
height: parent.height
flickable: flick
visible: flick.contentHeight > flick.height
} }
} }

View file

@ -1,4 +1,5 @@
import QtQuick 2.4 import QtQuick 2.4
import QtQuick.Controls 2.2
import FlightGear.Launcher 1.0 import FlightGear.Launcher 1.0
import "." import "."
@ -21,6 +22,7 @@ Rectangle {
contentWidth: parent.width contentWidth: parent.width
contentHeight: content.childrenRect.height contentHeight: content.childrenRect.height
boundsBehavior: Flickable.StopAtBounds boundsBehavior: Flickable.StopAtBounds
ScrollBar.vertical: ScrollBar {}
function labelText(lbl, idx, key) { function labelText(lbl, idx, key) {
var value = _addOns.modules.get(idx, key); var value = _addOns.modules.get(idx, key);
@ -36,7 +38,7 @@ Rectangle {
Item { Item {
id: content id: content
width: root.width - scrollbar.width width: root.width
height: childrenRect.height height: childrenRect.height
Column { Column {

View file

@ -1,4 +1,5 @@
import QtQuick 2.4 import QtQuick 2.4
import QtQuick.Controls 2.2
import FlightGear.Launcher 1.0 import FlightGear.Launcher 1.0
import "." import "."
@ -25,10 +26,11 @@ Rectangle {
contentWidth: parent.width contentWidth: parent.width
contentHeight: content.childrenRect.height contentHeight: content.childrenRect.height
boundsBehavior: Flickable.StopAtBounds boundsBehavior: Flickable.StopAtBounds
ScrollBar.vertical: ScrollBar {}
Item { Item {
id: content id: content
width: root.width - scrollbar.width width: root.width
height: childrenRect.height height: childrenRect.height
Column { Column {
@ -233,13 +235,4 @@ Rectangle {
} // of main item } // of main item
} // of Flickable } // of Flickable
Scrollbar {
id: scrollbar
anchors.right: parent.right
anchors.top: parent.top
height: parent.height
flickable: flickable
visible: flickable.visibleArea.heightRatio < 1.0
}
} // of Rect } // of Rect

View file

@ -1,4 +1,6 @@
import QtQuick 2.0 import QtQuick 2.0
import QtQuick.Controls 2.2
import FlightGear.Launcher 1.0 as FG import FlightGear.Launcher 1.0 as FG
Item { Item {
@ -42,6 +44,8 @@ Item {
cellHeight: 128 + Style.strutSize cellHeight: 128 + Style.strutSize
highlightMoveDuration: 0 highlightMoveDuration: 0
ScrollBar.vertical: ScrollBar {}
readonly property int baseCellWidth: 172 + (Style.strutSize * 2) readonly property int baseCellWidth: 172 + (Style.strutSize * 2)
readonly property int colCount: Math.floor(width / baseCellWidth) readonly property int colCount: Math.floor(width / baseCellWidth)
@ -49,7 +53,7 @@ Item {
left: parent.left left: parent.left
top: parent.top top: parent.top
bottom: parent.bottom bottom: parent.bottom
right: scrollbar.left right: parent.right
topMargin: Style.margin topMargin: Style.margin
} }
@ -69,12 +73,4 @@ Item {
focus: true focus: true
highlight: highlight highlight: highlight
} }
Scrollbar {
id: scrollbar
anchors.right: parent.right
anchors.top: parent.top
height: view.height
flickable: view
}
} }

View file

@ -1,4 +1,5 @@
import QtQuick 2.0 import QtQuick 2.0
import QtQuick.Controls 2.2
import FlightGear.Launcher 1.0 as FG import FlightGear.Launcher 1.0 as FG
import "." import "."
@ -44,12 +45,13 @@ Item {
ListView { ListView {
id: aircraftList id: aircraftList
ScrollBar.vertical: ScrollBar {}
anchors { anchors {
left: parent.left left: parent.left
top: parent.top top: parent.top
bottom: parent.bottom bottom: parent.bottom
right: scrollbar.left right: parent.right
topMargin: Style.margin topMargin: Style.margin
} }
@ -72,12 +74,4 @@ Item {
// when doing a progrmatic set // when doing a progrmatic set
readonly property int __realHighlightMoveDuration: 200 readonly property int __realHighlightMoveDuration: 200
} }
Scrollbar {
id: scrollbar
anchors.right: parent.right
anchors.top: parent.top
height: aircraftList.height
flickable: aircraftList
}
} }

View file

@ -1,4 +1,5 @@
import QtQuick 2.4 import QtQuick 2.4
import QtQuick.Controls 2.2
import FlightGear.Launcher 1.0 import FlightGear.Launcher 1.0
import FlightGear 1.0 import FlightGear 1.0
import "." import "."
@ -12,9 +13,10 @@ Item {
Flickable { Flickable {
id: flick id: flick
height: parent.height height: parent.height
width: parent.width - scrollbar.width width: parent.width
flickableDirection: Flickable.VerticalFlick flickableDirection: Flickable.VerticalFlick
contentHeight: contents.childrenRect.height + Style.margin * 2 contentHeight: contents.childrenRect.height + Style.margin * 2
ScrollBar.vertical: ScrollBar {}
Component.onCompleted: { Component.onCompleted: {
if (_launcher.flightPlan.cruiseSpeed.value === 0.0) { if (_launcher.flightPlan.cruiseSpeed.value === 0.0) {
@ -444,14 +446,6 @@ Item {
} // of flickable } // of flickable
Scrollbar {
id: scrollbar
anchors.right: parent.right
height: parent.height
flickable: flick
visible: flick.contentHeight > flick.height
}
Component { Component {
id: airportDetails id: airportDetails
PlanAirportView { PlanAirportView {

View file

@ -1,4 +1,5 @@
import QtQuick 2.4 import QtQuick 2.4
import QtQuick.Controls 2.2
import FlightGear 1.0 import FlightGear 1.0
import "." import "."
@ -50,7 +51,7 @@ Rectangle {
} }
if (root.haveHeader()) if (root.haveHeader())
minWidth = Math.max(minWidth, header.width); minWidth = Math.max(minWidth, header.width);
flick.width = minWidth + scroller.width flick.width = minWidth
} }
function haveHeader() function haveHeader()
@ -61,7 +62,7 @@ Rectangle {
Flickable { Flickable {
id: flick id: flick
anchors.centerIn: parent anchors.centerIn: parent
ScrollBar.vertical: ScrollBar {}
height: Math.min(root.maximumPermittedHeight, contentHeight); height: Math.min(root.maximumPermittedHeight, contentHeight);
contentHeight: itemsColumn.childrenRect.height contentHeight: itemsColumn.childrenRect.height
@ -91,14 +92,4 @@ Rectangle {
} // menu item repeater } // menu item repeater
} // of menu contents column } // of menu contents column
} }
Scrollbar {
id: scroller
flickable: flick
visible: flick.contentHeight > flick.height
anchors.right: root.right
anchors.rightMargin: 1
anchors.verticalCenter: parent.verticalCenter
height: flick.height
}
} }

View file

@ -1,82 +0,0 @@
import QtQuick 2.4
Item
{
id: root
implicitWidth: 14
property Flickable flickable: parent
readonly property real heightRatio: flickable ? flickable.visibleArea.heightRatio : 0
readonly property int barSize: Math.max(height * heightRatio, width * 3);
readonly property bool enabled: heightRatio < 1.0
readonly property int scrollRange: height - barSize
function normalisedPosition()
{
if (!flickable) return 0;
// becuase we might use a longer bar height than is proportional to
// height ratio, we have to re-normalise the position
var visArea = flickable.visibleArea;
return visArea.yPosition / (1.0 - visArea.heightRatio);
}
function verticalExtent()
{
var f = root.flickable;
return (f.height / f.visibleArea.heightRatio) - f.height;
}
MouseArea {
id: trackArea
hoverEnabled: true
anchors.fill: parent
onClicked: {
var clickPos = (mouse.y / height)
flickable.contentY = clickPos * verticalExtent();
}
visible: root.enabled
}
Item {
id: track
width: parent.width
height: parent.height
Rectangle {
anchors.fill: parent
color: "white"
opacity: 0.5
}
Rectangle {
id: thumb
x: 2
width: parent.width - 4
height: root.barSize
radius: width / 2
color: "#4f4f4f"
Binding on y {
when: !thumbArea.drag.active
value: root.normalisedPosition() * root.scrollRange
}
MouseArea {
id: thumbArea
anchors.fill: parent
drag.axis: Drag.YAxis
drag.minimumY: 0
drag.maximumY: scrollRange
drag.target: thumb
preventStealing: true
onMouseYChanged: {
var position = (thumb.y / root.scrollRange)
flickable.contentY = position * verticalExtent();
}
}
}
} // of track item
}

View file

@ -1,4 +1,6 @@
import QtQuick 2.4 import QtQuick 2.4
import QtQuick.Controls 2.2
import FlightGear.Launcher 1.0 import FlightGear.Launcher 1.0
import "." import "."
@ -26,7 +28,9 @@ Item {
contentHeight: sectionColumn.childrenRect.height contentHeight: sectionColumn.childrenRect.height
flickableDirection: Flickable.VerticalFlick flickableDirection: Flickable.VerticalFlick
height: parent.height height: parent.height
width: parent.width - scrollbar.width width: parent.width
ScrollBar.vertical: ScrollBar {}
Column Column
{ {
@ -527,12 +531,4 @@ Item {
} }
} // of Column } // of Column
} // of Flickable } // of Flickable
Scrollbar {
id: scrollbar
anchors.right: parent.right
height: settingsFlick.height
flickable: settingsFlick
visible: settingsFlick.contentHeight > settingsFlick.height
}
} }

View file

@ -1,4 +1,6 @@
import QtQuick 2.4 import QtQuick 2.4
import QtQuick.Controls 2.2
import FlightGear.Launcher 1.0 import FlightGear.Launcher 1.0
import "." import "."
@ -26,9 +28,11 @@ Item {
Flickable { Flickable {
id: flick id: flick
ScrollBar.vertical: ScrollBar {}
anchors { anchors {
left: parent.left left: parent.left
right: scrollbar.right right: parent.right
top: buttonRow.bottom top: buttonRow.bottom
bottom: parent.bottom bottom: parent.bottom
margins: Style.margin margins: Style.margin
@ -51,12 +55,4 @@ Item {
text: _config.htmlForCommandLine(); text: _config.htmlForCommandLine();
} }
} }
Scrollbar {
id: scrollbar
anchors.right: parent.right
height: flick.height
flickable: flick
visible: flick.contentHeight > flick.height
}
} }

View file

@ -34,7 +34,6 @@
<file>qml/AircraftDownloadPanel.qml</file> <file>qml/AircraftDownloadPanel.qml</file>
<file>qml/Button.qml</file> <file>qml/Button.qml</file>
<file>qml/AircraftWarningPanel.qml</file> <file>qml/AircraftWarningPanel.qml</file>
<file>qml/Scrollbar.qml</file>
<file>qml/AircraftDetailsView.qml</file> <file>qml/AircraftDetailsView.qml</file>
<file>qml/AircraftFullDelegate.qml</file> <file>qml/AircraftFullDelegate.qml</file>
<file>qml/AircraftCompactDelegate.qml</file> <file>qml/AircraftCompactDelegate.qml</file>