飙血推荐
  • HTML教程
  • MySQL教程
  • JavaScript基础教程
  • php入门教程
  • JavaScript正则表达式运用
  • Excel函数教程
  • UEditor使用文档
  • AngularJS教程
  • ThinkPHP5.0教程

canvas绘制“飞机大战”小游戏,真香!

时间:2022-02-11  作者:HarmonyOSDev  
canvas绘制“飞机大战”小游戏,真香! canvas是ArkUI开发框架里的画布组件,常用于自定义绘制图形。因为其轻量、灵活、高效等优点,被广泛应用于UI界面开发中。本期,我们将为大家介绍canvas组件的使用。

canvas是ArkUI开发框架里的画布组件,常用于自定义绘制图形。因为其轻量、灵活、高效等优点,被广泛应用于UI界面开发中。

本期,我们将为大家介绍canvas组件的使用。

一、canvas介绍


1.  什么是canvas?


在Web浏览器中,canvas是一个可自定义width、height的矩形画布,画布左上角为坐标原点,以像素为单位,水平向右为x轴,垂直向下为y轴,画布内所有元素的位置基于原点进行定位。

如图1所示,我们通过<canvas>标签,创建了一个width=1500px,height=900px的空白画布,我们还需要“画笔”才能绘制图形。canvas采用轻量的逐像素渲染机制,以JS为“画笔”直接控制画布像素,从而实现图形绘制。

图1 canvas画布

2.  canvas的“画笔”


