Viadeo Twitter Google Bookmarks ! Facebook Digg del.icio.us MySpace Yahoo MyWeb Blinklist Netvouz Reddit Simpy StumbleUpon Bookmarks Windows Live Favorites 
Logo Documentation Qt ·  Page d'accueil  ·  Toutes les classes  ·  Classes principales  ·  Annotées  ·  Classes groupées  ·  Modules  ·  Fonctions  · 

qmlcontactslistview.qml Example File

qmlcontactslistview/qmlcontactslistview.qml
 /****************************************************************************
 **
 ** Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies).
 ** Contact: http://www.qt-project.org/
 **
 ** This file is part of the documentation of the Qt Pim Module.
 **
 ** $QT_BEGIN_LICENSE:FDL$
 ** GNU Free Documentation License
 ** Alternatively, this file may be used under the terms of the GNU Free
 ** Documentation License version 1.3 as published by the Free Software
 ** Foundation and appearing in the file included in the packaging of
 ** this file.
 **
 ** Other Usage
 ** Alternatively, this file may be used in accordance with the terms
 ** and conditions contained in a signed written agreement between you
 ** and Nokia.
 **
 **
 **
 **
 **
 ** $QT_END_LICENSE$
 **
 ****************************************************************************/
 import QtQuick 2.0
 import QtContacts 5.0

 Rectangle {
     id: contactsApplication
     width: 400
     height: 600
     state: "listView"

     Rectangle {
         id: browsingArea
         anchors {
             top: parent.top
             left: parent.left
             right: parent.right
         }
         height: contactsApplication.height - btnArea.height - statusBar.height
         color: "lightblue"

         ContactModel {
             id: contactsModel
             manager: "memory"
             Component.onCompleted: {
                     contactsModel.importContacts(Qt.resolvedUrl("example.vcf"))
             }
             sortOrders: [
                 SortOrder {
                     detail: ContactDetail.Name
                     field: Name.FirstName
                     direction: Qt.AscendingOrder
                 }
             ]
         }

         // ![Contact delegate]
         Component {
             id: contactDelegate

             Rectangle {
                 id: delRect
                 width: parent.width
                 height: 60
                 border.width: 1
                 border.color: "darkgreen"
                 color: delRect.ListView.isCurrentItem ? "#F5678A" : browsingArea.color

                 Column {
                     anchors {
                         verticalCenter: parent.verticalCenter
                         left: parent.left
                         leftMargin: 6
                     }
                     Text {
                         text: contact.name.firstName
                         font.bold: true
                     }
                     Text { text: contact.phoneNumber.number }
                 }

                 Keys.onReturnPressed: {
                     contactEditor.contact = contact
                     goToEditView()
                 }

                 MouseArea {
                     anchors.fill: parent
                     onClicked: {
                         contactsView.currentIndex = index
                     }
                 }
             }
         }
         // ![Contact delegate]

         // ![ListView for showing the contacts]
         ListView {
             id: contactsView
             anchors.fill: browsingArea
             width: browsingArea.width
             height: browsingArea.height
             model: contactsModel
             focus: true
             clip: true
             delegate: contactDelegate
         }
         // ![ListView for showing the contacts]
     }

     // ![Button area]
     Rectangle {
         id: btnArea
         width: parent.width
         height: 20
         color: "#C7BFBF"
         anchors {
             bottom: statusBar.top
             right: parent.right
             left: parent.left
         }
         Row {
             id: btnRow
             anchors.centerIn: parent
             spacing: 10

             // buttons for 'listView' state
             GenericButton {
                 id: btnNew
                 width: 160
                 buttonText: "Add New Contact"
                 visible: true
                 onClicked: {
                     contactEditor.contact = 0
                     goToEditView()
                 }
             }
             GenericButton {
                 id: btnEdit
                 width: 160
                 buttonText: "Edit Contact"
                 visible: true
                 onClicked: {
                     contactEditor.contact = contactsView.model.contacts[contactsView.currentIndex]
                     goToEditView()
                 }
             }
             // buttons for 'editView' state
             GenericButton {
                 id: btnCancel
                 width: 120
                 buttonText: "Cancel"
                 visible: false
                 onClicked: {
                     contactEditor.cancel()
                     goToListView()
                 }
             }

             GenericButton {
                 id: btnDelete
                 width: 120
                 buttonText: "Delete"
                 visible: false
                 onClicked: {
                     contactEditor.deleteContact()
                     goToListView()
                 }
             }

             GenericButton {
                 id: btnSave
                 width: 120
                 buttonText: "Save"
                 visible: false
                 onClicked: {
                     contactEditor.updateContact()
                     goToListView()
                 }
             }
         }
     }
     // ![Button area]

     // ![Status bar area]
     Rectangle {
         id: statusBar
         anchors {
             bottom: parent.bottom
             right: parent.right
             left: parent.left
         }
         width: parent.width
         height: 24
         color: "gainsboro"

         Text {
             id: barText
             anchors.centerIn: parent
             text: " "
         }

         Timer {
             id: barTimer
             interval: 2000
             running: false
             onTriggered: {
                 barText.text = " "
             }
         }

         function updateMsg(msg) {
             barText.text = msg
             barTimer.restart()
         }
     }
     // ![Status bar area]

     // ![Custom contact editor]
     ContactEditor {
         id: contactEditor
         height: parent.height - statusBar.height - btnArea.height
         z: -1
     }
     // ![Custom contact editor]

     // ![Applications state changes]
     states: [
         State {
             name: "listView"
             PropertyChanges {
                 target: contactEditor
                 z: -1
             }
             PropertyChanges {
                 target: contactsView
                 focus: true
             }
         },
         State {
             name: "editView"
             PropertyChanges {
                 target: contactEditor
                 z: 1
             }
             PropertyChanges { target: btnNew; visible: false }
             PropertyChanges { target: btnEdit; visible: false }
             PropertyChanges { target: btnCancel; visible: true }
             PropertyChanges { target: btnDelete; visible: true }
             PropertyChanges { target: btnSave; visible: true }
             StateChangeScript { script: contactEditor.resetToDefaults() }
         }
     ]
     // ![Applications state changes]

     function goToListView() {
         contactEditor.contact = ""
         contactsApplication.state = "listView"
     }

     function goToEditView() {
         contactsApplication.state = "editView"
     }
 }
Cette page est une traduction d'une page de la documentation de Qt, écrite par Nokia Corporation and/or its subsidiary(-ies). Les éventuels problèmes résultant d'une mauvaise traduction ne sont pas imputables à Nokia. Qt 5.0-snapshot
Copyright © 2012 Developpez LLC. Tous droits réservés Developpez LLC. Aucune reproduction, même partielle, ne peut être faite de ce site et de l'ensemble de son contenu : textes, documents et images sans l'autorisation expresse de Developpez LLC. Sinon, vous encourez selon la loi jusqu'à 3 ans de prison et jusqu'à 300 000 E de dommages et intérêts. Cette page est déposée à la SACD.
Vous avez déniché une erreur ? Un bug ? Une redirection cassée ? Ou tout autre problème, quel qu'il soit ? Ou bien vous désirez participer à ce projet de traduction ? N'hésitez pas à nous contacter ou par MP !
 
 
 
 
Partenaires

Hébergement Web