Qt Quick之Canvas
QML中的Canvas,俗称画布,它用来定义一个绘图区域,可以使用ECMAScript代码来绘制直线,矩形,贝塞尔曲线,弧线,图片,文字等图元,还可以为这些图元应用填充颜色和边框颜色,甚至还可以进行低阶的像素级的操作。
1. 几个重要概念
(1)画布
下面的代码定义了一个宽320像素高240像素的画布
Canvas
{
width:;
height:;
}
(2)画师
画师如同MFC中的DC和Qt C++中的QPainter,那么QML中的画师是谁呢?Content2D是也!可以在Qt帮助文档中使用索引模式查找“Context2D”关键字来查看相关信息。
方法1:
Canvas
{
onPaint:
{
var ctx = getContext("2d");
}
}
方法2:
Canvas{
id:canvas;
contextType:"2d";
onPaint:{
context.lineWidth=;
}
}
(3)画笔
lineWidth:设置画笔的宽度
strokeStyle:设置画笔颜色或风格
(4)画刷
在context2D这里,fillStyle属性是描述画刷的
(5)坐标系
(0,0)为左上角,x轴水平向右为正,y轴垂直向下为正
(6)图元
基本图元有线,弧,矩形,曲线,文本,图片等
2. 基本绘图模式
Canvas
{
width:;
height:;
onPaint:
{
var ctx = getContext("2d"); ctx.lineWidth = ; // 设置画笔宽度
ctx.strockStyle="red"; // 设置画笔颜色
ctx.fillStyle="blue"; // 设置填充色 ctx.beginPath();
ctx.rect(,,,);
ctx.fill();
ctx.stroke();
}
}
上面代码演示如何绘制一个矩形和矩形边框,展示了使用Canvas和Context2D绘图的一般步骤:
(1)定义一个Canvas对象,设置width和Height
(2)定义onPaint信号处理器
(3)获取Context2D对象
(4)实际的绘图操作
3. 绘制路径
使用Content2D绘制路径的一般步骤:
(1)调用beginPath()
(2)调用moveTo(),lineTo(),rect(),quadraticCurveTo(),arc(),bezierCurveTo()等可以构造路径元素的方法
(3)调用fill()或stroke()
这里主要介绍下fillStyle属性的使用,fillStyle与Qt C++中的QBrush类似,保存用于填充图元的画刷,它可以是一个颜色值,也可以是CanvasGradient或CanvasPattern对象
Canvas
{
width: ;
height: ;
contextType:"2d";
onPaint:
{
var ctx = getContext("2d");
ctx.lineWidth = ;
ctx.lineJoin = "round"
ctx.strokeStyle = "red";
ctx.font = "42px sans-serif"; //ctx.fillStyle = "blue"; // 使用颜色进行填充
var gradient = ctx.createLinearGradient(,,,);
gradient.addColorStop(, Qt.rgba(,,,));
gradient.addColorStop(, Qt.rgba(,,,));
ctx.fillStyle =gradient; // 使用渐变对象进行填充 ctx.beginPath();
ctx.moveTo(,);
ctx.lineTo(,);
ctx.rect(,,,);
ctx.text("stroke text", ,);
ctx.fill(); ctx.stroke();
}
}
注意:closePath()方法用于结束当前的路径,从路径终点到起点绘制一条直线来封闭路径,比如:
ctx.beginPath();
ctx.moveTo(,);
ctx.lineTo(,);
ctx.lineTo(,);
ctx.closePath();
ctx.fill();
ctx.stroke();
通过closePath绘制一个三角形
4. 绘制文本
Context2D对象与文本相关的方法有三个:fillText(),strokeText(),text()
fillText()使用fillStyle填充文字
strokeTexr()使用strokeStyle描文字边框
text()方法在路径上添加一串文本作为构成路径的元素之一
上面代码效果:

