矢量绘图:

1. 为矢量绘图绘制外边 - graphics.lineStype()

    private createGameScene():void
{
console.log("Runtime start."); var myShape:egret.Shape = new egret.Shape(); myShape.graphics.lineStyle(10, 0x00ff00, 1);
myShape.graphics.beginFill(0xff0000, 1);
myShape.graphics.drawRect(0,0,100,200);
myShape.graphics.endFill();
this.addChild(myShape); console.log("Runtime end.");
}

2. 清空一个显示对象的绘图 - graphics.clear()

3. 绘制圆形 - graphics.drawCircle(0, 0, 50)

4. 画直线:

    private createGameScene():void
{
var myShape:egret.Shape = new egret.Shape();
myShape.graphics.lineStyle(5, 0x00ff00, 1);
myShape.graphics.moveTo(50, 10); //将画笔移动到起点位置
myShape.graphics.lineTo(100, 20); //从起点位置划线到终点
myShape.graphics.endFill();
this.addChild(myShape);
}

5. 贝塞尔曲线:

    private createGameScene():void
{
var myShape:egret.Shape = new egret.Shape();
myShape.graphics.lineStyle(5, 0x00ff00, 1);
myShape.graphics.moveTo(50, 200);      //将画笔移动到起点位置
myShape.graphics.curveTo(150, 50, 250, 200); //指定起始移动方向的交汇点坐标,与终点坐标后进行画线
myShape.graphics.endFill();
this.addChild(myShape);
}

6. 绘制圆弧:

    private createGameScene():void
{
var myShape:egret.Shape = new egret.Shape();
myShape.graphics.lineStyle(5, 0x00ff00, 1);
myShape.graphics.beginFill(0x1122cc);
//圆心坐标、半径、起始弧度、终止弧度,填充的区域是圆弧+圆弧两端点的连接所包含的区域
myShape.graphics.drawArc(200,200,100,Math.PI/3, Math.PI);
myShape.graphics.endFill();
this.addChild(myShape);
}

7. 值得注意的是:graphic 可以用来绘制多个图形,不用一个 graphic 对应一个图形。

遮罩

1. 矩形遮罩:

    private createGameScene():void
{
var shp: egret.Shape = new egret.Shape();
shp.graphics.beginFill(0xff0000);
shp.graphics.drawRect(0,0,100,100);
shp.graphics.endFill();
this.addChild(shp); var shp2: egret.Shape = new egret.Shape();
shp2.graphics.beginFill(0x00ff00);
shp2.graphics.drawCircle(0,0,20);
shp2.graphics.endFill();
this.addChild(shp2);
shp2.x = 20;
shp2.y = 20; var rect: egret.Rectangle = new egret.Rectangle(20,20,30,50); //参数指定的区域是遮罩不遮挡的区域
shp.mask = rect;
}

2. 对象遮罩:可以用一个对象当成另一个对象的遮罩

square.mask = circle;    //像这样直接指定即可

碰撞检测

    private createGameScene():void {

        var infoTest = new egret.TextField();
infoTest.y = 200;
infoTest.text = "碰撞结果";
this.addChild(infoTest); //显示一个文本以展示测试结果 var shp:egret.Shape = new egret.Shape();
shp.graphics.beginFill(0xff0000);
shp.graphics.drawRect(0, 0, 120, 120);
shp.graphics.endFill();
this.addChild(shp); console.log(shp.width); //shp 的 width 与 height 与显示对线的内容相关,这里是 120
console.log(shp.height); var testPoint = new egret.Shape();
testPoint.graphics.beginFill(0x000000);
testPoint.graphics.drawRect(100, 100, 5, 5); //标记一个黑色的边界点
testPoint.graphics.endFill();
this.addChild(testPoint); var isHit:boolean = shp.hitTestPoint(110, 110); //结论:是否碰撞与 shp.graphics 相关,而与 shp.width/height 无关
infoTest.text = "碰撞结果" + isHit; //就算已经 addchild,可以直接修改文本, 结果是 true shp.graphics.clear(); //如果不clear, 重新 drawRect 不会生效
shp.graphics.beginFill(0xff0000);
shp.graphics.drawRect(0, 0, 100, 100);
shp.graphics.endFill();
var isHit:boolean = shp.hitTestPoint(110, 110);
infoTest.text = "碰撞结果" + isHit; //结果是 false
}

  值得注意的是,精确坐标的碰撞检测是非常消耗性能的,尽量少用。

