js画布组件(<canvas></canvas>)

本文详细介绍了HTML5 Canvas的基本用法,包括如何设置画布、获取上下文对象、绘制图形和文本等内容。此外还展示了绘制线条、圆形及图片的具体实例。

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

一、Canvas是什么?

Canvas就是一个画布,可以进行画任何的线、图形、填充等一系列的操作,而且操作的画图就是js,所以让js编程到了嗑药的地步。另外Canvas不仅仅提供简单的二维矢量绘图,也提供了三维的绘图,以及图片处理等一系列的api支持。

二、Canvas重要Context对象

(1) 要使用Canvas来绘制图形必须在页面中添加Canvas的标签。

例如: <canvas id="demoCanvas" width="500" height="500"> <p>爷,你还在上个世纪吧,现在都html5了,您还在ie6时代?</p> </canvas>

(2) 当然只有上面的标签,只能是创建好了一个画布,其中width和height属性就是设置画布的大小。Id属性也是必须的,后面要用Id来拿到当前的Canvas的Dom对象。通过此Canvase的Dom对象就可以获取他的上下文了,Canvas绘制图形都是靠着Canvas对象的上下文对象.

代码:
<script type="text/javascript">
//第一步:获取canvas元素
var canvasDom = document.getElementById("demoCanvas");
//第二步:获取上下文
var context = canvasDom.getContext('2d');
</script>

(3) Context上下文默认两种绘制方式:第一种:绘制线(stroke),第二种:填充:fill。

注意:决定了使用哪种方式之后,在填充或者绘制线之前先设置样式。

三、Canvas Fisrt Demo:画一个立体透明的矩形

Canvas绘制的总体的步骤

  • 创建HTML页面,设置画布标签
  • 编写js,获取画布dom对象
  • 通过Canvas标签的Dom对象获取上下文
  • 设置绘制线样式、颜色
  • 绘制矩形,或者填充矩形

Canvas绘制一个矩形和填充一个矩形的Demo

<body>
    <canvas id="demoCanvas" width="500" height="500">
        <p>爷,你还在上个世纪吧,现在都html5了,您还在ie6时代?</p>
    </canvas>
    <!---下面将演示一种绘制矩形的demo--->
    <script type="text/javascript">
         
        //第一步:获取canvas元素
        var canvasDom = document.getElementById("demoCanvas");
        //第二步:获取上下文
        var context = canvasDom.getContext('2d');
        //第三步:指定绘制线样式、颜色
        context.strokeStyle = "red";
        //第四步:绘制矩形,只有线。内容是空的
        context.strokeRect(10, 10, 190, 100);
        
        //以下演示填充矩形。
        context.fillStyle = "blue";
        context.fillRect(110,110,100,100);
    </script>
</body>
最终效果下图:

四、Canvas绘制线条

    Context对象的beginPath方法表示开始绘制路径,moveTo(x, y)方法设置线段的起点,lineTo(x, y)方法设置线段的终点,stroke方法用来给透明的线段着色。moveto和lineto方法可以多次使用。最后,还可以使用closePath方法,自动绘制一条当前点到起点的直线,形成一个封闭图形,省却使用一次lineto方法。
                        
        <body>
        <canvas id="demoCanvas" width="500" height="600">
        </canvas>
        <script type="text/javascript">
            //通过id获得当前的Canvas对象
            var canvasDom = document.getElementById("demoCanvas");
            //通过Canvas Dom对象获取Context的对象
            var context = canvasDom.getContext("2d");
            context.beginPath(); // 开始路径绘制
            context.moveTo(20, 20); // 设置路径起点,坐标为(20,20)
            context.lineTo(200, 200); // 绘制一条到(200,20)的直线
            context.lineTo(400, 20);
            context.closePath();
            context.lineWidth = 2.0; // 设置线宽
            context.strokeStyle = "#CC0000"; // 设置线的颜色
            context.stroke(); // 进行线的着色,这时整条线才变得可见
        </script>
        </body>
    
