QML GridView скрыть одну ячейку - PullRequest
0 голосов
/ 27 апреля 2018

Можно ли скрыть определенную ячейку в GridView? Я установил делегат, но у меня все еще есть свободное место для этого элемента GridView. Это возможно сделать?

visible: false
width: 0
height: 0

Ответы [ 2 ]

0 голосов
/ 27 апреля 2018

Еще одно упрощенное решение только с QML, основанное на скрытии элементов.

import QtQuick 2.7
import QtQuick.Window 2.2
import QtQuick.Layouts 1.2

Window {
    id: window
    title: "test"
    visible: true
    width: 400
    height: 400
    GridLayout {
        id: layout
        anchors.fill: parent
        columns: 4
        Repeater {
            id: container
            model: 20
            Rectangle {
                id: item
                property int itemIndex: index
                Layout.fillWidth: true
                height: 60
                color: Qt.rgba(Math.random(),Math.random(),Math.random(),1)
                Text {
                    anchors.centerIn: parent
                    text:item.itemIndex
                }

                MouseArea {
                    anchors.fill: parent
                    onClicked: {
                        item.visible = false;
                        layout.doIt(item.itemIndex);
                    }
                }
            }
        }
        function doIt(index)
        {
            var item = container.itemAt(index);
            if(item)
                item.visible = false;
            for(var i = index - 1;i >= 0;i --)
            {
                var prev_item = container.itemAt(i);
                if(prev_item.visible) {
                    prev_item.Layout.columnSpan ++;
                    break;
                }
            }
        }
    }
}
0 голосов
/ 27 апреля 2018

Как было сказано в комментарии, вы действительно можете использовать модель QSortFilterProxy, но здесь есть другое решение. Вы можете реализовать чисто QML FilterProxyModel, используя DelegateModel и DelegateModelGroup

import QtQuick 2.10
import QtQml.Models 2.3

DelegateModel {

    property var filterAccepts: function(item) {
        return true
    }

    onFilterAcceptsChanged: refilter()

    function refilter() {
        if(hidden.count>0)
            hidden.setGroups(0, hidden.count, "default")
        if(items.count>0)
            items.setGroups(0, items.count, "default")
    }

    function filter() {
        while (unsortedItems.count > 0) {
            var item = unsortedItems.get(0)
            if(filterAccepts(item.model))
                item.groups = "items"
            else
                item.groups = "hidden"
        }
    }

    items.includeByDefault: false
    groups: [
        DelegateModelGroup {
            id: default
            name: "default"
            includeByDefault: true
            onChanged: filter()
        },
        DelegateModelGroup {
            id: hidden
            name: "hidden"
        }
    ]

}

Объяснение : Каждый раз, когда элемент добавляется в модель, он добавляется в группу «по умолчанию», которая вызывает обработчик onChanged, который будет вызывать filter().

Filter () будет искать элементы в группе по умолчанию и перемещать их либо в группу items (которая сделает их видимыми), либо в группу hidden, в зависимости от результата функции filterAccepts.

Когда изменяется filterAccept, SortProxyModel будет перемещать каждый элемент в группу по умолчанию для запуска глобальной повторной фильтрации.

Затем вы можете использовать свою прокси-модель следующим образом:

FilterProxyModel
{
    id: filterProxyModel

    model: <YourBaseModel>
    delegate: <YourDelegate>

    filterAccepts: function(item) {
          // Eg: Only "small" items will be displayed
          return item.size == "small"
    }
}

GridView
{
    anchors.fill: parent
    model: filterProxyModel
    cellHeight: 100
    cellWidth: 100
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...