- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试在 QML 和 C++ 中实现 ComboBox,我可以在其中动态更改 ComboBox 的内容。我提供了一个 QStringList 作为 ComboBox-Model,并希望使用两个按钮从 ComboBox 中插入/删除一个条目。
我可以在我的 ComboBox 中显示 QStringList,但是当我单击添加按钮时,我的 QStringList 在我的类中得到更新,但不知何故 View 不会更新 ComboBox 条目。我应该怎么做才能告诉 View 我的组合框模型已更新?
这是我的代码:
组合框模型.h
#ifndef COMBOBOXMODEL_H
#define COMBOBOXMODEL_H
#include <QObject>
#include <QStringList>
class ComboBoxModel : public QObject
{
Q_OBJECT
Q_PROPERTY(QStringList comboList READ comboList WRITE setComboList NOTIFY comboListChanged)
Q_PROPERTY(int count READ count WRITE setCount NOTIFY countChanged)
public:
ComboBoxModel(QObject *parent = 0);
ComboBoxModel(const QStringList &list,int count, QObject *parent = 0);
const QStringList comboList();
void setComboList(const QStringList &comboList);
int count();
void setCount(int cnt);
Q_INVOKABLE void addElement(const QString &element);
Q_INVOKABLE void removeElement(int index);
signals:
void comboListChanged();
void countChanged();
public slots:
private:
QStringList m_comboList;
int m_count;
};
#endif // COMBOBOXMODEL_H
组合框模型.cpp
#include "comboboxmodel.h"
#include "qdebug.h"
ComboBoxModel::ComboBoxModel(QObject *parent) :
QObject(parent)
{
}
ComboBoxModel::ComboBoxModel(const QStringList &list, int count, QObject *parent) :
QObject(parent), m_comboList(list), m_count(count)
{
}
const QStringList ComboBoxModel::comboList()
{
return m_comboList;
}
void ComboBoxModel::setComboList(const QStringList &comboList)
{
if (m_comboList != comboList)
{
m_comboList = comboList;
emit comboListChanged();
}
}
int ComboBoxModel::count()
{
return m_count;
}
void ComboBoxModel::setCount(int cnt)
{
if (cnt != m_count)
{
m_count = cnt;
emit countChanged();
}
}
void ComboBoxModel::addElement(const QString &element)
{
m_comboList.append(element);
emit comboListChanged();
setCount(m_comboList.count());
emit countChanged();
for (int i = 0; i<m_count; i++)
{
qDebug() << m_comboList.at(i);
}
}
void ComboBoxModel::removeElement(int index)
{
if (index < m_comboList.count())
{
m_comboList.removeAt(index);
emit comboListChanged();
setCount(m_comboList.count());
emit countChanged();
}
for (int i = 0; i<m_count; i++)
{
qDebug() << m_comboList.at(i);
}
}
main.cpp
#include <QApplication>
#include <QQmlApplicationEngine>
#include <qqmlengine.h>
#include <qqmlcontext.h>
#include <qqml.h>
#include <QStringList>
#include "comboboxmodel.h"
int main(int argc, char *argv[]) {
QApplication app(argc, argv);
QQmlApplicationEngine engine;
ComboBoxModel combo;
QStringList tmp;
tmp << "1" << "2" << "3" << "4" << "5" << "6" << "7";
combo.setComboList(tmp);
QQmlContext *ownContext = engine.rootContext();
ownContext->setContextProperty("myModel", QVariant::fromValue(combo.comboList()));
QQmlContext *classContext = engine.rootContext();
classContext->setContextProperty("comboModel", &combo);
engine.load(QUrl(QStringLiteral("qrc:/main.qml")));
return app.exec(); }
main.qml
import QtQuick 2.3 import QtQuick.Controls 1.2
ApplicationWindow {
visible: true
width: 640
height: 480
title: qsTr("Hello World")
menuBar: MenuBar {
Menu {
title: qsTr("File")
MenuItem {
text: qsTr("&Open")
onTriggered: console.log("Open action triggered");
}
MenuItem {
text: qsTr("Exit")
onTriggered: Qt.quit();
}
}
}
Text {
text: qsTr("Hello World")
anchors.centerIn: parent
}
ComboBox {
id: comboBox1
x: 258
y: 54
model: myModel
editable: true
onAccepted: {
if (editableCombo.find(currentText) === -1) {
model.append({text: editText})
currentIndex = editableCombo.find(editText)
}
}
}
Button {
id: button1
x: 280
y: 139
text: qsTr("Remove Item")
onClicked: comboModel.removeElement(comboBox1.currentIndex)
}
Rectangle{
x: 281
y: 316
width: 80
height: 20
color: "white"
TextEdit {
id: textEdit1
width: 80
height: 20
text: qsTr("Text Edit")
font.pixelSize: 12
}
}
Button {
id: button2
x: 280
y: 388
text: qsTr("Add Item")
onClicked: comboModel.addElement(textEdit1.text)
} }
最佳答案
所以我终于想出了如何做这类事情。
在 main.qml 中它应该是:
model: comboModel.comboList
代替:
model: myModel
现在我可以从我的列表中添加/删除项目,并且它们会正确显示。
感谢您的提示 BaCaRoZzo。
有人可以将这个主题更改为“已解决”吗?
关于c++ - QML 动态组合框条目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26887373/
如果下一个元素的宽度超过指定布局的宽度,是否有 QML 布局或某些配置会自动将 QML 项目包装到下一行? 当我使用 QML GridLayout ,项目刚好离开窗口的边缘并被剪裁: GridLayo
如果下一个元素的宽度超过指定布局的宽度,是否有 QML 布局或某些配置会自动将 QML 项目包装到下一行? 当我使用 QML GridLayout ,项目刚好离开窗口的边缘并被剪裁: GridLayo
如何在 qml 文件之间发送变量或信号? http://i.stack.imgur.com/MChCG.png Mainwindow -> 创建组件Item2.qml MainWindow -> 创建
我正在做一些事情,我有一个名为“FloatingMenu”的类(它应该在 C++ 中管理菜单)及其在文件 FloatingMenu.qml 中用于 GUI 的 QML alter-ego。我有一个文件
我正在尝试做一些看似简单的事情,但失败了:定义一个简单的内联文本格式组件,然后用不同的文本多次实例化它。这是代码 Item { . . . Component { id: favButtonL
我可以在页面中使用 InvokeActionItem 轻松共享项目,但我需要能够在 ListView 项目中调用它。我设法触发了一个调用,但我不知道如何在触发它时添加数据。我不断收到错误消息 Invo
我如何在 QML 中检测 Window {} 之外的点击? Rectangle { id: topLevel height: 400; width: 400 Window {
我试过 : var child = grid.children[slot1]; grid.children[slot1] = grid.children[slot2]; grid.children[s
例如,我希望创建一个包含 100 个文本编辑器的 qml 窗口,如何在循环中创建它?那可能吗? 最佳答案 循环是命令式代码,所以它不是 QML,而是 Javascript 或 C++。所以当然,你可以
这是我的 QML 文件,其中包含一个文本组件: import QtQuick 2.0 Item { id: idItmWrapText Text { id: idTxt
我正在寻找一种方法来显示一个文本提示,说明预期的输入作为对用户的建议。以谷歌搜索栏为例: 是否有我缺少的属性,或者这是必须通过脚本来实现的? 最佳答案 Qt Quick 输入项上不存在该属性。您可以为
为 qml 项设置背景的最简单方法是让子矩形的 anchor 完全填满父项: Item { width: 320 height: 240 Rectangle {
我想将属性动态添加到 QML 元素: Item { id: dynamicProperty; property int first; Component.onCompleted: { /*
我用 PySide 和 QML 编写了某种安装程序。按照设计,它必须是多页的。而且我想将要从 QML 表单调用的插槽划分为不同的对象(理想情况下,划分为模块,但据我了解,带有插槽的对象必须继承 QOb
QML 中有没有办法用 opacity: 0 创建一个矩形?仍然有可见的边界?如果没有,有关如何解决它的任何建议? 谢谢 最佳答案 不,不透明度适用于项目的完整视觉方面(并且不透明度:0 使项目完全不
属性变体 a:{}似乎不起作用。 a 最终未定义,而不是一个空字典。 我对 Javascript 不是很有经验...初始化属性以保存空字典的正确方法是什么? 以下 qml 在控制台上打印“qrc:/m
我在 SO 上查看了大量关于 QML 内容边距的问题,但所有答案都指向缺少 spacing: 0 属性。我已经完成了所有这些,但仍然有一些我无法消除的奇怪空间。任何人都可以解释为什么这个 QML 代码
我有一个用于样式定义的 QML 单例,定义如下: pragma Singleton import QtQuick 2.2 import QtQuick.Controls 1.1 import QtQu
这是以下代码的结果: 主.qml import QtQuick 2.8 Item { Reusable { index: 1234 // reusable with
属性变体 a:{}似乎不起作用。 a 最终未定义,而不是一个空字典。 我对 Javascript 不是很有经验...初始化属性以保存空字典的正确方法是什么? 以下 qml 在控制台上打印“qrc:/m
我是一名优秀的程序员,十分优秀!