5. 绘制图片
Context2D有4种不同形式的drawImage()方法,可以用来绘制图片
(1)显示本地图片
(2)显示网络图片
Canvas
{
width: ;
height: ;
id:canvas;
property var imageName: "dartlike_weapon.png";
property var imageUrl: "http://g2.ykimg.com/0516000053548ED267379F510C0061FA"; onPaint:
{
var ctx = getContext("2d"); ctx.drawImage(imageUrl, ,); // 绘制网络图片 ctx.drawImage(imageName, ,); // 绘制本地图片
} Component.onCompleted:
{
loadImage(imageUrl); // 异步加载图片,图片加载完发射imageLoaded信号
loadImage(imageName);
} onImageLoaded:
{
requestPaint(); // 重绘Canvas
}
}
上面的代码演示了显示本地和网络图片,Component.onCompleted附加信号处理器内调用Canvas的loadImage()方法来加载图片,该方法会异步加载图片,当图片加载完成时,发射imageLoaded信号,在对应的信号处理器onImageLoaded内调用requestPainte()方法来重回Canvas.怎样知道图片是否加载成功了呢?可以通过Canvas的isImageError(),isImageLoaded()两个方法来判断,他们接受和loadImage()同样的参数,返回布尔值,只有成功加载的图片才可以使用Context2D来绘制。
(3)使用Image属性显示网络图片
Image
{
id:imageSource;
source: "http://g2.ykimg.com/0516000053548ED267379F510C0061FA";
visible: false;
onStateChanged: {
if(status == Image.Ready)
{
canvas.requestPaint();
}
}
}
(4)使用createImageData显示图像
drawImage还可以绘制CanvasImageData对象,CanvasImageData对象使用一维数组,按照RGBA的顺序来保存图像数据
onPaint:
{
var ctx = getContext("2d"); if(imageData == null)
{
imageData = ctx.createImageData(,);
for (var i = ;i < ;i+=)
{
imageData.data[i] = Math.floor(Math.random()*);
imageData.data[i+] = Math.floor(Math.random()*);
imageData.data[i+] = Math.floor(Math.random()*);
imageData.data[i+] = ;
}
} ctx.drawImage(imageData,,); // 绘制createImageData
}
(5)4种方法的综合实例
import QtQuick 2.9
import QtQuick.Window 2.2 Window {
visible: true
width:
height:
title: qsTr("Hello World") Canvas
{
width: ;
height: ;
id:canvas;
property var imageName: "dartlike_weapon.png";
property var imageUrl: "http://g2.ykimg.com/0516000053548ED267379F510C0061FA"; Image
{
id:imageSource;
source: "http://g2.ykimg.com/0516000053548ED267379F510C0061FA";
visible: false;
/*onStateChanged: {
if(status == Image.Ready)
{
canvas.requestPaint();
}
}*/
} property var imageData: null;
onPaint:
{
var ctx = getContext("2d"); if(imageData == null)
{
imageData = ctx.createImageData(,);
for (var i = ;i < ;i+=)
{
imageData.data[i] = Math.floor(Math.random()*);
imageData.data[i+] = Math.floor(Math.random()*);
imageData.data[i+] = Math.floor(Math.random()*);
imageData.data[i+] = ;
}
} ctx.drawImage(imageData,,); // 绘制createImageData
ctx.drawImage(imageUrl, ,); // 绘制网络图片 ctx.drawImage(imageSource, ,); // 绘制image属性
ctx.drawImage(imageName, ,); // 绘制本地图片
} Component.onCompleted:
{
loadImage(imageUrl); // 异步加载图片,图片加载完发射imageLoaded信号
loadImage(imageName);
loadImage(imageSource);
} onImageLoaded:
{
requestPaint(); // 重绘Canvas
}
}
}

