Qt-QML-Canvas写个小小的闹钟

简介: Qt-QML-Canvas写个小小的闹钟

image.png

先看下演示效果


大致过程



先绘制仪表盘,圆圈和刻度


剩下再绘制三个指针


最后在绘制上面的电子时钟


下面写源代码


import QtQuick 2.0


Rectangle

{

   id:root

   anchors.centerIn: parent

   width: 200

   height: 200

   color: "transparent"

   property int time_H : 0;

   property int time_M : 0;

   property int time_S : 0;



   Timer

   {

           interval: 500; running: true; repeat: true

           onTriggered:

           {


               time.text = Qt.formatDateTime(new Date(), "hh:mm:ss")

               root.time_H = Qt.formatDateTime(new Date(), "hh")

               root.time_M = Qt.formatDateTime(new Date(), "mm")

               root.time_S = Qt.formatDateTime(new Date(), "ss")

           }


   }


   Canvas

   {

       anchors.fill: parent

       onPaint:

       {

           var ctx = getContext("2d");

           ctx.lineWidth = 2;

           ctx.strokeStyle = "#FFFFFF";

           ctx.globalAlpha = 1.0;

           ctx.beginPath();

           ctx.arc(100,100,99,0,2*Math.PI);

           ctx.stroke();

           ctx.restore();


           for(var i =0;i<32;i++)

           {

               ctx.save();

               ctx.translate(width/2,height/2);

               ctx.rotate(((i)*30)*Math.PI/180);

               ctx.beginPath();

               //判定长短线

               if(i%3 == 0)

               {

                   ctx.moveTo(0,-99+15);

                   ctx.lineTo(0,-99+2);

               }

               else

               {

                   ctx.moveTo(0,-99+10);

                   ctx.lineTo(0,-99+2);

               }

               //绘制

               ctx.stroke();

               ctx.restore();

           }

       }

   }

   Rectangle

   {

       width: 20

       height: 20

       anchors.horizontalCenter: parent.horizontalCenter

       anchors.top: parent.top

       anchors.topMargin: 15

       color: "#00000000"

       Text {

           anchors.centerIn: parent

           font.family: "微软雅黑"

           font.pixelSize: 14

           color: "#FFFFFF"

           text: qsTr("12")

       }

   }

   Rectangle

   {

       width: 20

       height: 20

       anchors.verticalCenter: parent.verticalCenter

       anchors.right: parent.right

       anchors.rightMargin: 15

       color: "#00000000"

       Text {

           anchors.centerIn: parent

           font.family: "微软雅黑"

           font.pixelSize: 14

           color: "#FFFFFF"

           text: qsTr("3")

       }

   }

   Rectangle

   {

       width: 20

       height: 20

       anchors.verticalCenter: parent.verticalCenter

       anchors.left: parent.left

       anchors.leftMargin: 15

       color: "#00000000"

       Text {

           anchors.centerIn: parent

           font.family: "微软雅黑"

           font.pixelSize: 14

           color: "#FFFFFF"

           text: qsTr("9")

       }

   }

   Rectangle

   {

       width: 20

       height: 20

       anchors.horizontalCenter: parent.horizontalCenter

       anchors.bottom: parent.bottom

       anchors.bottomMargin: 15

       color: "#00000000"

       Text {

           anchors.centerIn: parent

           font.family: "微软雅黑"

           font.pixelSize: 14

           color: "#FFFFFF"

           text: qsTr("6")

       }

   }

   Canvas

   {

       id:m_Hour

       property int m_Radius: (root.width>=root.height)? (root.height)/2 : (root.width)/2

       width: m_Radius*2

       height: m_Radius*2

       anchors.centerIn: parent

       rotation: (root.time_H%12)*30 + root.time_M*6/60 + root.time_S*6/60/60 - 180

       onPaint:

       {

           var ctx = getContext("2d");

           ctx.lineWidth = 2;

           ctx.fillStyle = "#FFFFFF";

           ctx.strokeStyle = "#FFFFFF";

           ctx.beginPath()

           ctx.moveTo(m_Radius,m_Radius)

           ctx.lineTo(m_Radius+4,m_Radius+m_Radius*0.5)

           ctx.lineTo(m_Radius,m_Radius*2-37)

           ctx.lineTo(m_Radius-4,m_Radius+m_Radius*0.5)

           ctx.closePath()

           ctx.fill()

           ctx.stroke()

       }


   }

   Canvas

   {

       id:m_Min

       property int m_Radius: (root.width>=root.height)? (root.height)/2 : (root.width)/2

       width: m_Radius*2

       height: m_Radius*2

       anchors.centerIn: parent

       rotation: root.time_M*6 + root.time_S*6/60 - 180

       onPaint:

       {

           var ctx = getContext("2d");

           ctx.lineWidth = 2;

           ctx.fillStyle = "yellow";

           ctx.strokeStyle = "yellow";

           ctx.beginPath()

           ctx.moveTo(m_Radius,m_Radius)

           ctx.lineTo(m_Radius+2,m_Radius+m_Radius*0.5)

           ctx.lineTo(m_Radius,m_Radius*2-32)

           ctx.lineTo(m_Radius-2,m_Radius+m_Radius*0.5)

           ctx.closePath()

           ctx.fill()

           ctx.stroke()

       }


   }


   Canvas

   {

       id:m_Second

       property int m_Radius: (root.width>=root.height)? (root.height)/2 : (root.width)/2

       width: m_Radius*2

       height: m_Radius*2

       anchors.centerIn: parent

       rotation: root.time_S*6 - 180

       onPaint:

       {

           var ctx = getContext("2d");

           ctx.lineWidth = 2;

           ctx.fillStyle = "red";

           ctx.strokeStyle = "red";

           ctx.beginPath()

           ctx.moveTo(m_Radius,m_Radius)

           ctx.lineTo(m_Radius+1,m_Radius+m_Radius*0.5)

           ctx.lineTo(m_Radius,m_Radius*2-28)

           ctx.lineTo(m_Radius-1,m_Radius+m_Radius*0.5)

           ctx.closePath()

           ctx.fill()

           ctx.stroke()

       }


   }

   Rectangle

   {

       border.color: "#FFFFFF"

       border.width: 2

       width: 80

       height: 40

       anchors.centerIn: parent

       color: "#000000"

       Text {

           id:time

           anchors.centerIn: parent

           color: "#00FF00"

           font.family: "微软雅黑"

           font.pixelSize: 16

           text: qsTr("22:22:22")

       }

   }


}


