• modellex.h

     #ifndef MODELEX_H
    #define MODELEX_H
    #include <QAbstractItemModel>
    #include <QVector>
    #include <QMap>
    #include <QStringList>
    #include <QWidget> class modelex : public QAbstractTableModel
    { public:
    explicit modelex(QObject *parent = ); virtual int rowCount(const QModelIndex &parent=QModelIndex()) const;
    virtual int columnCount(const QModelIndex &parent=QModelIndex()) const;
    QVariant data(const QModelIndex &index, int role) const;
    QVariant headerData(int section, Qt::Orientation orientation, int role) const; private:
    QVector<int> army;
    QVector<int> weapon;
    QMap<int,QString> armymap;
    QMap<int,QString> weaponmap; QStringList weaponlist;
    QStringList armylist;
    QStringList header; void showModel();
    }; #endif // MODELEX_H
  • modelex.cpp
     #include "modelex.h"
    
     modelex::modelex(QObject *parent):QAbstractTableModel(parent)
    {
    armymap[] ="空军";
    armymap[] ="海军";
    armymap[] ="陆军"; weaponmap[] = "AK47";
    weaponmap[] = "M16";
    weaponmap[] = "M18";
    showModel();
    } int modelex::rowCount(const QModelIndex &parent) const
    {
    return army.size();//行数
    } int modelex::columnCount(const QModelIndex &parent) const
    {
    return ;//列数
    } //返回每一行每一列的数据
    QVariant modelex::data(const QModelIndex &index, int role) const
    {
    if(!index.isValid())
    {
    return QVariant();
    }
    if(role == Qt::DisplayRole)
    {
    switch(index.column())
    {
    case :
    return armymap[army[index.row()]];
    break;
    case :
    return armymap[weapon[index.row()]];
    break;
    default:
    return QVariant();
    } }
    return QVariant();
    } QVariant modelex::headerData(int section, Qt::Orientation orientation, int role) const
    {
    if(role == Qt::DisplayRole && Qt::Horizontal == orientation)
    {
    //返回表的开头
    return header[section];
    }
    else
    {
    return QAbstractTableModel::headerData(section,orientation,role);
    }
    } void modelex::showModel()
    {
    header<<"兵种" <<"兵器";
    //数字与字符串对应
    army<<<<<<<<<<;
    weapon<<<<<<<<<<;
    }
  • main.cpp
     #include "widget.h"
    #include <QApplication>
    #include <QTableView>
    #include "modelex.h" int main(int argc, char *argv[])
    {
    QApplication a(argc, argv);
    //Widget w;
    //w.show();
    modelex m;
    QTableView view;
    view.setModel(&m);
    view.show();
    view.resize(,); return a.exec();
    }

运行效果

34.QT模型(表格绘制)的更多相关文章

  1. Qt实现表格树控件-支持多级表头

    目录 一.概述 二.效果展示 三.实现方式 四.多级表头 1.数据源 2.表格 3.QStyledItemDelegate绘制代理 五.测试代码 六.相关文章 原文链接:Qt实现表格树控件-支持多级表 ...

  2. qt模型学习

    # -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' from PyQt4.Qt import * from PyQt4. ...

  3. Qt之表格控件蚂蚁线

    一.蚂蚁线 摘自互动百科:在图像影像软件中表示选区的动态虚线,因为虚线闪烁的样子像是一群蚂蚁在跑,所以俗称蚂蚁线.在Poshop,After Effect等软件中比较常见. 背景:用过excel的同学 ...

  4. Qt实现表格控件-支持多级列表头、多级行表头、单元格合并、字体设置等

    目录 一.概述 二.效果展示 三.定制表头 1.重写数据源 2.重写QHeaderView 四.设置属性 五.相关文章 原文链接:Qt实现表格控件-支持多级列表头.多级行表头.单元格合并.字体设置等 ...

  5. Qt实现表格树控件-自绘树节点虚线

    目录 一.开心一刻 二.自绘树节点? 三.效果展示 四.实现思路 1.可扩展接口 2.函数重写 3.同步左侧表头 五.相关文章 原文链接:Qt实现表格树控件-自绘树节点虚线 一.开心一刻 一程序员第一 ...

  6. Qt之自绘制饼图

    1.说明 最近在搞绘图方面的工作,说实话C++的第三方绘图库并不算多,总之我了解的有:qtcharts.ChartDirector.qwt.kdchart和QCustomPlot.这几个库各有利弊. ...

  7. 重构一段基于原生JavaScript的表格绘制代码

    为了在CardSimulate项目中方便的显示技能和效果列表,决定重构以前编写的一段JavaScript代码——att表格绘制库,这段代码的作用是将特定的JavaScript数据对象转化为表格,支持精 ...

  8. QT 基本图形绘制

    QT 基本图形绘制 1.告诉绘制引擎一些东西 QPainter::Antialiasing 在可能的情况下,反锯齿       QPainter::TextAntialiasing 在可能的情况下,文 ...

  9. [Qt5] 使用Qt设计器绘制主窗口

    实践代码: git clone https://github.com/dilexliu/learn_qt5.git Step1: Qt设计器绘制窗口 保存会得到一个文件: mainwindow.ui ...

随机推荐

  1. Gitlab 维护措施

    Gitlab 升级: https://jingyan.baidu.com/article/72ee561ab1b333e16038df63.html Gitlab Rpm包地址: https://pa ...

  2. SQLServer Union 和 Union All 在Insert 语句中的不同效果

    如果不是发了那个帖子还不会像这样意外发现这两者的不同,好歹了也工作了一段时间,真是汗颜 上例子: 执行此条插入语句后,只会插入两条数据,因为会把完全重复的数据过滤掉 insert into tests ...

  3. Android网络编程随想录(3)

    大多数Android的app都会使用HTTP协议来发送和接收数据.在Android开发中,通常使用两种http客户端:一个是Apache的HttpClient,另一个是HttpURLConnectio ...

  4. JavaScript实现数字时钟功能

    <html> <head> <meta charset="utf-8"> <title>无标题文档</title> &l ...

  5. 《SLIC Superpixels》阅读笔记

    原始链接:http://blog.csdn.net/jkhere/article/details/16819285 或许有改动,请参考原文! SLIC 超像素(SLICSuperpixels) Rad ...

  6. (转)RabbitMQ学习之路由(java)

    http://blog.csdn.net/zhu_tianwei/article/details/40887755 参考:http://blog.csdn.NET/lmj623565791/artic ...

  7. win系统如何在桌面显示我的电脑

    如果是在Windows Server 2012本地控制台下,直接按Win(键盘上的微软徽标键)+R,输入: rundll32.exe shell32.dll,Control_RunDLL desk.c ...

  8. Ubuntu终端命令行缩短显示路径

    平时我们使用linux终端命令行的时候,常常会被一个问题困扰,那就是文件路径过长, 有时候甚至超过了一行,这样看起来非常别扭,其实只要两步就可以解决这个问题: 1,修改.bashrc文件(用户根目录下 ...

  9. 洛谷P1654 OSU!_概率与期望

    Code: #include<cstdio> #include<algorithm> using namespace std; const int maxn = 1000000 ...

  10. 推荐一款能支持国密SM2浏览器——密信浏览器

    密信浏览器( MeSince Browser )是基于Chromium开源项目开发的国密安全浏览器,支持国密算法和国密SSL证书,同时也支持国际算法及全球信任SSL证书:密信浏览器使用界面清新,干净. ...