首页--> 计算机--> FLASH教程
 
不到40行代码的填色游戏
http://www.xxqqss.com 学习轻松网 发布日期:2006/10/30 点击量:6369
 
今天一个朋友问我怎么做花纹填充上色,就花点时间给他做了一个。
思路是利用beginBitmapFill画矩形,然后用待填充的图形做mask。
舞台上有两个mc,一个是colors,一个是canvas,另外还有一个描边图形
colors负责选色,canvas里面是多个分离的图形,也就是待填充mc(无需取名)

看一下代码:
//先是定义一个画矩形函数
import flash.display.BitmapData;
import flash.geom.*;
function createRectangle(x:Number, y:Number, w:Number, h:Number, mc:MovieClip) {
        mc.moveTo(x, y);
        mc.lineTo(x+w, y);
        mc.lineTo(x+w, y+h);
        mc.lineTo(x, y+h);
        mc.lineTo(x, y);
        mc.endFill();
}
//然后对canvas的每个mc写onRelease响应
for (i in canvas) {
        if (typeof (canvas[i]) == "movieclip") {
                if (canvas[i].type != "rect") {
                        canvas[i].onRelease = function() {
                                                                                    //如果已经被上色了,就会有一个与之绑定的_mc,再次上色之前,要把这个link_mc删掉
                                if (this.link_mc._name) {
                                        this.link_mc._bmp.dispose();
                                        this.link_mc.removeMovieClip();
                                }
                                                                                     //根据_mc的位置和大小,画一个匹配的矩形,然后进行类型和链接的设置
                                var rect_mc:MovieClip = canvas.createEmptyMovieClip("rect"+canvas.getNextHighestDepth(), canvas.getNextHighestDepth());
                                rect_mc.type = "rect";
                                this.link_mc = rect_mc;
                                rect_mc.bmp = new BitmapData(20, 20, false, 0xFF0000);
                                rect_mc.bmp.draw(select_color_mc);
                                rect_mc.beginBitmapFill(rect_mc.bmp);
                                var r:Object = this.getBounds(canvas);
                                createRectangle(r.xMin, r.yMin, r.xMax-r.xMin, r.yMax-r.yMin, rect_mc);
                                                                                     //最后做一个mask,这样就达到了上色的效果
                                rect_mc.setMask(this);
                        };
                }
        }
}
//对颜色拾取器进行onRelease设定
for (i in colors) {
        if (typeof (colors[i]) == "movieclip") {
                colors[i].onRelease = function() {
                        select_color_mc=this
                };
        }
}
是不是很简单,这就是BitmapData的强大功效啦!

花纹填充.fla

花纹填充.swf

作者:chenlangeer   来源:闪吧


打印】 【关闭
免责声明 :本站刊载此文不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。对本文有任何异议,请发送fiyeadwyv@163.com
【免费游戏赚钱网址导航】(站长QQ:9792414)多站号请误用相同密码 【站长信箱】幸运28交流群号:122287647
游戏赚钱平台
注册地址
企业/个人
企业
 有赚网与蹦蹦网是深度合作关系
企业
手机app端赚钱名称
下载安装后输入邀请码领额外红包
估计日赚收入(亲体验)
下载方式
闪电盒子
邀请码:413270540831
3元
 安卓手机各应用市场(推荐应用宝),苹果手机输入名称查找。
中青看点
邀请码:25741975
2元
趣头条
邀请码:A443657406
1元
 
健康游戏忠告:抵制不良游戏,拒绝盗版游戏;注意自我保护,谨防受骗上当;适度游戏益脑,沉迷游戏伤身;合理安排时间,享受健康生活。
本站声明不参与任何游戏网站经营事宜,如果你和第三方游戏网站产生纠纷事宜请自行协商解决,本站感谢你的支持和理解。
站长QQ:9792414