canvas本身虽不具备绘制能力,但是提供了获取“画笔”的方法。开发者可通过getContext(\'2d\')方法获取CanvasRenderingContext2D对象完成2D图像绘制,或通过getContext(\'webgl\')方法获取WebGLRenderingContext对象完成3D图像绘制。

目前,ArkUI开发框架中的WebGL1.0及WebGL2.0标准3D图形绘制能力正在完善中,所以本文将着重介绍2D图像的绘制。如图2所示,是CanvasRenderingContext2D对象提供的部分2D图像绘制方法,丰富的绘制方法让开发者能高效的绘制出矩形、文本、图片等。

图2 图像绘制方法

另外,开发者还可以获取OffscreenCanvasRenderingContext2D对象进行离屏绘制,绘制方法同上。

当绘制的图形比较复杂时,频繁的删除与重绘会消耗很多性能。开发者可根据自身的需求灵活选取canvas的渲染方式。这时,开发者可以根据自身的需求灵活选取离屏渲染的方式,通过创建OffscreenCanvas对象作为一个缓冲区,然后将需要绘制的内容先绘制在OffscreenCanvas上,最后再将OffscreenCanvas绘制到主画布上,以提高画布性能,确保绘图的质量。

二、canvas基础绘制方法


通过上节对canvas组件的基本介绍,相信大家对canvas组件已经有了一定的认识,下面我们将为大家实际演示canvas组件在ArkUI开发框架中的使用方法。ArkUI开发框架参考Web浏览器中canvas的设计,并在“类Web开发范式”及“声明式开发范式”两种开发范式中进行提供,接下来我们将分别介绍这两种开发范式中canvas的使用。

1.  类Web开发范式中canvas的绘制方法


类Web开发范式,使用HML标签文件进行布局搭建、CSS文件进行样式描述,并通过JS语言进行逻辑处理。目前,JS语言的canvas绘图功能已经基本上完善,下面我们将通过两个示例,展示基于JS语言的canvas组件基础使用方法。

(1)矩形填充

CanvasRenderingContext2D对象提供了fillRect(x, y, width,height)方法,用于绘制一个填充的矩形。如图3所示,在画布内绘制了一个黑色的填充矩形,x与y指定了在canvas画布上所绘制的矩形的左上角(相对于原点)的坐标,width和height则设置了矩形的尺寸。

图3 填充的矩形

示例代码如下:

//创建一个width=1500px,height=900px的画布
<!-- 域名 -->
<div>
  <canvas ref="canvas" style="width: 1500px; height: 900px; "></canvas>
</div>
 

//域名
export default {
  onShow() {
    const el =this.$域名as;
    //获取2D绘制对象
    const ctx = 域名ontext(\'2d\');
    //设置填充为黑色
    域名Style = \'#000000\';
    //设置填充矩形的坐标及尺寸
    域名Rect(200, 200, 300, 300);
   }
}

(2)缩放与阴影

CanvasRenderingContext2D对象提供了scale(x,y)方法,参数x表示横轴方向上缩放倍数,y表示纵轴方向上缩放的倍数,值得注意的是缩放过程中定位也会被缩放。如图4所示,是将上个示例中的填充矩形通过 scale(2,1.5)进行缩放,并通过shadowBlur方法加上阴影后的效果。

图4 缩放与添加阴影后的效果

示例代码如下:

//域名
export default {
  onShow() {
    const el =this.$域名as;
    const ctx = 域名ontext(\'2d\');
   //设置绘制阴影的模糊级别
    域名owBlur = 80;
    域名owColor = \'rgb(0,0,0)\';
    域名Style = \'rgb(0,0,0)\';
    // x Scale to 200%,y Scale to 150%
    域名e(2, 1.5);
    域名Rect(200, 200, 300, 300);
   }
}

2.  声明式开发范式中canvas的绘制方法


声明式开发范式,采用TS语言并进行声明式UI语法扩展,从组件、动效和状态管理三个维度提供了UI绘制能力。目前,eTS语言已经提供了canvas组件绘制能力,但功能仍在完善中。下面我们将通过两个示例,展示声明式开发范式中canvas组件的基础使用方法。

(1)图片叠加

如图5所示,是三张图片叠加的效果,顶层的图片覆盖了底层的图片。通过依次使用drawImage(x,y, width, height)方法设置图片坐标及尺寸,后面绘制的图片自动覆盖原来的图像,从而达到预期效果。

图5 图片叠加

扩展的TS语言采用更接近自然语义的编程方式,让开发者可以直观地描述UI界面,示例代码如下:

@Entry
@Component
struct IndexCanvas1 {
  private settings:RenderingContextSettings = new RenderingContextSettings(true);
//获取绘图对象
  private ctx: RenderingContext = new RenderingContext(域名ings);
//列出所要用到的图片
  private img:ImageBitmap = new ImageBitmap("common/域名");
  build() {
    Column() {
      //创建canvas
      Canvas(域名)
        .width(1500)
        .height(900)
        .border({color:"blue",width:1,})
        .backgroundColor(\'#ffff00\')
         //开始绘制
        .onReady(() => {
          域名Image( 域名,400,200,540,300);
          域名Image( 域名,500,300,540,300);
          域名Image( 域名,600,400,540,300);
        })
    }
    .width(\'100%\')
    .height(\'100%\')
  }
}

(2)点击创建线性渐变

如图6所示,在画布中是一个线性渐变效果。本示例基于canvas扩展了一个Button组件,通过点击“Click”按钮,触发onClick()方法,并通过调用createLinearGradient()方法,绘制出了一个线性渐变色。

图6 图片上添加文字

示例代码如下:

@Entry
@Component
struct GradientExample {
  private settings: RenderingContextSettings = new RenderingContextSettings(true);
  private context: RenderingContext = new RenderingContext(域名ings);
  private gra: CanvasGradient = new CanvasGradient();
  build() {
    Column({ space: 5 })  {
//创建一个画布
      Canvas(域名ext)
        .width(1500)
        .height(900)
        .backgroundColor(\'#ffff00 \')
      Column() {
//设置按钮的样式
        Button(\'Click\').width(250).height(100).backgroundColor(\'#000000\')
          .onClick(() => {
//创建一个线性渐变色
            var grad = 域名teLinearGradient(600, 200, 400, 750)
            域名olorStop(0.0, \'red\');
            域名olorStop(0.5, \'white\');
            域名olorStop(1.0, \'green\');
            域名Style = grad;
            域名Rect(400, 200, 550, 550);
          })
       }.alignItems(域名er)
     }
   }
 }

三、飞机大战小游戏绘制实践


如图7所示,是一款“飞机大战”小游戏,通过控制战机的移动摧毁敌机。如何使用ArkUI开发框架提供的canvas组件轻松实现这个经典怀旧的小游戏?实现思路及关键代码如下:

图7 飞机大战小游戏

1. 首先列出游戏所用到的图片。

private imgList:Array<string> = ["域名","域名"…];

2. 将图片渲染到canvas画布上。

let img:ImageBitmap = new ImageBitmap("图片路径(如common/images)/"+域名ist[数组下标]);
域名Image( img,150/* x坐标*/,  150/* y坐标*/, 600/*宽*/, 600/*高*/)

3. 绘制背景图片和战机向下移动的效果。

域名Image(域名, 0, 域名);
域名Image(域名, 0, 域名 - 480);
域名++ == 480 && (域名 = 0);

4. 使用域名d函数随机获取敌机图片并渲染到画布上。并且改变敌机y轴坐标,使它向下运动。

Efight = 域名d(域名om()*7);
//前七张为敌机图片。
let img:ImageBitmap = new ImageBitmap("common/img"+域名ist[Efight]);
域名Image(img, 0, 域名ght + 50);//渲染敌机

5. 在页面每隔120s出现一排子弹,之后减小或增大(x,y)轴的坐标达到子弹射出效果。

let i= 0;
setInterval(()=>{
  域名Image(域名mg1,image.x – 10 – (i *10) , image.x + (i *10))
  域名Image(域名mg2, this. bulImg1,image.x – (i *10) , i image.x + (i *10))
  域名Image(域名mg3, image.x + 10 + (i *10), image.x + (i *10))
i ++;
},120)

6.使用onTouch方法获取战机移动位置,获取拖动的坐标后重新设置战机的图片坐标,使战机实现拖动效果。

.onTouch((event)=>{
  var offsetX = 域名lX ||域名hes[0].localX;
  var offsetY = 域名lY ||域名hes[0].localY;
  var w = 域名Img[0].width,
      h = 域名Img[0].height;
  var nx = offsetX - w / 2,
      ny = offsetY - h / 2;
      nx < 20 - w / 2 ? nx = 20 - w / 2 : nx > (域名owWidth - w / 2 - 20) ? nx =
  (域名owWidth - w / 2 - 20) : 0;
  ny < 0 ? ny = 0 : ny > (域名owHeight - h / 2) ? ny = (域名owHeight –
  h/2) : 0;
     域名.x = nx;
     域名.y = ny;
     域名t = 2;


注:本示例引用了部分开源资源:https://域名/xs528/game,感兴趣的开发者可参考此开源资源,结合文中的实现思路补全代码。

以上就是本期全部内容,期待广大开发者能通过canvas组件绘制出精美的图形。更多canvas组件的详细使用方法,可跳转到官网文档(https://域名/cn/docs/documentation/doc-references/js-components-canvas-canvas-0000000000621808)进行学习。

扫码添加开发者小助手微信

获取更多HarmonyOS开发资源和开发者活动资讯

标签:编程
湘ICP备14001474号-3  投诉建议:234161800@qq.com   部分内容来源于网络,如有侵权,请联系删除。