目录
相关文章
|
8月前
|
计算机视觉 C++
基于Qt的简易图片浏览器设计与实现
基于Qt的简易图片浏览器设计与实现
333 1
|
5月前
【qt】 QGridLayout布局管理器怎么用?
【qt】 QGridLayout布局管理器怎么用?
192 0
|
5月前
QML 界面切换的方法
QML 界面切换的方法
338 1
|
8月前
Qt+OpenGL 打砖块游戏
Qt+OpenGL 打砖块游戏
100 0
【QT】历时两个月,用QT实现超级玛丽,谁说QT不能写游戏?【附源码】
【QT】历时两个月,用QT实现超级玛丽,谁说QT不能写游戏?【附源码】
|
JavaScript
Qt图片浏览器
可以显示jpg、jpeg、png、bmp。可以从电脑上拖动图到窗口并显示出来或者打开文件选择 重载实现dragEnterEvent(拖拽)、dropEvent(拖拽放下)、resizeEvent(窗口大小改变)
115 0
QT之Qml使用QSystemTrayIcon实现系统托盘
QT之Qml使用QSystemTrayIcon实现系统托盘
|
数据库 C++
Qt实现程序启动动画
Qt实现程序启动动画
Qt-QSplashScreen-程序启动动画
Qt-QSplashScreen-程序启动动画
397 0
Qt-QSplashScreen-程序启动动画
|
开发工具 C语言
Qt编写自定义控件33-图片切换动画
一、前言 在很多看图软件中,切换图片的时候可以带上动画过渡或者切换效果,显得更人性化,其实主要还是炫一些,比如百叶窗、透明度变化、左下角飞入等,无论多少种效果,核心都是围绕QPainter来进行,将各种动画效果对应的图片的区域动态计算并绘制出来,配合以QPropertyAnimation动画属性产生线性插值,比如渐入飞入时候,可以中间快速两端慢速。
1049 1