qml学习---------------利用Canvas绘制文本

这篇博客介绍了如何在Qt QML的Canvas组件中绘制文本,包括利用fillText()、strokeText()和text()方法设置文本样式,并通过示例展示具体用法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在利用Canvas绘制文本的时候,可以指定文本不同的风格。
Context2D中和文本相关的方法有3个: fillText() , strokeText() , text();

使用方法就下面两种:
ctx.beginPath();
ctx.text(“stroken text” ,100 , 100);
ctx.stroke();

或者是另外的一种使用方法:
ctx.strokeText(“stroken text” , 200 ,100);

下面就通过一个具体的例子来学习下。

import QtQuick 2.2

Canvas{

    width: 530;
    height: 300;
    id: root;

    onPaint: {
        var ctx = getContext("2d");
        ctx.lineWidth = 2;
        ctx.strokeStyle = "red";
        ctx.font = " 42px sans-serif";

        var gradient = ctx.createLinearGradient(0,0, width , height);
        gradient.addColorStop( 0.0 , Qt.rgba(0 , 1 ,0 , 1));
        gradient.addColorStop(1.0 , Qt.rgba(0,0, 1 , 1));

        ctx.fillStyle = gradient;

        ctx.beginPath();
        ctx.text("Fill Text on Path" , 10 , 50);
        ctx.fill();  // 设置 ↑ 的text的风格为fill

        ctx.fillText("Fill Text" , 10 , 100);


        ctx.beginPath();
        ctx.text("Stroke Text on Path" , 10 , 150);
        ctx.stroke(); //设置 ↑ 的text风格为stroke


        ctx.strokeText("Stroke Text" , 10 , 200);

        ctx.beginPath();
        ctx.text("Stroke and Fill Text on Path" , 10 , 250 );
        ctx.stroke();
        ctx.fill();


    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值