diff options
author | Marvin Borner | 2020-04-04 20:24:18 +0200 |
---|---|---|
committer | Marvin Borner | 2020-04-04 20:24:18 +0200 |
commit | 81cc34bfcc8d7ec695a4d70c4c1c82b9035bf272 (patch) | |
tree | fd885f80b2670c29924f79b6b54343ed50b65d9a /qml/pages | |
parent | d452393fdc957503b0387932f442851265175f08 (diff) |
Different modes, fixed timer, zero doubletap, etc..
Diffstat (limited to 'qml/pages')
-rw-r--r-- | qml/pages/FirstPage.qml | 110 | ||||
-rw-r--r-- | qml/pages/Game.qml | 124 | ||||
-rw-r--r-- | qml/pages/LeaderBoard.qml | 2 | ||||
-rw-r--r-- | qml/pages/Menu.qml | 64 |
4 files changed, 189 insertions, 111 deletions
diff --git a/qml/pages/FirstPage.qml b/qml/pages/FirstPage.qml deleted file mode 100644 index bfc1ba0..0000000 --- a/qml/pages/FirstPage.qml +++ /dev/null @@ -1,110 +0,0 @@ -import QtQuick 2.2 -import Sailfish.Silica 1.0 -import ".." - -ApplicationWindow { - initialPage: pageComponent - - Component { - id: pageComponent - - Page { - id: page - allowedOrientations: Orientation.All - - SilicaFlickable { - anchors.fill: parent - contentHeight: root.height - - PullDownMenu { - MenuItem { - text: qsTr("Leaderboard") - onClicked: pageStack.push(Qt.resolvedUrl("LeaderBoard.qml")) - } - } - - Column { - property int bits: 4 - property var correct: new Array(bits) - property var matrix: new Array(Math.pow(bits + 1, 2)) - - id: root - width: page.width - height: page.height - spacing: Theme.paddingLarge - - PageHeader { - title: qsTr("Binary Fun") - } - - function nearest(number) { - if (number % (bits + 1) === 0) { - return number - } else { - return number - (number % (bits + 1)) - } - } - - function check(index) { - root.matrix[index] ^= 1; - var near = nearest(index); - - if (Number(root.matrix.slice(near, near + bits).join("")).toString() === (root.matrix[near + bits] >>> 0).toString(2)) { - correct[near / (bits + 1) - 1] = 1; - info_label.text = parseInt(info_label.text.substr(0, info_label.text.indexOf('/'))) + 1 + " / " + root.bits; - } else { - correct[near / (bits + 1) - 1] = 0; - } - - if (correct.filter(function(i) { return i === 1 }).length === bits) { - info_label.text = "Yeeehaa!"; - timer.running = false; - } - } - - Grid { - property int row: 0 - - id: grid - anchors.bottom: page.bottom - columns: root.bits + 1 - rows: root.bits + 1 - Repeater { - id: repeater - model: Math.pow(root.bits + 1, 2) - delegate: Bit { - bits: root.bits - index: modelData - width: page.width / (root.bits + 1) - } - } - } - - Label { - id: info_label - text: "0 / " + root.bits - anchors.horizontalCenter: parent.horizontalCenter - // anchors.top: grid.bottom - anchors.bottom: page.bottom - } - - Label { - id: timer_label - text: "0.0" - anchors.horizontalCenter: parent.horizontalCenter - // anchors.top: won.bottom - anchors.bottom: page.bottom - } - - Timer { - id: timer - interval: 1 - running: true - repeat: true - onTriggered: timer_label.text = (parseFloat(timer_label.text) + 0.01).toFixed(2).toString() - } - } - } - } - } -} diff --git a/qml/pages/Game.qml b/qml/pages/Game.qml new file mode 100644 index 0000000..8f95f58 --- /dev/null +++ b/qml/pages/Game.qml @@ -0,0 +1,124 @@ +import QtQuick 2.2 +import Sailfish.Silica 1.0 +import ".." + +Page { + property int bits: 0 // gets passed by previous page + + id: page + allowedOrientations: Orientation.All + + SilicaFlickable { + anchors.fill: parent + contentHeight: root.height + + /*PullDownMenu { + MenuItem { + text: qsTr("Leaderboard") + onClicked: pageStack.push(Qt.resolvedUrl("LeaderBoard.qml")) + } + }*/ + + Column { + property int bits: page.bits + property var correct: new Array(bits) + property var matrix: new Array(Math.pow(bits + 1, 2)) + property var start_time: 0 + + id: root + width: page.width + height: page.height + spacing: Theme.paddingLarge + + PageHeader { + title: qsTr("Binary Fun") + } + + function nearest(number) { + if (number % (bits + 1) === 0) { + return number + } else { + return number - (number % (bits + 1)) + } + } + + function check(index) { + root.matrix[index] ^= 1; + var near = nearest(index); + var current_score = parseInt(info_label.text.substr(0, info_label.text.indexOf('/'))) + + if (Number(root.matrix.slice(near, near + bits).join("")).toString() === (root.matrix[near + bits] >>> 0).toString(2)) { + correct[near / (bits + 1) - 1] = 1; + info_label.text = current_score + 1 + " / " + root.bits; + } else { + if (correct[near / (bits + 1) - 1] === 1) { + info_label.text = current_score - 1 + " / " + root.bits; + } + + correct[near / (bits + 1) - 1] = 0; + } + + if (correct.filter(function(i) { return i === 1 }).length === bits) { + info_label.text = "Yeeehaaw!"; + timer_label.text = ((new Date().getTime() - start_time) / 1000) + "s - Not bad!" + timer.running = false; + new_game.visible = true; + } + } + + Grid { + property int row: 0 + + id: grid + anchors.bottom: page.bottom + columns: root.bits + 1 + rows: root.bits + 1 + Repeater { + id: repeater + model: Math.pow(root.bits + 1, 2) + delegate: Bit { + bits: root.bits + index: modelData + width: page.width / (root.bits + 1) + } + } + } + + Label { + id: info_label + text: "0 / " + root.bits + anchors.horizontalCenter: parent.horizontalCenter + // anchors.top: grid.bottom + anchors.bottom: page.bottom + } + + Label { + id: timer_label + text: "0s" + anchors.horizontalCenter: parent.horizontalCenter + // anchors.top: won.bottom + anchors.bottom: page.bottom + } + + Timer { + id: timer + interval: 1000 + running: true + repeat: true + onTriggered: { + if (root.start_time === 0) + root.start_time = (new Date()).getTime(); + timer_label.text = parseInt(timer_label.text.substr(0, timer_label.text.indexOf('s'))) + 1 + "s"; + } + } + + Button { + id: new_game + text: qsTr("Play again!") + visible: false + anchors.horizontalCenter: parent.horizontalCenter + onClicked: pageStack.replace(Qt.resolvedUrl("Game.qml"), {bits: root.bits}) + } + } + } +} diff --git a/qml/pages/LeaderBoard.qml b/qml/pages/LeaderBoard.qml index 596b0e2..93dad0e 100644 --- a/qml/pages/LeaderBoard.qml +++ b/qml/pages/LeaderBoard.qml @@ -1,4 +1,4 @@ -import QtQuick 2.0 +import QtQuick 2.2 import Sailfish.Silica 1.0 Page { diff --git a/qml/pages/Menu.qml b/qml/pages/Menu.qml new file mode 100644 index 0000000..39de258 --- /dev/null +++ b/qml/pages/Menu.qml @@ -0,0 +1,64 @@ +import QtQuick 2.2 +import Sailfish.Silica 1.0 + +Page { + id: page + allowedOrientations: Orientation.All + + SilicaFlickable { + anchors.fill: parent + contentHeight: column.height + + Column { + id: column + width: page.width + height: page.height + spacing: Theme.paddingLarge + + PageHeader { + title: qsTr("Binary Fun") + } + + ButtonLayout { + anchors.horizontalCenter: parent.horizontalCenter + anchors.verticalCenter: parent.verticalCenter + rowSpacing: Theme.paddingLarge * 2 + + Button { + text: qsTr("Very easy (2 Bit)") + onClicked: { + pageStack.push(Qt.resolvedUrl("Game.qml"), {bits: 2}); + } + } + + Button { + text: qsTr("Easy (4 Bit)") + onClicked: { + pageStack.push(Qt.resolvedUrl("Game.qml"), {bits: 4}); + } + } + + Button { + text: qsTr("Medium (6 Bit)") + onClicked: { + pageStack.push(Qt.resolvedUrl("Game.qml"), {bits: 6}); + } + } + + Button { + text: qsTr("Hard (8 Bit)") + onClicked: { + pageStack.push(Qt.resolvedUrl("Game.qml"), {bits: 8}); + } + } + + Button { + text: qsTr("Godlike (10 Bit)") + onClicked: { + pageStack.push(Qt.resolvedUrl("Game.qml"), {bits: 10}); + } + } + } + } + } +} |