1. 九宫切

  典型例子就是圆角矩形的拉伸问题。

  先去P一张绿色的圆角矩形。

    private createGameScene():void {
var box:egret.Bitmap = new egret.Bitmap();
box.texture = RES.getRes("box_png");
//拉伸
box.width *= 2; //矢量绘图是 Shape/Sprite 的 graphics 有的功能,才有自身的 width/height 与 所绘图形的 width/height
this.addChild(box); var box9:egret.Bitmap = new egret.Bitmap(RES.getRes("box_png"));
var rect9:egret.Rectangle = new egret.Rectangle(40, 40, 80, 80);
box9.scale9Grid = rect9;
box9.width *= 2;
box9.y = 200;
this.addChild(box9);
}

  看下两者的区别:

2. 纹理集

  • 不用每次为一张图片执行一次HTTP请求;
  • 引擎渲染时减少IO的次数;

  主要是在配置与资源调用上进行微调即可:

  • 合图并生成 json 配置文件;
  • 资源类型为 sheet: {"name":"dogs","type":"sheet","url":"assets/dogs.json"}
  • 调用时:RES.getRes( "dogs.dog1" )

 3. Timer

class myTimer extends egret.DisplayObjectContainer
{
public constructor()
{
super();
var timer:egret.Timer = new egret.Timer(500, 5); //500ms执行1次,一共执行5次
timer.addEventListener(egret.TimerEvent.TIMER, ()=>{
myTimer.count ++;
console.log("count:" + myTimer.count);
}, this);
timer.addEventListener(egret.TimerEvent.TIMER_COMPLETE, ()=>{ console.log("end")}, this);
timer.start();
} public static count:number = 0;
}

4. Tick: 

    private createGameScene():void {
var heroTicks = new startTickerTest(); //要添加到舞台才会触发 egret.Event.ADDED_TO_STAGE 事件,但 Main 这个容器是由 egret 自己添加到舞台的,看不到 addChild
this.addChild(heroTicks);
}
class startTickerTest extends egret.DisplayObjectContainer {
public constructor() {
super(); //容器被添加到舞台显示列表时调用
this.once(egret.Event.ADDED_TO_STAGE, this.onLoad, this);
} private hero:egret.Bitmap;
private speed:number = 0.05;
private time:number = 0; private onLoad(event:egret.Event) {
var hero:egret.Bitmap = new egret.Bitmap(RES.getRes("hero1_png"));
this.addChild(hero);
this.hero = hero;
this.time = egret.getTimer();
//不与帧率挂钩的每秒60次回调
egret.startTick(this.moveStar, this);
} //egret 在执行 startTick 的回调时,会给予参数 timeStamp(当前时间戳)
private moveStar(timeStamp:number):boolean {
var now = timeStamp;
var time = this.time;
var pass = now - time; //平均时间间隔=1000ms/60=16.67ms
console.log("moveStar: ",(1000 / pass).toFixed(5));
this.hero.x += this.speed * pass;
if(this.hero.x >= 300)
egret.stopTick(this.moveStar, this);
this.time = now;
return false;
}
}

5. 帧事件:

    private createGameScene():void {
var heroTicks = new startTickerTest();
this.addChild(heroTicks);
}
class startTickerTest extends egret.DisplayObjectContainer {
public constructor() {
super();
this.once(egret.Event.ADDED_TO_STAGE,this.onLoad,this);
} private hero:egret.Bitmap;
private timeOnEnterFrame:number = 0;
private speed:number = 0.5; private onLoad(event:egret.Event) {
var hero:egret.Bitmap = new egret.Bitmap(RES.getRes("hero1_png"));
this.addChild(hero);
this.hero = hero;
//监听帧事件
this.addEventListener(egret.Event.ENTER_FRAME,this.onEnterFrame,this);
this.timeOnEnterFrame = egret.getTimer();
} private onEnterFrame(e:egret.Event){
var now = egret.getTimer();
var time = this.timeOnEnterFrame;
var pass = now - time;
console.log("onEnterFrame: ", (1000 / pass).toFixed(5));
this.hero.x += this.speed * pass;
if(this.hero.x > 300)
this.removeEventListener(egret.Event.ENTER_FRAME,this.onEnterFrame,this);
this.timeOnEnterFrame = egret.getTimer();
}
}

  基础构成看的差不多了,剩下的知识在实际项目应用中边学边用了!