Egret 矢量绘图、遮罩、碰撞检测的更多相关文章

  1. Egret引擎随学随机

    1.纹理集实际上就是将一些零碎的小图放到一张大图当中.游戏中也经常使用到纹理集.使用纹理集的好处很多,我们通过将大量的图片拼合为一张图片从而减少网络请求,原先加载数次的图片资源现在加载一次即可.同时, ...

  2. 圆形CD绘制 (扇形)

    参考: Egret教程Arc是使用示例:http://edn.egret.com/cn/article/index/id/673 我封装的工具类: /** * 圆形进度 * @author chenk ...

  3. Egret的容器--删除对象,遮罩

    class P91F extends egret.Sprite { public constructor() { super(); this.addEventListener(egret.Event. ...

  4. Egret Engine 2D - 遮罩

      矩形遮罩 shp.mask = new egret.Rectangle(20,20,30,50);   注意如果rec发生变化,需要重要将rec赋值给shp.mask 删除遮罩的方法 sprite ...

  5. Egret Engine 2D - 矢量绘图

      绘制矩形 drawRect 绘制矩形边 lineStyle( 10, 0x00ff00 清空绘图 clear 绘制园形 drawCircle 绘制直线 moveTo lineTo 绘制曲线 cur ...

  6. Egret初体验–躲避类小游戏

    下面简单介绍一下我这个游戏:基本上就3个画面(准备再添加一个胜利的界面)开始画面,一个按钮,点击进入游戏游戏画面,滚动的背景,触摸移动的老鹰,从天而降的翔,以及右上角的时间条结束画面,显示结果,关注按 ...

  7. Egret官方案例学习笔记

    1.资源记载方式 (1)Egret引擎是2.0.5. (2)resource/resource.json文件是: { "resources": [ { "name&quo ...

  8. Egret 纹理、计时器

    1. 九宫切 典型例子就是圆角矩形的拉伸问题. 先去P一张绿色的圆角矩形. private createGameScene():void { var box:egret.Bitmap = new eg ...

  9. Egret学习笔记 (Egret打飞机-9.子弹对敌机和主角的碰撞)

    运行起来,虽然主角飞机和敌机都在互相发射子弹,但是子弹打中了就和没打中效果是一样的.. 这一章我们就来处理子弹和飞机的碰撞问题. 我们所有的操作都是基于Main这个容器来做的.所以我就把这个处理放到M ...

随机推荐

  1. 从cpu加电到加载OS内核的详细过程(清华大学ucore-lab1总结一)

    结合最近学习清华的OS课,先用“人话”来高度抽象的描述一下我自己的理解.CPU在系统加电也就是我们按下电源开关后,开始初始化他的寄存器,主要是cs和eip(本文基于x86架构),然后在ROM中找到一个 ...

  2. Mac下Intellij IDea发布Java Web项目(适合第一次配置Tomcat的家伙们)详解二

    准备工作:新建第一个JavaWeb项目 step3 给第一次配置tomcat的家伙们再说一遍如何配置tomcat 3.1 [Run]-[Edit Configurations] 3.2 [Defaul ...

  3. 【最短路】埃雷萨拉斯寻宝(eldrethalas) 解题报告

    问题来源 BYVoid魔兽世界模拟赛 [问题描述] 一万两千年前,当精灵还是在艾萨拉女王的统治下的时候,辛德拉就是是女王手下一名很有地位的法师了.他受任建造了一座城市,来保存女王的法师们进行魔法研究的 ...

  4. UVALIVE 5893 计算几何+搜索

    题意:很复杂的题意,我描述不清楚. 题目链接:http://acm.bnu.edu.cn/bnuoj/contest_show.php?cid=3033#problem/33526 大致是,给定一个起 ...

  5. ISAP 简介

    刘汝佳的蓝书上已经给出了大部分,先给上完整代码(以草地排水为例). #include<iostream> #include<algorithm> #include<cst ...

  6. Java 判断一段网络资源是否存在

    package cn.ycmedia.common.utils; import java.io.InputStream; import java.net.URL; import java.net.UR ...

  7. Linux的进程优先级-邹立巍

    http://liwei.life/2016/04/07/linux%E7%9A%84%E8%BF%9B%E7%A8%8B%E4%BC%98%E5%85%88%E7%BA%A7/

  8. [转] Linux文件系统之hard link&symbol link

    这个图很清楚的表示出硬链接和软链接的方式. 1.硬链接: 基本定义:硬链接是有着相同inode号的仅文件名不同的文件(该文件名包含路径信息). 理解:如图,hard link和原始file通过同一个i ...

  9. Android(java)学习笔记222:开发一个多界面的应用程序之不同界面间互相传递数据(短信助手案例的优化:请求码和结果码)

    1.开启界面获取返回值 (1)采用一种特殊的方式开启Activity:               startActivityForResult(intent , 0): (2)在被开启的Activi ...

  10. Bernese安装及使用

    一.安装: 伯尔尼软件的安装很简单,但是在64位下,可能perl解释器安装不成功,我找了一个,并且可用,下载地址: 链接:http://pan.baidu.com/s/1hr8fgEC 密码:fj8b ...