1/**************************************************************************** 2** 3** Copyright (C) 2017 The Qt Company Ltd. 4** Contact: https://www.qt.io/licensing/ 5** 6** This file is part of the examples of the Qt Toolkit. 7** 8** $QT_BEGIN_LICENSE:BSD$ 9** Commercial License Usage 10** Licensees holding valid commercial Qt licenses may use this file in 11** accordance with the commercial license agreement provided with the 12** Software or, alternatively, in accordance with the terms contained in 13** a written agreement between you and The Qt Company. For licensing terms 14** and conditions see https://www.qt.io/terms-conditions. For further 15** information use the contact form at https://www.qt.io/contact-us. 16** 17** BSD License Usage 18** Alternatively, you may use this file under the terms of the BSD license 19** as follows: 20** 21** "Redistribution and use in source and binary forms, with or without 22** modification, are permitted provided that the following conditions are 23** met: 24** * Redistributions of source code must retain the above copyright 25** notice, this list of conditions and the following disclaimer. 26** * Redistributions in binary form must reproduce the above copyright 27** notice, this list of conditions and the following disclaimer in 28** the documentation and/or other materials provided with the 29** distribution. 30** * Neither the name of The Qt Company Ltd nor the names of its 31** contributors may be used to endorse or promote products derived 32** from this software without specific prior written permission. 33** 34** 35** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 36** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 37** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 38** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 39** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 40** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 41** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 42** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 43** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 44** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 45** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE." 46** 47** $QT_END_LICENSE$ 48** 49****************************************************************************/ 50 51 import QtQuick 2.0 52 import QtQuick.Window 2.0 53 54 Component { 55 id: photoDelegate 56 Item { 57 id: wrapper; width: 79; height: 79 58 59 function photoClicked() { 60 imageDetails.photoTitle = title; 61 imageDetails.photoDate = datetaken; 62 imageDetails.photoUrl = "http://farm" + farm + ".static.flickr.com/" + server + "/" + id + "_" + secret + ".jpg"; 63 console.log(imageDetails.photoUrl); 64 scaleMe.state = "Details"; 65 } 66 67 Item { 68 anchors.centerIn: parent 69 scale: 0.0 70 Behavior on scale { NumberAnimation { easing.type: Easing.InOutQuad} } 71 id: scaleMe 72 73 Rectangle { height: 79; width: 79; id: blackRect; anchors.centerIn: parent; color: "black"; smooth: true } 74 Rectangle { 75 id: whiteRect; width: 76; height: 76; anchors.centerIn: parent; color: "#dddddd"; smooth: true 76 Image { id: thumb; 77 // source: imagePath; 78 source: imageDetails.photoUrl = "http://farm" + farm + ".static.flickr.com/" + server + "/" + id + "_" + secret + "_t.jpg" 79 width: parent.width; height: parent.height 80 x: 1; y: 1; smooth: true} 81 Image { source: "images/gloss.png" } 82 } 83 84 Connections { 85 target: toolBar 86 onButton2Clicked: if (scaleMe.state == 'Details' ) scaleMe.state = 'Show' 87 } 88 89 states: [ 90 State { 91 name: "Show"; when: thumb.status == Image.Ready 92 PropertyChanges { target: scaleMe; scale: Math.round(Screen.pixelDensity / 4) } 93 }, 94 State { 95 name: "Details" 96 PropertyChanges { target: scaleMe; scale: Math.round(Screen.pixelDensity / 4)} 97 ParentChange { target: wrapper; parent: imageDetails.frontContainer } 98 PropertyChanges { target: wrapper; x: 20; y: 60; z: 1000 } 99 PropertyChanges { target: background; state: "DetailedView" } 100 } 101 ] 102 transitions: [ 103 Transition { 104 from: "Show"; to: "Details" 105 ParentAnimation { 106 NumberAnimation { properties: "x,y"; duration: 500; easing.type: Easing.InOutQuad } 107 } 108 }, 109 Transition { 110 from: "Details"; to: "Show" 111 SequentialAnimation { 112 ParentAnimation { 113 NumberAnimation { properties: "x,y"; duration: 500; easing.type: Easing.InOutQuad } 114 } 115 PropertyAction { targets: wrapper; properties: "z" } 116 } 117 } 118 ] 119 } 120 MouseArea { anchors.fill: wrapper; onClicked: { photoClicked() } } 121 } 122 } 123