百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

网页游戏开发基础——Canvas基本图形绘制

zhezhongyun 2025-01-23 22:24 24 浏览

  什么是Canvas?Canvas是HTML5新增的一个标签,你可以把它翻译为画布,通过它可以绘制二维或三维图形,有了它就可以不用安装flash而实现复杂的动画功能。如何通过Canvas绘图?下面我们来看一个简单的例子,涵盖Canvas初始化、图片加载、图形绘制、图片显示等基本功能。

  一、HTML页面结构

  先看看HTML页面结构,详细代码如下:

  <title>标签指定网页标题;

  <meta>标签指定页面使用的字符集;

  <style>标签定义了一个名叫CenterWarp的样式;

  <body>标签中的onload="main()"表示页面加载完毕后调用main函数。

  <body>标签里有一个<div>标签,它的样式表示它的宽高为浏览器客户区的宽高,它的子元素水平、垂直居中。

  <canvas>标签定义了一块绘图区域,但canvas元素本身不绘制,你必须通过JavaScript脚本来绘制,注意其中的id="GameCanvans",表示可以通过JavaScript函数document.getElementById("GameCanvans")来将对Canvas元素的引用保存至一个变量中,在随后的代码可通过此变量来调用Canvas的绘图函数。

  二、Canvas初始化

  首先获取对Canvas元素的引用,然后再获取绘图上下文,代码参见initCanvas()函数:


此函数首先通过g_canvas=document.getElementById("GameCanvans")函数将Canvas元素的引用保存至全局变量g_canvas中,接着通过g_canvas获取Canvas元素的绘图上下文,并将绘图上下文保存至全局变量g_context中,即g_context=g_canvas.getContext("2d");在接下来的代码中通过此全局变量来调用Canvas的绘图函数。注意:getContext()函数的参数为"2d",表示获取的是2d绘图上下文,即进行二维绘制。接下来的代码设置了Canvas的宽、高,分别为320和240,最后根据初始化的结果返回true或false。

函数clearScreen()的作用是用黑色填充整个Canvas区域,即用黑色清屏。fillRect()函数有四个参数,依次为填充区域左上角x、y坐标,填充区域宽、高。

  三、绘制空心矩形、填充矩形

  绘制空心矩形需要设置strokeStyle,即矩形边框颜色,然后调用strokeRect()函数,四个参数依次为矩形左上角x、y坐标,宽、高。

  填充矩形的代码与清屏的代码类似,相关说明参见清屏函数clearScreen()。

  四、显示图片

  在Canvas中显示一幅图片需要分两步实现,首先要加载图片,接下来等图片加载完毕后才能绘制,我们先看看加载图片的代码:

  function loadPicture(){

    g_image=new Image();

    g_image.src="default.png";

    g_image.onload=function(){

      drawPicture();

    }

  }

  第1步:先创建一个Image对象;

  第2步:设置此图片对象的src属性,即图片路径(此处是相对路径,即,与JavaScript脚本文件处于相同路径);

  第3步:图片加载完毕后,调用绘图函数drawPicture()来绘图。

  g_image.onload=function(){}表示图片加载完毕后执行花括号中的语句,类似于<body>标签中的onload="main()",页面加载完毕后执行main()函数。

  最后,让我们来看看drawPicture()函数的代码

  function drawPicture(){

    g_context.drawImage(g_image,0,0,300,180,10,50,300,180);

  }

  即,调用Canvas的drawImage()函数绘图,其参数含义分别表示:

  1、g_image:图片对象

  2、0:图像左上角x坐标

  3、0:图像左上角y坐标

  4、300:图像宽度

  5、180:图像高度

  此例中图片尺寸为400×400,(0,0,300,180)表示从图片左上角(0,0)处复制300×180部分图片到Canvas中

  6、10:表示在Canvas中绘制的左上角x坐标

  7、50:表示在Canvas中绘制的左上角y坐标

  8、300:表示在Canvas中绘制的宽度

  9、180:表示在Canvas中绘制的高度

  将参数8和参数9改为与参数4、参数5不一样的数值可以实现缩放效果。

default.png如下图

完整的代码如下:

<script type="text/javascript">

  var g_canvas,g_context,g_image;

  function initCanvas(){

    g_canvas=document.getElementById("GameCanvans");

    g_context=g_canvas.getContext("2d");

    g_canvas.width=320;

    g_canvas.height=240;

    return (g_canvas&&g_context);

  }


  function clearScreen(){

    g_context.fillStyle="black";

    g_context.fillRect(0,0,320,240);

  }


  function drawWhiteRect(){

    g_context.strokeStyle="white";

    g_context.strokeRect(10,30,300,10);

  }


  function fillRedRect(){

    g_context.fillStyle="red";

    g_context.fillRect(10,10,300,10);

  }


  function drawPicture(){

    g_context.drawImage(g_image,0,0,300,180,10,50,300,180);

  }


  function loadPicture(){

    g_image=new Image();

    g_image.src="default.png";

    g_image.onload=function(){

      drawPicture();

    }

  }


  function main(){

    if(!initCanvas()){

      console.log("初始化canvas失败!");

      return;

    }

    clearScreen();

    fillRedRect();

    drawWhiteRect();

    loadPicture();

  }

