• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            eryar

            PipeCAD - Plant Piping Design Software.
            RvmTranslator - Translate AVEVA RVM to OBJ, glTF, etc.
            posts - 603, comments - 590, trackbacks - 0, articles - 0

            Qt Python Scriptable Application

            Posted on 2020-02-24 14:56 eryar 閱讀(4536) 評論(0)  編輯 收藏 引用 所屬分類: 2.OpenCASCADE6.Others

             

            Qt Python Scriptable Application

            eryar@163.com

             

            Abstract. Python and C++ are in many ways as different as two languages could be: while C++ is usually compiled to machine-code, Python is interpreted. Python's dynamic type system is often cited as the foundation of its flexibility, while in C++ static typing is the cornerstone of its efficiency. C++ has an intricate and difficult compile-time meta-language, while in Python, practically everything happens at runtime.

             

            Key Words. Qt, Python, Shiboken2, PySide2

            1 Introduction

            Python和C++是兩種不同的開發(fā)語言:C++通常編譯成機器碼,而Python是解釋型的。Python的動態(tài)類型系統(tǒng)是它靈活性的基礎,而C++的靜態(tài)類型運行效率高。對于許多程序員來說,讓Python和C++互為補充來進行程序開發(fā)是很完美的。Python程序的性能瓶頸可以用C++來重寫;C++程序選擇Python作為中間腳本語言,可以為程序提供方便地集成和擴展能力,即支持程序二次開發(fā),方便為程序定制功能。

            2 Shiboken2

            Shiboken2是一個為C/C++庫生成CPython綁定代碼的生成器,用來創(chuàng)建PySide的模塊,換句話說,Shiboken可以用來暴露Qt C++API給Python。

            Shiboken使用ApiExtractor庫來分析所有的Qt頭文件。由于使用的clang,不依賴Qt,所以Shiboken也可用于將非Qt的C++項目。并且Shiboken有一個類型系統(tǒng)Typesytem,基于XML文件。

             

             

            編譯PySide的前提條件就是先要編譯出Shiboken。當成功編譯PySide后,就會生成Shiboken等類庫。既然使用Shiboken可以將Qt的C++對象暴露給Python,那么如何將C++和Python結(jié)合起來,生成一個支持Python腳本的程序呢?

            在PySide2的例子文件夾中提供了兩個例子:

            l  SampleBinding:暴露非Qt的C++對象給Python;

            l  ScriptableApplication:支持腳本的程序示例;

            如何編譯這兩個例子,在其中的ReadMe.md中都有詳細說明,主要是配置好PySide2,Shiboken2等環(huán)境。其中ScriptableApplication中提供了CMake和QMake兩種編譯方式,將他們生成VS的工程可以看出,在VS項目中增加了XML文件,并將其設置成Custom Build Tool:

             

            并為其配置Shiboken的一些命令選項:

             

            3 ScriptableApplication Example

            編譯成功程序運行截圖如下所示:

             

            程序支持了Python腳本,當然也可以使用PySide來開發(fā)GUI,如下所示:

             

            4 Conclusion

            為C++程序提供Python腳本支持有很多開源庫可以實現(xiàn),如boost.python, pycxx等,而Qt 的PySide2使用Shiboken2來將Qt的C++類型暴露給Python,所以也可以直接使用Shiboken2來將C++類封裝成Python類。

            5 References

            1. Building Hybrid Systems With Boost Python, by Dave Abrahams and Ralf W. Grosse-Kunstleve
            2. https://wiki.qt.io/Qt_for_Python/Shiboken
            3. https://doc.qt.io/qtforpython/shiboken2/contents.html
            4. https://www.qt.io/blog/2018/05/31/write-python-bindings
            5. https://code.qt.io/cgit/pyside/pyside-setup.git/tree/examples/scriptableapplication

             


            為了方便大家在移動端也能看到我的博文和討論交流,現(xiàn)已注冊微信公眾號,歡迎大家掃描下方二維碼關(guān)注。
            Shing Liu(eryar@163.com)
            中文字幕久久精品无码| 精品国产热久久久福利| 99久久国产综合精品女同图片 | 7777久久久国产精品消防器材| 狠狠色丁香久久婷婷综合_中| 久久亚洲AV无码精品色午夜麻豆| 久久久老熟女一区二区三区| 国产激情久久久久影院老熟女免费 | 欧洲精品久久久av无码电影| 久久成人精品视频| 亚洲熟妇无码另类久久久| 国产精品无码久久久久| 色婷婷综合久久久中文字幕| 久久免费视频一区| 久久综合中文字幕| 久久九九精品99国产精品| 久久久久婷婷| 国产精品嫩草影院久久| 99久久精品毛片免费播放| 麻豆精品久久久久久久99蜜桃| 久久国产精品国语对白| 99久久99久久| 91精品国产色综合久久| 精品熟女少妇a∨免费久久| 久久久久精品国产亚洲AV无码| 日韩欧美亚洲综合久久影院Ds| 久久成人永久免费播放| 久久99久久99小草精品免视看| 久久久久人妻精品一区二区三区| 久久青青草视频| 亚洲综合久久夜AV | 亚洲精品99久久久久中文字幕| 国产精品伊人久久伊人电影| 久久精品成人免费网站| 女人香蕉久久**毛片精品| 2022年国产精品久久久久| 久久精品国产91久久综合麻豆自制 | 囯产极品美女高潮无套久久久 | 亚洲国产精品一区二区久久hs| 亚洲欧洲久久av| 77777亚洲午夜久久多人|