、Canvas绘制文本
    Context上下文对象的fillText(string, x, y)方法是用来绘制文本,它的三个参数分别为文本内容、起点的x坐标、y坐标。使用之前,需用font设置字体、大小、样式(写法类似与CSS的font属性)。与此类似的还有strokeText方法,用来添加空心字。另外注意一点:fillText方法不支持文本断行,即所有文本出现在一行内。所以,如果要生成多行文本,只有调用多次fillText方法。
以下是代码Demo:
                        
        <canvas id="demoCanvas" width="500" height="600"></canvas>
        <script type="text/javascript">
            //通过id获得当前的Canvas对象
            var canvasDom = document.getElementById("demoCanvas");
            //通过Canvas Dom对象获取Context的对象
            var context = canvasDom.getContext("2d");
            context.moveTo(200,200);
            
            // 设置字体
            context.font = "Bold 50px Arial";
            // 设置对齐方式
            context.textAlign = "left";
            // 设置填充颜色
            context.fillStyle = "#005600";
            // 设置字体内容,以及在画布上的位置
            context.fillText("老马!", 10, 50);
            // 绘制空心字
            context.strokeText("blog.itjeek.com!", 10, 100);
        </script>

六、Canvas绘制圆形和椭圆

    在上一篇文章中,笔者已经跟大家介绍过了绘制矩形,绘制其他形状,比如圆形等,都是一个思路,只不过是方法不同罢了。那接下里给各位演示一小绘制圆形和椭圆。Context上下文的arc方法就是绘制圆形或者椭圆,arc方法的x和y参数是圆心坐标,radius是半径,startAngle和endAngle则是扇形的起始角度和终止角度(以弧度表示),anticlockwise表示做图时应该逆时针画(true)还是顺时针画(false)。
以下是绘制图形的Demo:

        <canvas id="demoCanvas" width="500" height="600"></canvas>
        <script type="text/javascript">
            //通过id获得当前的Canvas对象
            var canvasDom = document.getElementById("demoCanvas");
            //通过Canvas Dom对象获取Context的对象
            var context = canvasDom.getContext("2d");
            context.beginPath();//开始绘制路径
            //绘制以 (60,60)为圆心,50为半径长度,从0度到360度(PI是180度),最后一个参数代表顺时针旋转。
            context.arc(60, 60, 50, 0, Math.PI * 2, true);
            context.lineWidth = 2.0;//线的宽度
            context.strokeStyle = "#000";//线的样式
            context.stroke();//绘制空心的,当然如果使用fill那就是填充了。
        </script>

七、Canvas绘制图片

    Canvas绘制图片应该是他的一大特点或者是亮点吧。当然配合File的API,让JS变得无可匹敌。那接下里给大家演示一下怎样绘制图片,并且做出一个立体效果出来。
以下是绘制图片的Demo:

    <canvas id="demoCanvas" width="500" height="600"></canvas>
    <script type="text/javascript">
        //通过id获得当前的Canvas对象
        var canvasDom = document.getElementById("demoCanvas");
        //通过Canvas Dom对象获取Context的对象
        var context = canvasDom.getContext("2d");
        var image = new Image();//创建一张图片
        image.src = "Images/a.png";//设置图片的路径
        image.onload = function() {//当图片加载完成后
            for (var i = 0; i < 10; i++) {//输出10张照片
                //参数:(1)绘制的图片  (2)坐标x,(3)坐标y
                context.drawImage(image, 100 + i * 80, 100 + i * 80);
            }
        };
    </script>

八、总结

Canvas总算介绍了最基本的用法了。当然本文大量借鉴了其他网站的例子。作者也是把最基本的精华部分罗列了一下。总体来说Canvas绘制图片和文本、形状都不是很难,API代码上手难度基本就是初级。但是由此而带来的非常多的可能,让Html5真正的强大到无可比拟的地步。
当然本文并没有涉及到Canvas3D绘制的相关内容,而且关于Canvas绘制渐变色、绘制阴影、图片的相关处理操作等,这些内容,如果读者确实需要的可以自行搜索查找相关资料或者直接阅读Html5的最新标准文档。

 