</script>

  保存以上代码,并在浏览器中打开,将显示如下结果:

  好了,Canvas基本的绘图功能就介绍完了,现在我们已经完全具备开发简单网页游戏的能力了,接下来将给大家详细介绍如何实现一个数独游戏,敬请关注。

相关推荐

JPA实体类注解,看这篇就全会了

基本注解@Entity标注于实体类声明语句之前,指出该Java类为实体类,将映射到指定的数据库表。name(可选):实体名称。缺省为实体类的非限定名称。该名称用于引用查询中的实体。不与@Tab...

Dify教程02 - Dify+Deepseek零代码赋能,普通人也能开发AI应用

开始今天的教程之前,先解决昨天遇到的一个问题,docker安装Dify的时候有个报错,进入Dify面板的时候会出现“InternalServerError”的提示,log日志报错:S3_USE_A...

用离散标记重塑人体姿态:VQ-VAE实现关键点组合关系编码

在人体姿态估计领域,传统方法通常将关键点作为基本处理单元,这些关键点在人体骨架结构上代表关节位置(如肘部、膝盖和头部)的空间坐标。现有模型对这些关键点的预测主要采用两种范式:直接通过坐标回归或间接通过...

B 客户端流RPC (clientstream Client Stream)

客户端编写一系列消息并将其发送到服务器,同样使用提供的流。一旦客户端写完消息,它就等待服务器读取消息并返回响应gRPC再次保证了单个RPC调用中的消息排序在客户端流RPC模式中,客户端会发送多个请...

我的模型我做主02——训练自己的大模型:简易入门指南

模型训练往往需要较高的配置,为了满足友友们的好奇心,这里我们不要内存,不要gpu,用最简单的方式,让大家感受一下什么是模型训练。基于你的硬件配置,我们可以设计一个完全在CPU上运行的简易模型训练方案。...

开源项目MessageNest打造个性化消息推送平台多种通知方式

今天介绍一个开源项目,MessageNest-可以打造个性化消息推送平台,整合邮件、钉钉、企业微信等多种通知方式。定制你的消息,让通知方式更灵活多样。开源地址:https://github.c...

使用投机规则API加快页面加载速度

当今的网络用户要求快速导航,从一个页面移动到另一个页面时应尽量减少延迟。投机规则应用程序接口(SpeculationRulesAPI)的出现改变了网络应用程序接口(WebAPI)领域的游戏规则。...

JSONP安全攻防技术

关于JSONPJSONP全称是JSONwithPadding,是基于JSON格式的为解决跨域请求资源而产生的解决方案。它的基本原理是利用HTML的元素标签,远程调用JSON文件来实现数据传递。如果...

大数据Doris(六):编译 Doris遇到的问题

编译Doris遇到的问题一、js_generator.cc:(.text+0xfc3c):undefinedreferenceto`well_known_types_js’查找Doris...

网页内嵌PDF获取的办法

最近女王大人为了通过某认证考试,交了2000RMB,官方居然没有给线下教材资料,直接给的是在线教材,教材是PDF的但是是内嵌在网页内,可惜却没有给具体的PDF地址,无法下载,看到女王大人一点点的截图保...

印度女孩被邻居家客人性骚扰,父亲上门警告,反被围殴致死

微信的规则进行了调整希望大家看完故事多点“在看”,喜欢的话也点个分享和赞这样事儿君的推送才能继续出现在你的订阅列表里才能继续跟大家分享每个开怀大笑或拍案惊奇的好故事啦~话说只要稍微关注新闻的人,应该...

下周重要财经数据日程一览 (1229-0103)

下周焦点全球制造业PMI美国消费者信心指数美国首申失业救济人数值得注意的是,下周一希腊还将举行第三轮总统选举需要谷歌日历同步及部分智能手机(安卓,iPhone)同步日历功能的朋友请点击此链接,数据公布...

PyTorch 深度学习实战(38):注意力机制全面解析

在上一篇文章中,我们探讨了分布式训练实战。本文将深入解析注意力机制的完整发展历程,从最初的Seq2Seq模型到革命性的Transformer架构。我们将使用PyTorch实现2个关键阶段的注意力机制变...

聊聊Spring AI的EmbeddingModel

序本文主要研究一下SpringAI的EmbeddingModelEmbeddingModelspring-ai-core/src/main/java/org/springframework/ai/e...

前端分享-少年了解过iframe么

iframe就像是HTML的「内嵌画布」,允许在页面中加载独立网页,如同在画布上叠加另一幅动态画卷。核心特性包括:独立上下文:每个iframe都拥有独立的DOM/CSS/JS环境(类似浏...