diff options
author | Aaron Kennedy <aaron.kennedy@nokia.com> | 2009-04-28 05:12:21 (GMT) |
---|---|---|
committer | Aaron Kennedy <aaron.kennedy@nokia.com> | 2009-04-28 05:12:21 (GMT) |
commit | daab991ef3705813cf0f3662c0b0bc241cafdf0f (patch) | |
tree | 91fecefe392557fbac53574fbfb6dac8906a108b /examples | |
parent | 2b8abf28d10a6d064fe116892161289be5ffb391 (diff) | |
parent | c139630bb792e3d0e364c05c7be3e190bfd90b64 (diff) | |
download | Qt-daab991ef3705813cf0f3662c0b0bc241cafdf0f.zip Qt-daab991ef3705813cf0f3662c0b0bc241cafdf0f.tar.gz Qt-daab991ef3705813cf0f3662c0b0bc241cafdf0f.tar.bz2 |
Merge branch 'kinetic-declarativeui' of ../kinetic into kinetic-declarativeui-qfx
Conflicts:
examples/declarative/minehunt/minehunt.qml
Diffstat (limited to 'examples')
-rw-r--r-- | examples/declarative/minehunt/minehunt.qml | 257 |
1 files changed, 72 insertions, 185 deletions
diff --git a/examples/declarative/minehunt/minehunt.qml b/examples/declarative/minehunt/minehunt.qml index 9454f2f..20c3874 100644 --- a/examples/declarative/minehunt/minehunt.qml +++ b/examples/declarative/minehunt/minehunt.qml @@ -1,186 +1,73 @@ -Item { - id: field - width: 370 - height: 480 - properties: Property { - name: "clickx" - type: "Int" - value: 0 - } - properties: Property { - name: "clicky" - type: "Int" - value: 0 - } - resources: [ - Component { - id: tile - Flipable { - id: flipable - width: 40 - height: 40 - transform: [ - Axis { - id: axis - xStart: 20 - xEnd: 20 - yStart: 20 - yEnd: 0 - } - ] - front: Image { - src: "pics/front.png" - width: 40 - height: 40 - Image { - anchors.horizontalCenter: parent.horizontalCenter - anchors.verticalCenter: parent.verticalCenter - src: "pics/flag.png" - opacity: modelData.hasFlag - opacity: Behaviour { - NumericAnimation { - property: "opacity" - duration: 250 - } - } - } - } - back: Image { - src: "pics/back.png" - width: 40 - height: 40 - Text { - anchors.horizontalCenter: parent.horizontalCenter - anchors.verticalCenter: parent.verticalCenter - text: modelData.hint - color: "white" - font.bold: true - opacity: modelData.hasMine == false && modelData.hint > 0 - } - Image { - anchors.horizontalCenter: parent.horizontalCenter - anchors.verticalCenter: parent.verticalCenter - src: "pics/bomb.png" - opacity: modelData.hasMine - } - Explosion { - anchors.horizontalCenter: parent.horizontalCenter - anchors.verticalCenter: parent.verticalCenter - explode: modelData.hasMine==true && modelData.flipped==true - } - } - states: [ - State { - name: "back" - when: modelData.flipped == true - SetProperty { - target: axis - property: "rotation" - value: 180 - } - } - ] - transitions: [ - Transition { - SequentialAnimation { - PauseAnimation { - duration: { - var ret = Math.abs(flipable.parent.x-field.clickx) + - Math.abs(flipable.parent.y-field.clicky); +<Item id="field" width="370" height="480"> + <properties> + <Property name="clickx" type="Int" value="0"/> + <Property name="clicky" type="Int" value="0"/> + </properties> + <resources> + <Component id="tile"> + <Flipable id="flipable" width="40" height="40"> + <transform> + <AxisRotation id="axis" axis.startX="20" axis.endX="20" axis.startY="20" axis.endY="0" /> + </transform> + <front> + <Image src="pics/front.png" width="40" height="40"> + <Image anchors.horizontalCenter="{parent.horizontalCenter}" + anchors.verticalCenter="{parent.verticalCenter}" + src="pics/flag.png" opacity="{modelData.hasFlag}"> + <opacity> + <Behaviour> + <NumericAnimation property="opacity" duration="250"/> + </Behaviour> + </opacity> + </Image> + </Image> + </front> + <back> + <Image src="pics/back.png" width="40" height="40"> + <Text anchors.horizontalCenter="{parent.horizontalCenter}" anchors.verticalCenter="{parent.verticalCenter}" + text="{modelData.hint}" color="white" font.bold="true" + opacity="{modelData.hasMine == false && modelData.hint > 0}"/> + <Image anchors.horizontalCenter="{parent.horizontalCenter}" anchors.verticalCenter="{parent.verticalCenter}" + src="pics/bomb.png" opacity="{modelData.hasMine}"/> + <Explosion anchors.horizontalCenter="{parent.horizontalCenter}" anchors.verticalCenter="{parent.verticalCenter}" explode="{modelData.hasMine==true && modelData.flipped==true}"/> + </Image> + </back> + <states> + <State name="back" when="{modelData.flipped == true}"> + <SetProperty target="{axis}" property="angle" value="180" /> + </State> + </states> + <transitions> + <Transition> + <SequentialAnimation> + <PauseAnimation duration="{var ret = Math.abs(flipable.parent.x-field.clickx) + Math.abs(flipable.parent.y-field.clicky); if (ret > 0) {if(modelData.hasMine==true && modelData.flipped==true){ret*3;}else{ret;}} else {0}}"/> + <NumericAnimation easing="easeInOutQuad" properties="angle"/> + </SequentialAnimation> + </Transition> + </transitions> + <MouseRegion anchors.fill="{parent}" + onClicked="field.clickx = flipable.parent.x; field.clicky = flipable.parent.y; row = Math.floor(index/9); col = index - (Math.floor(index/9) * 9); if(mouseButton==undefined || mouseButton=='Right'){flag(row,col);}else{flip(row,col);}" /> + </Flipable> + </Component> + </resources> + <Image src="pics/No-Ones-Laughing-3.jpg" tile="true"/> + <Description text="Use the 'minehunt' executable to run this demo!" width="300" opacity="{tiles?0:1}" anchors.horizontalCenter="{parent.horizontalCenter}" anchors.verticalCenter="{parent.verticalCenter}"/> + <Repeater dataSource="{tiles}" x="1" y="1"> + <Component> + <ComponentInstance component="{tile}" + x="{(index - (Math.floor(index/9) * 9)) * 41}" + y="{Math.floor(index/9) * 41}"/> + </Component> + </Repeater> + <Item id="gamedata" width="370" height="100" y="380"> + <Text color="white" font.size="18" x="20" y="20">In play:</Text> + <Image x="100" y="20" src="pics/bomb-color.png"/> + <Text x="100" y="60" color="white" text="{numMines}"/> + <Image x="140" y="20" src="pics/flag-color.png"/> + <Text x="140" y="60" color="white" text="{numFlags}"/> - ret > 0 - ? (modelData.hasMine==true && modelData.flipped==true) ? ret * 3 : ret - : 0 - } - } - NumericAnimation { - easing: "easeInOutQuad" - properties: "rotation" - } - } - } - ] - MouseRegion { - anchors.fill: parent - onClicked: { - field.clickx = flipable.parent.x; - field.clicky = flipable.parent.y; - row = Math.floor(index/9); - col = index - (Math.floor(index/9) * 9); - if (mouseButton==undefined || mouseButton=='Right') { - flag(row, col); - } else{ - flip(row, col); - } - } - } - } - } - ] - Image { - src: "pics/No-Ones-Laughing-3.jpg" - tile: true - } - Description { - text: "Use the 'minehunt' executable to run this demo!" - width: 300 - opacity: tiles?0:1 - anchors.horizontalCenter: parent.horizontalCenter - anchors.verticalCenter: parent.verticalCenter - } - Repeater { - dataSource: tiles - x: 1 - y: 1 - Component { - ComponentInstance { - component: tile - x: (index - (Math.floor(index/9) * 9)) * 41 - y: Math.floor(index/9) * 41 - } - } - } - Item { - id: gamedata - width: 370 - height: 100 - y: 380 - Text { - color: "white" - font.size: 18 - x: 20 - y: 20 - } - Image { - x: 100 - y: 20 - src: "pics/bomb-color.png" - } - Text { - x: 100 - y: 60 - color: "white" - text: numMines - } - Image { - x: 140 - y: 20 - src: "pics/flag-color.png" - } - Text { - x: 140 - y: 60 - color: "white" - text: numFlags - } - Image { - x: 240 - y: 0 - src: if(isPlaying==true){'pics/smile.png'}else{if(hasWon==true){'pics/glee.png'}else{'pics/frown.png'}} - MouseRegion { - anchors.fill: parent - onClicked: { reset() } - } - } - } -} + <Image x="240" y="0" src="{if(isPlaying==true){'pics/smile.png'}else{if(hasWon==true){'pics/glee.png'}else{'pics/frown.png'}}}"> + <MouseRegion anchors.fill="{parent}" onClicked="reset()"/> + </Image> + </Item> +</Item> |