search
HomeWeb Front-endH5 Tutorialhtml5 Canvas drawing tutorial (9)—Drawing rectangles and circles in canvas_html5 tutorial skills

This article talks about how to draw rectangles and circles in canvas. They are basic graphics. Of course, there are more basic graphics than them, but in canvas, you can only draw rectangles and circles without using other methods to simulate them.

Canvas draws rectangle
1, fillRect and strokeRect
fillRect can directly fill a rectangle, and the fill style is the style you currently set; the same The rationale for strokeRect is to directly stroke a rectangle
. Their parameters are consistent, in order (starting point x coordinate, starting point y, rectangular width, rectangular height). The starting point here, note, refers to the upper left corner of the rectangle.
We usually use them to do simple things, and they can only do simple things. Why? Because there is no "path" in the graphics they drew, it just came out directly.
For example, if you first fill a rectangle with fillRect, and then you want to stroke the rectangle, if you use stroke(), it will have no effect, because although there is a rectangle, there is no path.
If you desperately want to stroke this rectangle, you can use strokeRect() to stroke a rectangle at the same position - but they are actually independent, just overlapping positions.

Copy code
The code is as follows:

ctx.fillRect(200,100,50,40 );
ctx.strokeRect(200,100,50,40);

If we want a rectangle with both fill and stroke, then using fillRect and strokeRect at the same time will undoubtedly be cumbersome . So in this case we usually use the following method.

2, rect
The parameters of rect are no different from fillRect and strokeRect. The difference is that it only draws a path. As for the stroke or filling, you have to complete it yourself later. .

Copy code
The code is as follows:

ctx.rect(300,100,50,40 );
ctx.stroke()
ctx.fill();

What are the benefits of doing this? I mentioned in the previous article that filling or stroking consumes a lot of resources, so we often need to draw hundreds of paths at once (such as loops) and then stroke or fill them. At this time, use rect to draw the path and fill it at the end, which avoids the problem of fillRect and strokeRec having to fill or stroke each time.

3, lineTo
Of course you can also use 4 lineTo to draw a rectangle like my line drawing tutorial. But this is not necessary, see that article for details.

Canvas draws a circle
There is no eye in the sky. In fact, canvas does not have a real function that can directly draw a circle. What it draws is actually a 360-degree arc. , it looks like a circle.
We have talked about the function of canvas to draw arcs before, namely arc. We use it to draw a circle:

Copy code
The code is as follows:

ctx.arc(300 25,100 20,20,0,Math.PI*2);
ctx.stroke()
ctx. fill();

This arc is the same as rect, it also draws a path, and the filling or stroke needs to be completed later.
But it should be noted that the position judgment of a circle is different from that of a rectangle. We use the upper left corner of the rectangle as the starting point to determine its position, but we usually use the center of the circle to determine the position of the circle.
If you want to draw a set of horizontally and vertically centered rectangles and circles, then you must remember not to regard the starting point of the rectangle as the starting point of the circle - the starting point of the circle is the center of the circle!

Forget it, let me give you the current formula. For aligned circles and rectangles, the coordinates of the center of the circle = the coordinates of the rectangle and half the width and height of the rectangle.
That is, circle center x = rectangle x rectangle width/2, circle y = rectangle y rectangle height/2. This way they are absolutely aligned.
Although arc is not as easy to use as the method of directly drawing a circle - the method I envisioned to directly draw a circle only requires 3 parameters, namely the coordinates of the center of the circle and the radius - but arc can not only draw circles, but also semicircles and so on. , so the function is more powerful and you can make do with it.
Since there is a circle, there should be an ellipse, but there is not even a regular function for drawing a circle in canvas, let alone an ellipse. Therefore, drawing an ellipse must be simulated by other methods. This is more complicated, so I will leave it to later.
Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Vue和Canvas:如何实现手写签名和手势识别功能Vue和Canvas:如何实现手写签名和手势识别功能Jul 18, 2023 am 08:49 AM

Vue和Canvas:如何实现手写签名和手势识别功能引言:手写签名和手势识别功能在现代应用程序中越来越常见,它们可以为用户提供更加直观和自然的交互方式。Vue.js作为一款流行的前端框架,搭配Canvas元素可以实现这两个功能。本文将介绍如何使用Vue.js和Canvas元素来实现手写签名和手势识别功能,并给出相应的代码示例。一、手写签名功能实现要实现手写签

