这是我的容器类定义
class Container
{
private:
std::string stdstrContainerName;
std::string stdstrPluginType;
std::string stdstrPluginName;
int iSegments;
float fRadius;
public:
Container();
explicit Container(std::string strContainerName , std::string
strPluginName , std::string strPluginType, int segments , float
radius );
~Container();
std::string GetName();
std::string GetType();
void SetName(std::string stdstrName);
};
我希望树视图的节点将容器类的对象保存为数据。
这是 TreeItem 类的头文件。
class TreeItem
{
public:
explicit TreeItem( const Container &data , TreeItem *parent = 0 );
~TreeItem();
TreeItem *parent();
TreeItem *child(int iNumber);
int childCount() const;
int childNumber() const;
Container data() const;
bool setData(const Container &data);
bool insertChildren(int position, int count );
bool removeChildren( int position , int count );
private:
QList<TreeItem*> childItems;
Container itemData;
TreeItem* parentItem;
};
我面临的问题是在实现树模型函数时。如何使用容器而不是 QVariant 作为数据类型。
QVariant data(const QModelIndex &undex, int role) const override;
QVariant headerData(int section, Qt::Orientation orientation,
int role = Qt::DisplayRole) const override;
bool setData( const QModelIndex &index , const QVariant &value , int
role = Qt::EditRole) override;
你不能用Container
代替QVariant
,但你可以在QVariant
中使用Container
。看看Q_DECLARE_METATYPE
.
在声明 Container
之后将其添加到头文件中:
class Container
{
private:
// ...
public:
Container();
// ...
};
Q_DECLARE_METATYPE(Container); // You only need this once, so here is a good place
创建 Container
元类型时,可以像这样返回它:
QVariant data(const QModelIndex &index, int role) const override {
TreeItem *item = ...;
return QVariant::fromValue(item->data());
}
在您看来,您可以像这样检索Container
:
QVariant v = model()->data(index, role);
Container c = v.value<Container>();
请注意,这仅适用于同一线程,否则您需要向qRegisterMetaType()
注册Container
,甚至可能编写从/到QVariant
的转换器函数。
但是,这不适用于您的情况,因为模型和视图不是为存在于不同的线程中而设计的。