Qt Quick之Canvas的更多相关文章
- Qt Quick实现的涂鸦程序
之前一直以为 Qt Quick 里 Canvas 才干够自绘.后来发觉不是,原来还有好几种方式都能够画图! 能够使用原始的 OpenGL(Qt Quick 使用 OpenGL 渲染).能够构造QSGN ...
- Qt Quick 与 QML语言(初学笔记1)
Qt Quick Qt Quick是一些新的UI技术的集合,用来帮助开发者创建一种现在越来越多用于手机.多媒体播放器.机顶盒以及其他便携式设备上的直观的.现代的.流畅的用户界面.简单来说,Qt Qui ...
- qt quick中qml编程语言
Qt QML 入门 — 使用C++定义QML类型 发表于 2013 年 3 月 11 日 注册C++类 注册可实例化的类型 注册不实例化的QML类型 附带属性 注册C++类 注册可实例化的类型 如 ...
- Qt Quick 简单介绍
Qt Quick 是 Qt 提供的一种高级用户界面技术.使用它可轻松地为移动和嵌入式设备创建流畅的用户界面. 在 Android 设备上, Qt Quick 应用默认使用 OpenGL ES ,渲染效 ...
- Qt Quick 之 PathView 具体解释
PathView ,顾名思义,沿着特定的路径显示 Model 内的数据. Model 能够是 QML 内建的 ListModel . XmlListModel ,也能够是在 C++ 中实现的 QAbs ...
- Qt Quick 常用元素:ComboBox(下拉列表) 与 ProgressBar(进度条)
一.ComboBox ComboBox,即下拉列表框,由一个列表框和一个标签控件(或编辑控件)组成.ComboBox 的下拉列表是使用 Menu 实现的,列表内的每个条目对应一个 Menultem. ...
- Qt Quick 常用元素:RadioButton(单选框),CheckBox(复选框) 与 GroupBox(分组框)
先介绍一下 ExclusiveGroup. ExclusiveGroup (互斥分组)本身是不可见元素,用于将若干个可选择元素组合在一起, 供用户选择其中的一个选项.你可以在 ExclusiveGro ...
- 《Qt Quick 4小时入门》学习笔记4
http://edu.csdn.net/course/detail/1042/14806?auto_start=1 Qt Quick 4小时入门 第七章:处理鼠标与键盘事件 1.处理鼠标事件 鼠标信号 ...
- 《Qt Quick 4小时入门》学习笔记3
http://edu.csdn.net/course/detail/1042/14807?auto_start=1 Qt Quick 4小时入门 第八章:Qt Quick中的锚(anchors)布局 ...
随机推荐
- Fiddler 详尽教程与抓取移动端数据包
转载自:http://blog.csdn.net/qq_21445563/article/details/51017605 阅读目录 1. Fiddler 抓包简介 1). 字段说明 2). Stat ...
- Web框架的引入
为什么会有web框架 有了上一篇内容,静态.动态web服务器的实现,已经掌握了客户端请求到服务器处理的机制.在动态资源处理中,根据请求 .py 导入模块应用,然后调用应用入口程序实现动态处理.但是在真 ...
- 九度OJ 1184:二叉树遍历 (二叉树)
时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:3515 解决:1400 题目描述: 编一个程序,读入用户输入的一串先序遍历字符串,根据此字符串建立一个二叉树(以指针方式存储). 例如如下的 ...
- 我的Android进阶之旅------>Android中android:windowSoftInputMode的用法
面试题:如何在显示某个Activity时立即弹出软键盘? 答案:在AndroidManifest.xml文件中设置<activity>标签的android:windowSoftInputM ...
- 短时程突触可塑性(short-term synaptic plasticity)
介绍 神经元的突触可塑性一般被认为是大脑学习与记忆的分子生物学机制,它是指突触传递效率增强或减弱的变化现象.若这种变化只持续数十毫秒到几分,便称之为短时程突触可塑性,其中效率增强与减弱分别叫做短时程增 ...
- python基础15 ---面像对象的程序设计
面向对象的程序设计 一.面向对象的程序设计简介 1.面向对象程序设计的由来. 我们之前虽然学习过了面向过程的程序,它的核心是面向过程,一步一步的设计好了的流程,虽然极大的降低了程序的复杂度,但是一个设 ...
- Blobstore Java API overview
Blobstore API允许你的应用程序使用(serve)叫做Blobs的数据对象.这种数据对象比Datastore服务所允许的对象的尺寸大得多.Blobs能有效地为大文件比如视频.图片提供服务,允 ...
- php添加或升级扩展模块步骤
php添加或升级扩展模块步骤: 1).下载对应扩展的稳定版源码包2).进入到解压后的源码包执行: sudo /usr/local/php/bin/phpize //对应安装到哪个php版本 sudo ...
- CSS选择器(一)
一.CSS 元素选择器 最常见的 CSS 选择器是元素选择器.换句话说,文档的元素就是最基本的选择器. 如果设置 HTML 的样式,选择器通常将是某个 HTML 元素,比如 p.h1.em.a,甚至可 ...
- 3.25课·········JavaScript的DOM操作
1.DOM的基本概念 DOM是文档对象模型,这种模型为树模型:文档是指标签文档:对象是指文档中每个元素:模型是指抽象化的东西. 2.Window对象操作 一.属性和方法: 属性(值或者子对象): op ...