Canvas的优势有哪些Canvas的优势有哪些Aug 17, 2023 pm 04:52 PM

canvas的优势有强大的绘图功能、高性能、跨平台兼容性、支持多种图形格式、可以与其他Web技术集成、可以实现动态效果和可以实现复杂的图像处理。详细介绍:1、Canvas提供了丰富的绘图功能,可以绘制各种形状、线条、文本、图像等;2、Canvas在浏览器中直接操作像素,因此具有很高的性能;3、Canvas是基于HTML5标准的一部分,可以在各种现代浏览器上运行等等。

canvas特效有哪些canvas特效有哪些Aug 18, 2023 pm 04:12 PM

canvas特效有粒子效果、线条动画、图片处理、文字动画、音频可视化、3D效果、游戏开发等。详细介绍:1、粒子效果,通过控制粒子的位置、速度和颜色等属性来实现各种效果,如烟花、雨滴、星空等;2、线条动画,通过在画布上绘制连续的线条,创建出各种动态的线条效果;3、图片处理,通过对图片进行处理,可以实现各种炫酷的效果,如图片切换、图片特效等;4、文字动画等等特性。

如何利用Vue和Canvas创建逼真的天气动态背景如何利用Vue和Canvas创建逼真的天气动态背景Jul 17, 2023 am 08:33 AM

如何利用Vue和Canvas创建逼真的天气动态背景引言:在现代网页设计中,动态背景效果是吸引用户眼球的重要元素之一。本文将介绍如何利用Vue和Canvas技术来创建一个逼真的天气动态背景效果。通过代码示例,你将学习如何编写Vue组件和利用Canvas绘制不同天气场景,从而实现一个独特而吸引人的背景效果。步骤一:创建Vue项目首先,我们需要创建一个Vue项目。

canvas插件有哪些canvas插件有哪些Aug 17, 2023 pm 05:00 PM

canvas插件有Fabric.js、EaselJS、Konva.js、Three.js、Paper.js、Chart.js和Phaser。详细介绍:1、Fabric.js 是一个基于Canvas的开源 JavaScript 库,它提供了一些强大的功能;2、EaselJS是CreateJS库中的一个模块,它提供了一套简化了Canvas编程的API;3、Konva.js等等。

Vue和Canvas:如何实现图片的马赛克效果Vue和Canvas:如何实现图片的马赛克效果Jul 16, 2023 pm 10:17 PM

Vue和Canvas:如何实现图片的马赛克效果引言:随着Web技术的不断发展,越来越多的人开始使用Vue框架来构建交互式的前端应用。而在前端开发中,常常需要为用户提供图片处理的功能。本文将介绍如何利用Vue和Canvas实现图片的马赛克效果,为用户带来更好的视觉体验。一、马赛克效果概述马赛克效果是一种将图像的细节部分进行像素化处理,使得整个图像变得模糊和抽象

Vue和Canvas:如何实现视频播放器的定制化界面Vue和Canvas:如何实现视频播放器的定制化界面Jul 18, 2023 pm 02:49 PM

Vue和Canvas:如何实现视频播放器的定制化界面引言:在现代互联网时代,视频已经成为人们生活中必不可少的一部分。为了提供良好的用户体验,许多网站和应用程序都提供了自定义的视频播放器界面。本文将介绍如何使用Vue和Canvas技术实现一个定制化的视频播放器界面。一、前期准备在开始之前,您需要确保您已经安装了Vue和Canvas,并且熟悉这两种技术的基本用法

canvas引擎有哪些canvas引擎有哪些Aug 17, 2023 pm 05:29 PM

canvas引擎有Three.js、Pixi.js、EaselJS、Konva.js、Paper.js等。详细介绍:1、Pixi.js,提供了简单易用的API,支持精灵、纹理、滤镜等功能,同时还提供了丰富的工具和插件,方便开发者进行交互、动画和优化等操作;2、Pixi.js,提供了简单易用的API,支持精灵、纹理、滤镜等功能,还提供了丰富的工具和插件;3、EaselJS等等。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Tools

DVWA

DVWA

Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

SecLists

SecLists

SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

Dreamweaver Mac version

Dreamweaver Mac version

Visual web development tools

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment