QT4笔记

作者: 你猜_19ca | 来源:发表于2018-08-07 15:08 被阅读0次

    QT中文乱码

    QTextCodec::setCodecForCStrings(QTextCodec::codecForName("GB2312"));

    通过signal/slot来传递自定义类型的值

    •自定一种类型,在这个类型的顶部包含:#include <QMetaType>
    •在类型定义完成后,加入声明:Q_DECLARE_METATYPE(TextAndNumber);
    •在main()函数中注册这种类型:qRegisterMetaType<TextAndNumber>("TextAndNumber");
    •如果还希望使用这种类型的引用,可同样要注册:qRegisterMetaType<TextAndNumber>("TextAndNumber&");

    QString 转换为 char*

    QByteArray ba = src.toLatin1();
    const char s = ba.data();
    或者
    char
    ch;
    std::string str = m_ip.toStdString();
    ch = (char )malloc((str.length()+1)sizeof(char));
    memset(ch,0,str.length()+1);
    str.copy(ch,str.length(),0);
    或者
    ch = (char )malloc((str.length()+1)sizeof(char));
    str.copy(ch,str.length(),0);
    ch[str.length()] = '\0';

    不调用connect自动连接槽

    如果槽的命名是这样的话:void on_<widget name><signal name>(<signal parameters>);
    就会自动将widget name中的信号signal name和这个槽void on
    <widget name>_<signal name>(<signal parameters>)链接起来。
    这是QT不需要connect语句就可以自动链接信号和槽的机制!

    QThread线程

    在次线程中使用QT的类需要注意:

    1. QObject的子对象必须在它的父对象线程中创建。
    2. 在删除对应的QThread对象之前,必须删除所有在次线程中创建的QObject对象
    3. 必须在创建QObject对象的线程中删除它们

    QTimer问题

    QTimer使用信号/槽的时候必须在创建QTimer的那个线程中的线程执行exec()方法。但是执行exec()后线程进入事件循环,只有执行了exit()或quit()后才退出。
    所以个人认为:QTimer只能在GUI的主线程中创建,因为主线程会执行exec()后进入事件循环。
    若QTimer在子线程中创建,子线程不执行exec(),QTimer永远不会发送timeout()信号。

    qDebug

    %a,%A 读入一个浮点值(仅C99有效)    
    %c 读入一个字符    
    %d 读入十进制整数    
    %i 读入十进制,八进制,十六进制整数    
    %o 读入八进制整数    
    %x,%X 读入十六进制整数   
    %s 读入一个字符串,遇空格、制表符或换行符结束。    
    %f,%F,%e,%E,%g,%G 用来输入实数,可以用小数形式或指数形式输入。    
    %p 读入一个指针    
    %u 读入一个无符号十进制整数   
    %n 至此已读入值的等价字符数    
    %[] 扫描字符集合    
    %% 读%符号
    

    qss用法

    背景图片九宫格
    border-width: 5px; 
    border-image: url(./run/images/news/group_normal.png) 5 5 5 5 stretch stretch;
    border-width必须要加上,用border-image来自动根据大小扩展,而不用background-image
    
    字体颜色
    color: white;
    

    按钮3种状态:正常,鼠标置上,按下
    QPushButton
    QPushButton:hover
    QPushButton:checked
    对于checked,要把QPushButton设置为可checkable。(setCheckable(true))
    参考:http://www.cppblog.com/seahouse/archive/2011/03/29/142730.html

    设置QPushButton鼠标指向时变成手形

    pushButton->setCursor(QCursor(Qt::PointingHandCursor))

    Qt窗口操作函数(最大化,全屏,隐藏最大化,最小化)

    //Qt主窗口没有最小化,最大化按钮且最大化显示 
    int main(int argc, char *argv[]) 
    { 
        QApplication a(argc, argv); 
        TestQtForWinCE w; 
        w.setWindowFlags(w.windowFlags()& ~Qt::WindowMaximizeButtonHint& ~Qt::WindowMinimizeButtonHint); 
        w.showMaximized(); 
        return a.exec(); 
    }
    这里的“&~”是取反以后再按位与的意思,下面的“|”是按位或的意思
    //同时禁止最大化最小化按钮
    Qt::WindowMinMaxButtonsHint
    //也禁止关闭
    w.setWindowFlags(w.windowFlags() &~ (Qt::WindowMinMaxButtonsHint | Qt::WindowCloseButtonHint));
    Qt全屏显示函数        
    1、window.showFullScreen()//此方法只对顶级窗口有效,对子窗口无效
    2、yourwidget->setWindowFlags(Qt::window | Qt::FramelessWindowHint); 
     (第一个Qt::window表示此widget是窗口类型,第二个参数使用无框架就是没有标题,状态栏和边框)
    Qt最大化显示函数         window.showMaximized()
    Qt最小化显示函数         window.showMinimized()
    Qt固定尺寸显示函数         window.resize(x,y)
    子窗口全屏显示:
    QT中窗口部件QWidget成员函数showFullScreen();是用于将窗口部件全屏显示,但是他只对窗口模式的部件有用。子窗口的特征是 Qt::SubWindow,不是独立的窗口。因此对其调用showFullScreen()无效。通过对对子窗口调 用:setWindowFlags(Qt::Dialog);或setWindowFlags(Qt::Window);将其设为窗口模式后,即可调用 showFullScreen();进行全屏显示了。
    如果要还原为普通窗口,调用setWindowFlags(Qt::subwindow)将子窗口设置为非顶级窗口,再调用showNormal()还原子窗口显示。
    参考:
    相对于子窗口的全屏显示方法,不得不提的是子窗口退出全屏的方法。
    MFC中,子窗口退出全屏的方法简单直接,直接调用SetWindowPos()函数将子窗口显示到预定的位置即可。
    QT中,直接使用move和resize对窗口定位是没有效果的。需要先将子窗口设位非窗口模式。之后再将窗口移到理想位置。 
    即先调用setWindowFlags(Qt::Dialog);或者setWindowFlags(Qt::SubWindow);在调用move和resize函数。
    有人提到退出全屏时,调用showNormal(),再调setWindowFlags(Qt::SubWindow)。
    这有两个问题:1)showNormal()也是只对顶级窗口有效。2)可以考虑先调用showNormal()将窗口设为原来大小,在将窗口设为子窗口模式。但这样窗口回到父窗口之中也不会显示原来的大小。
    获取屏幕宽度和高度
    QApplication::desktop()->width()  ;
    QApplication::desktop()->height() ;
    即得到屏幕分辨率,如1024*768,800*600
    

    QSS样式

    Qt的CSS帮助文档
    打开Qt Assistant工具,在索引页面查找关键字:
    1、“Qt Style Sheets Reference”查看Qt样式表的用法
    2、“Qt Style Sheets Examples” 查看Qt样式表的实例
    3、“The Style Sheet Syntax” 查看Qt样式表语法

    QT utf8乱码

    xml是utf8格式,读取的中文调用如下方法:
    QString::fromUtf8(pTagChildElement->GetText()));

    QT 子线程不能调用主窗口线程的控件

    子线程不能调用主窗口线程的控件,否则会出现莫名其妙的错误,
    解决办法,通过信号/槽机制解决

    QObject::connect: Cannot queue arguments of type 'MediaDbAttirbute'(Make sure 'MediaDbAttirbute' is registered using qRegisterMetaType().)

    信号/槽的参数需要注册为QT的元类型,解决方法:
    qRegisterMetaType<MediaDbAttirbute>("MediaDbAttirbute");

    QT QListWidget删除item问题

    只调用removeItemWidget,不销毁指针指向的内存,会无效果。

    QListWidgetItem* pItem = ui.msgListWidget->item(100);
    ui.msgListWidget->removeItemWidget(pItem);
    delete pItem;
    pItem = NULL;
    

    QT QMap问题

    当使用QMap::iterator时,同一个iter如果map改变后,需要重新获取该map的iterator;
    原来的Iter还记录的未更新前的数组映射表,如果这时候引用老的iter,map的count变短后,可能导致队列溢出

    QProcess不能实时标准输出

    在被调用的进程里的main函数中添加如下代码:
    setvbuf(stdout, (char *)NULL, _IONBF, 0);

    QMutex与QMutexLocker互斥锁问题

    区别:

    1. QMutex需要手动lock和unlock, 如果函数有多个出口,可能会死锁
    2. QMutexLocker不需要unlock,在代码块结束时候自动释放
    3. QMutex对象被锁住以后,其他调用该锁的代码块均不能访问,直到锁被解开

    QT信号和槽

    1. 需要在线程队列存在的情况下才能执行,需要使线程进入监听状态,执行exec()函数
    2. 线程间通信,线程需要调用moveToThread(this);

    相关文章

      网友评论

          本文标题:QT4笔记

          本文链接:https://www.haomeiwen.com/subject/sdqavftx.html