转载于:https://www.cnblogs.com/jgjk/p/7638098.html

<template> <view> <canvas :style="{width:Size+ 'px', height:Size+ 'px'}" :canvas-id="QrcodeId" @click="RefreshQRcode"></canvas> </view> </template> <script> import { getCurrentInstance, defineComponent, reactive, ref, toRaw, watch, onActivated, onMounted } from 'vue'; import {onLoad,onShow} from '@dcloudio/uni-app'; import UQrocode from './weapp-qrcode.js'; export default { props: ["QrcodeId","Text",'Size'], emit: ['RefreshQRcode'], methods:{ RefreshQRcode(value){ var timestamp = new Date().getTime(); this.$emit("RefreshQRcode",timestamp) }, }, setup(parameter) { const handleMakeQrcode = () => { UQrocode.make({ //canvasId要和上面画布的id是一样的 canvasId:parameter.QrcodeId, componentInstance:this, text:parameter.Text, size:parameter.Size,//尺寸 margin:0 }) } onLoad(() => { // console.log(props.QrcodeId,'props.QrcodeId'); handleMakeQrcode() }); watch(() => parameter.Text, (newVal, oldVal) => { //新值,旧值 console.log(oldVal,"oldValoldValoldValoldVal") // console.log(newVal,"newValnewValnewValnewVal") if(newVal){ handleMakeQrcode() //监听到了 重新生成二维码 } }) // const Seconds = ref(0) // Seconds.value = parameter.Secondss // // console.log(Seconds.value,"console.log(Seconds.value)") // const startCountdown=()=> { // // Seconds.value = 10; // 设置倒计时初始值 // const timer = setInterval(() => { // if (Seconds.value > 0) { // Seconds.value--; // 每秒减1 // } else { // clearInterval(timer); // 倒计时结束,清除定时器 // } // }, 1000); // } return { // Seconds, }; }, } </script> <style lang="scss" scoped> </style>为什么小程序中展示不出二维码
03-28
给这段代码添加用户可以填写数量进行打印的功能,用户在输入框中填写需要打印图片的数量然后点击打印,填写多少就打印多少张图片,这是原代码<template> <view class="body"> <view class="barcode-display"> <text>Barcode: {{ barcode }}</text> </view> <image :src="previewImage" mode="aspectFit" class="preview-image"></image> <view class="uni-list"> <!-- 隐藏画布,用于标签绘制 --> <canvas :id="canvasId" :canvas-id="canvasId" type="2d" :style="{ width: labelWidth + 'px', height: labelHeight + 'px' }" style="position: fixed; left: -9999rpx; top: -9999rpx" /> <!-- 打印机列表 --> <view class="uni-list-cell"> <view class="uni-list-cell-left">打印机:</view> <view class="uni-list-cell-db"> <picker :value="deviceIndex" :range="deviceList" @change="onDeviceChanged" range-key="name"> <view class="uni-input">{{ deviceList[deviceIndex].name }}</view> </picker> </view> </view> </view> <view class="uni-padding-wrap uni-common-mt"> <!-- 设备搜索 --> <button type="primary" @click="startDiscovery">开始搜索打印机</button> <button type="primary" @click="stopDiscovery">停止搜索打印机</button> <!-- 链接打印机 --> <button type="primary" @click="openPrinter">打开打印机</button> <button type="primary" @click="closePrinter">关闭打印机</button> <!-- 标签编辑及打印 --> <button type="primary" plain="true" @click="printImage">打印图片</button> </view> <view style="text-align: center; padding: 10px"> <view style="margin: 10px; border: solid lightgray 1px"> <image v-for="item in previewList" :src="item.value" :key="item.key" class="image" mode="widthFix" style="margin: 10rpx; border: dashed lightgray 1px" /> </view> </view> </view> </template> <script> import { ref } from 'vue'; import { LPAPIFactory, LPA_Result, LPAUtils } from "@/uni_modules/dothan-lpapi-ble/js_sdk/index.js"; export default { setup() { const barcode = ref(''); const previewImage = ref(''); const fetchImageFromBackend = async () =>
03-26
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值