Egret 纹理、计时器的更多相关文章

  1. egret -纹理集的制作

    1. 理集的使用 :http://www.codeandweb.com/ 下载软件: TexturePackergithub: 相关工具:https://github.com/ping-chen/eg ...

  2. Egret自定义计时器(TimerManager和Laya.timer)

    一 自定义计时器 因为游戏中经常用到计时器,比如每1秒发射一枚子弹啊,每2秒怪物AI自动转向啊 每次去new Timer 然后addEventListener(egret.TimerEvent...  ...

  3. Egret 位图,纹理,添加背景 学习

    1,重新设置舞台大小,可以直接到VS中的 "解决方案"中,找到 launcher->egret_loader.js中,找到setDesignSize方法,修改其中大小即可:有 ...

  4. egret之纹理填充模式(上下填充)

    首先,我们准备两张图片,一张作为背景“瓶子”,一张作位填充物“饮料”. 在皮肤里我们设置右边图片的填充模式为“repeat”,修改Y的缩放为:-1.,调整图片位置使之与地图重合,如下: 现在,我们可以 ...

  5. Egret引擎随学随机

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

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

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

  7. Egret官方案例学习笔记

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

  8. [Egret]长按图片分享、分享图片、本地存储

    egret 分享有API可以把一个显示对象树渲染成一个位图纹理,我把它赋值给 HTML 的 Image 元素,就实现了图片的显示,在微信中,通过长按图片可以分享出去.当然在其他浏览器可以保存在本地. ...

  9. Egret中使用P2物理引擎

    游戏中的对象按照物理规律移动,体现重力.引力.反作用力.加速度等物体特性,实现自由落体.摇摆运动.抛物线运动,以及物理碰撞现象的模拟.用于模拟物理碰撞.物理运动的引擎称为物理引擎. 来自瑞典斯德哥尔摩 ...

随机推荐

  1. memcache基本讲解

    Memcached技术 介绍: memcached是一种缓存技术, 他可以把你的数据放入内存,从而通过内存访问提速,因为内存最快的, memcached技术的主要目的提速, 在memachec 中维护 ...

  2. [notes] ImageNet Classification with Deep Convolutional Neual Network

    Paper: ImageNet Classification with Deep Convolutional Neual Network Achievements: The model address ...

  3. Linux内核中SPI/I2c子系统剖析

    Linux内核中,SPI和I2C两个子系统的软件架构是一致的,且Linux内核的驱动模型都以bus,driver,device三种抽象对象为基本元素构建起来.下文的分析将主要用这三种抽象对象的创建过程 ...

  4. [RxJS] Transformation operator: scan

    All of the combination operators take two or more observables as input. These operators may also be ...

  5. qt 状态栏

    有段时间没有写过博客了.假期去上海旅游,所以一直没有能够上网.现在又来到这里,开始新的篇章吧!   今天的内容主要还是继续完善前面的那个程序.我们要为我们的程序加上一个状态栏.   状态栏位于主窗口的 ...

  6. [转] 怎样在Ubuntu 14.04中搭建gitolite git服务器

    相比gitosis,gitolite的功能更为强大,支持对权限的细分控制,学习一下在最新版 的ubuntu 14.04 LTS中搭建gitolite服务器是非常有必要的,嘿嘿,一会属于我们自己的Git ...

  7. Java基础知识强化09:String、StringBuffer和StringBuilder使用

    1. 对于三者使用的总结: (1).如果要操作少量的数据用 = String               (2).单线程操作字符串缓冲区下操作大量数据 = StringBuilder (3).多线程操 ...

  8. 移动端 设置 小于12px 字体 初探

    1.移动端字号规范 2. 百度字号调研 3. 绕过12px 限制 4. 缩放 5. chrome  字号

  9. oracle过滤分割字符串自定义函数

    该函数实现过滤前后的指定的字符串,诸如过滤分隔符等.可用于过滤字符串中的逗号分割符.特别说明:substr()函数支持从字符串倒数开始读取,例如: dbms_output.put_line( subs ...

  10. 别人走的路--uap

    首先,我先谈谈我个人的经历,我今年34岁了,做了10多年的ERP实施顾问,大学刚毕业的时候是做ERP软件开发的,后来转岗做了实施顾问.根据我的个人经验,我给你几点建议.1.既然是很大的公司,那么ERP ...