Qt Quick Controls



  • 参考视频:Introduction to Qt – Intro to Qt Quick Controls {tutorial}

    主要功能

    • 做一个经典的编辑器界面
    • 一个文件菜单,包含新建、打开、保存
    • 一个工具栏,包含新建、打开、保存

    源码

    main.qml

    import QtQuick 2.11
    import QtQuick.Window 2.11
    import QtQuick.Controls 2.3
    import QtQuick.Layouts 1.3
    ApplicationWindow {
        visible: true
        width: 640
        height: 480
        title: qsTr("Qt Quick Controls")
    
        Action{
            id:actionNew
            text: qsTr("&New")
            shortcut: StandardKey.New
            icon.source: "qrc:/baseline_fiber_new_black_18dp.png"
            onTriggered: {
                area.placeholderText = "To do - New"
            }
        }
        Action{
            id:actionOpen
            text: qsTr("&Open")
            shortcut: StandardKey.Open
            icon.source: "qrc:/baseline_folder_open_black_18dp.png"
            onTriggered: {
                area.placeholderText = "To do - Open"
            }
        }
        Action{
            id:actionSave
            text: qsTr("&Save")
            shortcut: StandardKey.Save
            icon.source: "qrc:/baseline_save_black_18dp.png"
            onTriggered: {
                area.placeholderText = "To do - Save"
            }
        }
        menuBar: MenuBar{
            Menu{
                title: "File"
                MenuItem{action: actionNew}
                MenuItem{action: actionOpen}
                MenuItem{action: actionSave}
            }
        }
        header: ToolBar{
            RowLayout{
                ToolButton{action: actionNew}
                ToolButton{action: actionOpen}
                ToolButton{action: actionSave}
            }
        }
        TextArea{
            id: area
            anchors.fill: parent
        }
    }
    
    

    截图

    最后的运行效果

    image

    自己做的时候留下的部分截图

    image

    思考与总结

    这是一个完全没有办法拖控件的Demo,所有的东西都是手敲的。不光如此,视频中的Action图标根本出不来,我最后是从 https://material.io/tools/icons/ 上下载了几个图标挂上去的。

    视频的后面展示了其他的几个控件,其实就是把几个新建的空工程跑了一遍。

    GitHub: https://github.com/PikachuHy/qml-demo/tree/master/qt-quick-controls


 

走马观花

最近的回复

  • @chinasmu Webkit网络的部分可能不是受到Qt控制的,扩展性较差,所以呢,还不能通过代码的方式侦听网络收发数据。但是WebEngine就可以。如果可以的话,试试Qt WebEngine。😺

    阅读更多
  • C

    我用qt建了个对话框程序,里面加了个webkit,请问有办法获取该控件的全部网络封包通信数据吗?
    不采用windows hook recv和send函数的形式,或者有没有第三方的控件可以这样做

    阅读更多
  • 这个错误不是编译器的错误,而是IntelliSense的错误。
    这种情况,可以不用太担心。

    如果你使用MSVC编译应用程序,那么最好安装Qt Visual Studio Addon,使用这个插件同步开发Qt应用程序。
    不过一个小小的建议,就是Qt Creator写Qt程序非常直观,不需要在Visual Studio中那么麻烦,而且Qt Creator是强制安装的,基本上你安装了Qt 5.12,就可以在安装的目录中找到它。QAxContainer是Qt的模块activeQt中的,需要在pro文件中写QT += axcontainer,才会找到这个类。

    阅读更多
  • C

    VS2017 Qt5.12
    新建一个空的QWidget对话框,编译执行
    可以成功生成并执行,但是错误列表里显示

    傲游截图20190217212931.png

    exe文件能够成功生成。

    另外的问题:我在vs2017编译环境中使用qt,需要用到 QAxContainer,我看帮助文档里说要在.pro中加入CONFIG+=qaxcontainer,但是vs2017创建的程序中没有.pro这个文件,那这句话应该加在哪里呢?

    还有我想建一个有浏览器控件的对话框程序,如果想在5.12版本中加入QtWebKit应该如何使用

    阅读更多

关注我们

微博
QQ群











召唤伊斯特瓦尔