设为首页 收藏本站
查看: 1262|回复: 0

[经验分享] ubuntu下使用golang、qml与ubuntu sdk开发桌面应用 (简单示例)

[复制链接]

尚未签到

发表于 2018-9-20 09:31:46 | 显示全部楼层 |阅读模式
ubuntu下使用golang、qml与ubuntu sdk开发桌面应用 (简单示例)
找了很长时间go的gui库,试了gtk,准备试qt的时候发现了这个qml库,试了下很好用。##准备工作**1、Go 1.2RC1**go的版本应该不能低于这个,我是在1.2RC发布当天升级后发现的qml,并测试的。**2、qml**项目主页 https://github.com/niemeyer/qml 目前还是alpha版。项目主页里面有各个平台的安装方法 装好后会顺带把qtcreator的ubuntu sdk plugin也给装上。然后运行qml的示例程序 github.com/niemeyer/qml/examples/particle![qml](http://images.cnblogs.com/cnblogs_com/hangxin1940/508415/o_qml1.png "qml")##Go qml这里尝试写一个简单的登录窗口![qml](http://images.cnblogs.com/cnblogs_com/hangxin1940/508415/o_qml2.png "qml")**1、编写qml**打开ubuntu sdk creator,设置下编译环境![qml](http://images.cnblogs.com/cnblogs_com/hangxin1940/508415/o_qml3.png "qml")在 tools -> options 中 build & run 条目中找到 qt versions,然后添加qmake的路径32-bit: /usr/lib/i686-linux-gnu/qt5/bin/qmake64-bit: /usr/lib/x86_64-linux-gnu/qt5/bin/qmake然后创建一个qml项目,这里可以尝试创建一些示例项目,这里我选择了 qt quick2 ui。他会创建3个文件,一个工程文件,一个源码文件,还有一个与当前用户有关的xml。首先修改工程文件,加入ubuntu sdk的import路径。修改`qmlproject`后缀名的文件,在最后面`List of plugin directories passed to QML runtime`注释下面加入几行:/* List of plugin directories passed to QML runtime */importPaths: [ "." ,"/usr/bin","/usr/lib/x86_64-linux-gnu/qt5/qml" ]然后编辑`qml`后缀的UI文件:// 这里用到了quick2和ubuntu sdk的模块import QtQuick 2.0import Ubuntu.Components 0.1import Ubuntu.Layouts 0.1MainView {id: rootobjectName: "mainView"applicationName: "LoginWindow"width: units.gu(50)height: units.gu(30)Page {title: "Login Window"objectName: "mainPage"Column {anchors.leftMargin: units.gu(2)anchors.rightMargin: units.gu(2)anchors.topMargin: units.gu(2)anchors.bottomMargin: units.gu(2)anchors.fill: parentspacing: units.gu(3)width: parent.widthItem {anchors.left: parent.leftheight: txtName.heightanchors.right: parent.rightLabel {id: lblUsernamewidth: units.gu(7)anchors.verticalCenter: txtName.verticalCentertext: "User Name"}TextField {id: txtNameanchors.left: lblUsername.rightwidth: parent.width - lblUsername.width - units.gu(4)anchors.leftMargin: units.gu(4)objectName: "txtName"placeholderText: "type your username"//焦点变更事件onFocusChanged: {if(focus){//当获得焦点时就用js控制台输出,qml会把它默认转到绑定语言的控制台标准输出console.log("qml: txtName focused")}}onTextChanged: {console.log("qml: " + txtName.text)//goObject将会被注入,它是一个go对象//这里要注意,go对象的属性或方法在go层面必须是暴露的//但在qml中被js调用时首字母必须小写,多试几次就知道了goObject.txtNameChanged(txtName.text)}}}Item {anchors.left: parent.leftheight: txtName.heightanchors.right: parent.rightLabel {id: lblPasswdwidth: units.gu(7)anchors.verticalCenter: txtPasswd.verticalCentertext: "Password"}TextField {id: txtPasswdanchors.left: lblPasswd.rightwidth: parent.width - lblPasswd.width - units.gu(4)anchors.leftMargin: units.gu(4)objectName: "txtPassword"echoMode: TextInput.Passwordtext: "password"}}}}}然后在qtcreator的build菜单中选择run,它会用qmlscene来加载这个ui,以便调试效果。在qtcreator中design好像有点问题,所以不建议这种所见即所得的编辑方法,这在ubuntu 13.10版本中,qt5正式引入后可能会改善。**2、编写main.go**在qml项目目录编写main.gopackage mainimport ("github.com/niemeyer/qml""log")// 用于注入qml的go结构type GoObject struct {}func (g *GoObject) TxtNameChanged(text string) {log.Println("go: ",text)}func main() {// 初始化qmlqml.Init(nil)// 创建引擎engine := qml.NewEngine()// 加载qmlcomponent, err := engine.LoadFile("atomqq.qml")if err != nil {panic(err)}// 获得上下文context := engine.Context()// 将一个go对象注入进qml上下文goObject := GoObject{}context.SetVar("goObject", &goObject)// 创建qml窗口window := component.CreateWindow(nil)// 获得根控件root := window.Root()// 根据Name属性获得空间//obj := root.ObjectByName("mainPage")//obj.Set("title", "xx登录窗口")// 显示窗口window.Show()// 获得根控件的一个属性width := root.Int("width")log.Println(width)// 设置一个属性的值// 这里将窗体的宽度增加1个像素,来出发qt对窗体进行重回// 由于使用的qml、qt5还有go在ubuntu中都不是稳定版,可能时某个里面还有bug.// qml窗体在初始化时,貌似没有画好,必须得手动重绘一次root.Set("width",>  posted on 2013-09-23 00:43 黑暗伯爵 阅读(...) 评论(...)  编辑 收藏


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-598665-1-1.html 上篇帖子: Golang学习 - 学习资源列表 下篇帖子: golang zip 压缩,解压(含目录文件)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表