html5自动抠图api,类似抠图、挖空效果的实现

package  {

import laya.display.Sprite;

import laya.display.Stage;

import laya.utils.HitArea;

/**

* ...

* @author yung

*/

public class LayaAirDemo {

private var red:Sprite;

private var box:Sprite;

public function LayaAirDemo() {

Laya.init(1200, 800);

Laya.stage.bgColor = "#efefef";

Laya.stage.alignH = Stage.ALIGN_CENTER;

Laya.stage.alignV = Stage.ALIGN_MIDDLE;

//绘制一个蓝色方块,不被抠图

var blue:Sprite = new Sprite();

blue.graphics.drawRect(0, 0, 500, 500, "#004080");

blue.pos(150, 150);

blue.size(500, 500);

blue.on("click", this, onClick);

Laya.stage.addChild(blue);

//增加一个容器

box = new Sprite();

//设置容器为画布缓存

box.cacheAs = "bitmap";

box.pos(200, 200);

Laya.stage.addChild(box);

//绘制红色方块

var red:Sprite = new Sprite();

red.graphics.drawRect(0, 0, 500, 500, "#ff0000");

box.addChild(red);

//绘制一个圆形区域,利用叠加模式,抠除上面红色区域

var circle:Sprite = new Sprite();

circle.graphics.drawCircle(0, 0, 50, "#ffff00");

circle.pos(50, 50);

//设置叠加模式

circle.blendMode = "destination-out";

box.addChild(circle);

var area:HitArea = new HitArea();

area.hit.drawRect(0, 0, 500, 500, "#ff0000");

area.unHit.drawCircle(250, 250, 50, "#ff0000");

box.hitArea = area;

box.mouseEnabled = true;

box.on("click", this, onBoxClick);

//绘制黑色区域,不被抠图

var black:Sprite = new Sprite();

black.graphics.drawRect(0, 0, 200, 200, "#000000");

black.pos(250, 250);

Laya.stage.addChild(black);

}

private function onBoxClick():void {

trace("box");

}

private function onClick():void {

trace("blue");

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值