summaryrefslogtreecommitdiffstats
path: root/experimental
diff options
context:
space:
mode:
authorGunnar Sletta <gunnar.sletta@digia.com>2013-04-23 11:19:39 +0200
committerGunnar Sletta <gunnar.sletta@digia.com>2013-04-23 12:49:59 +0300
commit730bf7b256f0f06c39f92dad064869f5d1368c62 (patch)
treee836042801e0f2e0492de6ca576cd30c956c633d /experimental
parent2ceb4b09650242b97bf17b968c49b6e6cf12601a (diff)
fixed up the demo suite
Change-Id: I42dfba551b26f66b8de41dad3df2a5e120c82fb8 Reviewed-by: Eirik Aavitsland <eirik.aavitsland@digia.com>
Diffstat (limited to 'experimental')
-rw-r--r--experimental/Wifi/main.qml157
1 files changed, 157 insertions, 0 deletions
diff --git a/experimental/Wifi/main.qml b/experimental/Wifi/main.qml
new file mode 100644
index 0000000..e01e6ee
--- /dev/null
+++ b/experimental/Wifi/main.qml
@@ -0,0 +1,157 @@
+import QtQuick 2.0
+import Qt.labs.wifi 0.1
+
+Rectangle
+{
+ id: root
+
+ color: Qt.rgba(Math.random(), Math.random(), Math.random(), 1);
+
+ QWifiManager {
+ id: wifiManager;
+
+ Component.onCompleted: start();
+
+ onReadyChanged: {
+ print("QML: QWifiManager is now connected...");
+ }
+
+ onOnlineChanged: print(online ? "QML: WifiManager is online" : "QML: WifiManager is not online...");
+
+ scanning: ready && connectedSSID == "";
+ }
+
+ Component {
+ id: listDelegate
+
+ Rectangle {
+ id: delegateBackground
+ property bool expanded: false
+ height: expanded ? 300 : 70
+ clip: true // ### fixme
+
+ Behavior on height { NumberAnimation { duration: 500; easing.type: Easing.InOutCubic } }
+
+ width: parent.width
+
+ gradient: Gradient {
+ GradientStop { position: 0; color: "white" }
+ GradientStop { position: 67 / delegateBackground.height; color: "lightgray" }
+ GradientStop { position: 1; color: "gray" }
+ }
+
+ Text {
+ id: ssidLabel
+ anchors.top: parent.top
+ anchors.left: parent.left
+ anchors.margins: 10
+ font.pixelSize: 24
+ font.bold: true
+ text: network.ssid + (wifiManager.connectedSSID == network.ssid ? " (connected)" : "");
+ }
+
+ Text {
+ id: bssidLabel
+ anchors.top: ssidLabel.bottom
+ anchors.left: parent.left
+ anchors.margins: 5
+ anchors.leftMargin: 40
+ text: network.bssid
+ color: "gray"
+ font.pixelSize: ssidLabel.font.pixelSize * 0.5
+ }
+
+ Text {
+ id: flagsLabel
+ x: 200
+ anchors.top: bssidLabel.top
+ text: (network.supportsWPA2 ? "WPA2 " : "")
+ + (network.supportsWPA ? "WPA " : "")
+ + (network.supportsWEP ? "WEP " : "")
+ + (network.supportsWPS ? "WPS " : "");
+ color: "gray"
+ font.pixelSize: ssidLabel.font.pixelSize * 0.5
+ font.italic: true
+ }
+
+ Rectangle {
+ width: Math.max(100 + network.signalStrength, 0) / 100 * parent.width;
+ height: 20
+ radius: 10
+ antialiasing: true
+ anchors.margins: 20
+ anchors.right: parent.right
+ anchors.top: parent.top
+ color: "white"
+ border.color: "lightgray"
+ }
+
+ MouseArea {
+ anchors.fill: parent
+ onClicked: {
+ parent.expanded = !expanded
+ }
+ }
+
+ Rectangle {
+ id: passwordInputBackground
+ anchors.fill: passwordInput
+ anchors.margins: -5
+ color: "white"
+ radius: 5
+ border.color: "gray"
+ }
+
+ TextInput {
+ id: passwordInput
+ y: 100
+ width: 300
+ height: 50
+ anchors.horizontalCenter: parent.horizontalCenter
+ font.pixelSize: 14
+ }
+
+ Rectangle {
+ id: connectButton
+ anchors.top: passwordInput.bottom
+ anchors.margins: 20
+ anchors.horizontalCenter: parent.horizontalCenter
+ width: passwordInput.width
+ height: passwordInputBackground.height
+
+ gradient: Gradient {
+ GradientStop { position: 0; color: "white" }
+ GradientStop { position: 1; color: buttonMouse.pressed ? "steelblue" : "lightsteelblue" }
+ }
+
+ border.color: "gray"
+
+ Text {
+ anchors.centerIn: parent
+ font.pixelSize: 24
+ text: "Connect"
+ }
+ MouseArea {
+ id: buttonMouse
+ anchors.fill: parent
+ onClicked: wifiManager.connect(network, passwordInput.text);
+ }
+ }
+
+ }
+ }
+
+ ListView {
+ anchors.fill: root
+ model: wifiManager.networks
+ delegate: listDelegate;
+ }
+
+ Image {
+ source: wifiManager.online ? "http://img3.imageshack.us/img3/9870/magepicture.jpg" : ""
+ anchors.bottom: parent.bottom
+
+ width: parent.width
+ height: sourceSize.height * (width / sourceSize.width);
+ }
+}