23
2015
01

(五)createjs-Bitmap

看过Text之后,再来看看Bitmap,用js的话,graphic估计会用的很少,大多数时候还是用位图的。

html里边自己的image就挺方便的,canvas处理image也挺方便。这里边没有BitmapDate,和as里不一样,为什么没有,可以看看Canvas的API,本身就提供了对于像素级的处理。LufyLegend里边提供了BitmapDate的封装,不知道createjs以后会不会也提供。

不废话了,直接上代码:

  1. //创建stage,参数为canvas的id

  2.  var stage=new createjs.Stage("gameMain");

  3. createjs.Ticker.setFPS(60);

  4. createjs.Ticker.addEventListener("tick", tick);

  5. function tick(event){

  6.                 stage.update();//需要tick,然后自己update,才能刷新显示。

  7. //stage.tick();//官方API说:A stage is the root level Container for a display list. Each time its tick method is called, it will render its display list to its target canvas.我居然信了,试了试不对,看源码也不是调用tick就能刷新显示。不知道是不是因为我英文太差理解错了。

  8. //console.log(stage.mouseX);//mouseX属性还是一直有值的,不错。

  9.             }


  10.  //创建一个bitmap

  11. //可以是地址,image,canvas元素或者字符串(应该是类似base64的图片字符串),svg暂时不研究.最好不要跨域

  12. //1

  13.     //var base64Img="";

  14.     //var bmp=new createjs.Bitmap(base64Img);

  15. //2

  16. /*

  17. var img=new Image();

  18. img.src="logo.png";

  19. var bmp=new createjs.Bitmap(img);

  20. */

  21. //3

  22. var bmp=new createjs.Bitmap("logo.png");

  23. //设置显示元件的位置

  24. bmp.x=10;

  25. bmp.y=10;

  26. //添加到显示列表

  27. stage.addChild(bmp);

创建Bitmap时,可以传入图片的地址、字符串(比如Base64编码的图片字符串)、Image对象、或者Canvas对象(忘记应该是canvas还是canvas的content了,也懒得试了),一般还是传入Image对象的时候多,先预加载,加载完了创建时直接传入image对象。

其实我最关心的还是怎么Draw,怎么直接处理图片的某个通道,后者某些像素,等等BitmapData里边的方法。

Bitmap里边的Draw方法没有研究,这个估计比较难,涉及的方面也比较多。以后再看,现在先能显示一张位图,就OK了。


点击查看实例

« 上一篇下一篇 »

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。