
您可以使用Qt Creator中的CMake来为台式机和Android设备构建应用程序。您还可以构建单个文件来测试您的更改。
Qt Creator自动检测在中指定的CMake可执行文件PATH。您可以将路径添加到其他CMake可执行文件,并在不同的构建和运行工具包中使用它们。
当您安装CMake时,将以Qt帮助文件格式(.qch)安装CMake文档。它是由Qt Creator自动注册的,您可以在“帮助”模式下查看它。
当您CMakeLists.txt在项目中编辑配置文件时,Qt Creator将自动运行CMake以刷新项目信息。生成项目时,项目信息也会自动刷新。
具体安装方法如下:
1、首先安装Qt creator编译器,双击上图中qt-creator-win-opensource-2.2.1.exe文件,开始一步步安装Qt creator编译器,安装路径为D:\Qt\qtcreator-2.2.1(不要带有空格)
2、再安装Qt库,双击qt-win-opensource-4.7.3-mingw.exe文件,一步步按照向导安装Qt库,下图1中路径是指Qt库的安装路径,安装过程会出现提示,要求定位mingw的位置,对应下图中的路径位置。
3、安装完成后,启动Qt Creator,选择菜单 [工具] -->[选项],然后点击左侧的 [Qt4] 标签页,接着点击右上角的 [添加],接下来点击下方的 [浏览],浏览到qmake所在的路径,此处即: D:\qt\4.7.3\bin\qmake.exe 最后应用该设置,设置完成后最好重新启动一下Qt Creator
编辑委托利用委托中重载createEditor(),激活QCheckBox,这个缺点是必须双击/选中,才能显示CheckBox控件。一般不满足实际中的直接显示的需要。
设置QAbstractTableModel的flags()函数,通过重写setData()与data()来实现。
使用QTableView的setIndexWidget(const QModelIndex &index, QWidget *widget)来实现。
此功能只应该用来显示可视区域内对应一个数据项的静态内容。如果想显示自定义的动态内容或执行自定义编辑器部件,子类化
QItemDelegate代替。也就是说,这只适合做静态数据的显示,不适合做一些插入、更新、删除 *** 作的数据显示。
自定义委托,通过paint()方法来实现。这种方式比较复杂,但适合扩展,除了可以嵌入复选框,还可以通过绘制其它控件,按钮、图片等自定义风格。
下面就介绍最常用的方式,即方法二。
QMap用来保存选中行号以及对应的选中状态
QMap check_state_map
setData()方法主要用来设置是否被选中,然后将对应的状态保存到QMap中
bool TableModel::setData( const QModelIndex &index, const QVariant &value, int role )
{
if(!index.isValid())
return false
if (role == Qt::CheckStateRole &&index.column() == 0)
{
check_state_map[index.row()] = (value == Qt::Checked ? Qt::Checked : Qt::Unchecked)
}
return true
}
data()方法主要用来显示,取出QMap中的值,返回对应的状态
QVariant TableModel::data(const QModelIndex &index, int role) const
{
if (!index.isValid())
return QVariant()
switch(role)
{
//case Qt::TextAlignmentRole:
// return Qt::AlignLeft | Qt::AlignVCenter
//case Qt::DisplayRole:
// return arr_row_list->at(index.row()).at(index.column())
case Qt::CheckStateRole:
if(index.column() == 0)
{
if (check_state_map.contains(index.row()))
return check_state_map[index.row()] == Qt::Checked ? Qt::Checked : Qt::Unchecked
return Qt::Unchecked
}
default:
return QVariant()
}
return QVariant()
}
flag()方法主要设置用户可选角色,绘制出QCheckBox
Qt::ItemFlags TableModel::flags(const QModelIndex &index) const
{
if (!index.isValid())
return 0
if (index.column() == 0)
return Qt::ItemIsEnabled | Qt::ItemIsSelectable | Qt::ItemIsUserCheckable
return Qt::ItemIsEnabled | Qt::ItemIsSelectable
}
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)