IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)

Container QML Type

Abstract base type providing functionality common to containers.

Article lu   fois.

L'auteur

Liens sociaux

Viadeo Twitter Facebook Share on Google+   

Container QML Type

I. Detailed Description

Container is the base type of container-like user interface controls that allow dynamic insertion and removal of items.

I-1. Using Containers

Typically, items are statically declared as children of Container, but it is also possible to add, insert, move and remove items dynamically. The items in a container can be accessed using itemAt() or contentChildren.

Most containers have the concept of a "current" item. The current item is specified via the currentIndex property, and can be accessed using the read-only currentItem property.

The following example illustrates dynamic insertion of items to a TabBar, which is one of the concrete implementations of Container.

 
Sélectionnez
Row {
    TabBar {
        id: tabBar

        currentIndex: 0
        width: parent.width - addButton.width

        TabButton { text: "TabButton" }
    }

    Component {
        id: tabButton
        TabButton { text: "TabButton" }
    }

    Button {
        id: addButton
        text: "+"
        flat: true
        onClicked: {
            tabBar.addItem(tabButton.createObject(tabBar))
            console.log("added:", tabBar.itemAt(tabBar.count - 1))
        }
    }
}

I-2. Managing the Current Index

When using multiple containers, such as TabBar and SwipeView, together, their currentIndex properties can be bound to each other to keep them in sync. When the user interacts with either container, its current index changes automatically propagate to the other container.

Notice, however, that assigning a currentIndex value in JavaScript removes the respective binding. In order to retain the bindings, use the following methods to alter the current index:

 
Sélectionnez
TabBar {
    id: tabBar
    currentIndex: swipeView.currentIndex
}

SwipeView {
    id: swipeView
    currentIndex: tabBar.currentIndex
}

Button {
    text: qsTr("Home")
    onClicked: swipeView.setCurrentIndex(0)
    enabled: swipeView.currentIndex != 0
}

Button {
    text: qsTr("Previous")
    onClicked: swipeView.decrementCurrentIndex()
    enabled: swipeView.currentIndex > 0
}

Button {
    text: qsTr("Next")
    onClicked: swipeView.incrementCurrentIndex()
    enabled: swipeView.currentIndex < swipeView.count - 1
}

I-3. Implementing Containers

Container does not provide any default visualization. It is used to implement such containers as SwipeView and TabBar. When implementing a custom container, the most important part of the API is contentModel, which provides the contained items in a way that it can be used as a delegate model for item views and repeaters.

 
Sélectionnez
Container {
    id: container

    contentItem: ListView {
        model: container.contentModel
        snapMode: ListView.SnapOneItem
        orientation: ListView.Horizontal
    }

    Text {
        text: "Page 1"
        width: container.width
        height: container.height
    }

    Text {
        text: "Page 2"
        width: container.width
        height: container.height
    }
}

Notice how the sizes of the page items are set by hand. This is because the example uses a plain Container, which does not make any assumptions on the visual layout. It is typically not necessary to specify sizes for items in concrete Container implementations, such as SwipeView and TabBar.

I-4. See Also

II. Property Documentation

 

II-1. contentChildren : list<Item>

This property holds the list of content children.

The list contains all items that have been declared in QML as children of the container, and also items that have been dynamically added or inserted using the addItem() and insertItem() methods, respectively.

Unlike contentData, contentChildren does not include non-visual QML objects. It is re-ordered when items are inserted or moved.

II-1-1. See Also

II-2. [default] contentData : list<QtObject>

This property holds the list of content data.

The list contains all objects that have been declared in QML as children of the container, and also items that have been dynamically added or inserted using the addItem() and insertItem() methods, respectively.

Unlike contentChildren, contentData does include non-visual QML objects. It is not re-ordered when items are inserted or moved.

II-2-1. See Also

II-3. [since QtQuick.Controls 2.5 (Qt 5.12)] contentHeight : real

This property holds the content height. It is used for calculating the total implicit height of the container.

Unless explicitly overridden, the content height is automatically calculated based on the implicit height of the items in the container.

This property was introduced in QtQuick.Controls 2.5 (Qt 5.12).

II-3-1. See Also

See also contentWidth

II-4. [read-only] contentModel : model

This property holds the content model of items.

The content model is provided for visualization purposes. It can be assigned as a model to a content item that presents the contents of the container.

 
Sélectionnez
Container {
    id: container
    contentItem: ListView {
        model: container.contentModel
    }
}
II-4-1. See Also

II-5. [since QtQuick.Controls 2.5 (Qt 5.12)] contentWidth : real

This property holds the content width. It is used for calculating the total implicit width of the container.

Unless explicitly overridden, the content width is automatically calculated based on the implicit width of the items in the container.

This property was introduced in QtQuick.Controls 2.5 (Qt 5.12).

II-5-1. See Also

See also contentHeight

II-6. [read-only] count : int

This property holds the number of items.

II-7. currentIndex : int

This property holds the index of the current item.

II-7-1. See Also

II-8. [read-only] currentItem : Item

This property holds the current item.

II-8-1. See Also

See also currentIndex

III. Method Documentation

 

III-1. void addItem(Item item)

Adds an item.

III-2. [since QtQuick.Controls 2.1 (Qt 5.8)] void decrementCurrentIndex()

Decrements the current index of the container.

This method can be called to alter the current index without breaking existing currentIndex bindings.

This method was introduced in QtQuick.Controls 2.1 (Qt 5.8).

III-2-1. See Also

III-3. [since QtQuick.Controls 2.1 (Qt 5.8)] void incrementCurrentIndex()

Increments the current index of the container.

This method can be called to alter the current index without breaking existing currentIndex bindings.

This method was introduced in QtQuick.Controls 2.1 (Qt 5.8).

III-3-1. See Also

III-4. void insertItem(int index, Item item)

Inserts an item at index.

III-5. Item itemAt(int index)

Returns the item at index, or null if it does not exist.

III-6. void moveItem(int from, int to)

Moves an item from one index to another.

III-7. [since QtQuick.Controls 2.3 (Qt 5.10)] void removeItem(Item item)

Removes and destroys the specified item.

This method was introduced in QtQuick.Controls 2.3 (Qt 5.10).

III-8. void setCurrentIndex(int index)

Sets the current index of the container.

This method can be called to set a specific current index without breaking existing currentIndex bindings.

III-8-1. See Also

III-9. [since QtQuick.Controls 2.3 (Qt 5.10)] Item takeItem(int index)

Removes and returns the item at index.

The ownership of the item is transferred to the caller.

This method was introduced in QtQuick.Controls 2.3 (Qt 5.10).

Vous avez aimé ce tutoriel ? Alors partagez-le en cliquant sur les boutons suivants : Viadeo Twitter Facebook Share on Google+