aboutsummaryrefslogtreecommitdiffhomepage
path: root/qml/pages
diff options
context:
space:
mode:
authorMarvin Borner2020-04-04 20:24:18 +0200
committerMarvin Borner2020-04-04 20:24:18 +0200
commit81cc34bfcc8d7ec695a4d70c4c1c82b9035bf272 (patch)
treefd885f80b2670c29924f79b6b54343ed50b65d9a /qml/pages
parentd452393fdc957503b0387932f442851265175f08 (diff)
Different modes, fixed timer, zero doubletap, etc..
Diffstat (limited to 'qml/pages')
-rw-r--r--qml/pages/FirstPage.qml110
-rw-r--r--qml/pages/Game.qml124
-rw-r--r--qml/pages/LeaderBoard.qml2
-rw-r--r--qml/pages/Menu.qml64
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});
+ }
+ }
+ }
+ }
+ }
+}