forked from slint-ui/slint
-
Notifications
You must be signed in to change notification settings - Fork 0
/
memory.slint
124 lines (102 loc) · 3.48 KB
/
memory.slint
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
// Copyright © SixtyFPS GmbH <[email protected]>
// SPDX-License-Identifier: MIT
struct TileData {
image: image,
image-visible: bool,
solved: bool,
}
component MemoryTile inherits Rectangle {
in property <bool> open-curtain;
in property <bool> solved;
in property <image> icon;
callback clicked;
border-radius: 8px;
background: root.solved ? #70ff00 : #858585;
animate background { duration: 800ms; }
Image {
source: root.icon;
width: parent.width - 16px;
height: parent.height - 16px;
x: 8px;
y: 8px;
}
// Left curtain
Rectangle {
x: 0;
background: #0025ff;
border-radius: 4px;
width: root.open-curtain ? 0px : parent.width / 2 + 4px;
height: parent.height;
clip: true;
animate width { duration: 250ms; easing: ease-in; }
Image {
width: root.width - 32px;
height: root.height - 32px;
x: 16px;
y: 16px;
source: @image-url("icons/tile_logo.png");
}
}
// Right curtain
right-curtain := Rectangle {
background: #0025ff;
border-radius: 4px;
x: root.open-curtain ? parent.width : parent.width / 2 - 4px;
width: root.open-curtain ? 0px : parent.width / 2 + 4px;
height: parent.height;
clip: true;
animate width { duration: 250ms; easing: ease-in; }
animate x { duration: 250ms; easing: ease-in; }
Image {
width: root.width - 32px;
height: root.height - 32px;
x: right-curtain.width - self.width - 16px;
y: 16px;
source: @image-url("icons/tile_logo.png");
}
}
TouchArea {
clicked => {
root.clicked();
}
width: 100%;
height: 100%;
}
}
export component MainWindow inherits Window {
in property <bool> disable-tiles;
in property <[TileData]> memory-tiles : [
{ image: @image-url("icons/at.png") },
{ image: @image-url("icons/balance-scale.png") },
{ image: @image-url("icons/bicycle.png") },
{ image: @image-url("icons/bus.png") },
{ image: @image-url("icons/cloud.png") },
{ image: @image-url("icons/cogs.png") },
{ image: @image-url("icons/motorcycle.png") },
{ image: @image-url("icons/video.png") },
];
callback check-if-pair-solved();
private property <length> tile-size: 80px;
private property <length> tile-spacing: 10px;
private property <int> row-count: 4;
private property <int> column-count: 4;
// "column_count + 1" and "row_count + 1" are the number of gaps between the tiles.
width: (root.column-count * root.tile-size) + ((root.column-count + 1) * root.tile-spacing);
height: (root.row-count * root.tile-size) + ((root.row-count + 1) * root.tile-spacing);
title: "Memory Game - Slint Demo";
for tile[i] in root.memory-tiles: MemoryTile {
clicked => {
if (!root.disable-tiles) {
tile.image-visible = true;
root.check-if-pair-solved();
}
}
x: root.tile-spacing + mod(i, root.column-count) * (root.tile-size + root.tile-spacing);
y: root.tile-spacing + floor(i / root.row-count) * (root.tile-size + root.tile-spacing);
width: root.tile-size;
height: root.tile-size;
icon: tile.image;
open-curtain: tile.image-visible || tile.solved;
solved: tile.solved;
}
}