达达首页 | 设计教程 | 辅助工具 | 字体字库 | 素材贴图 | 非 主 流 | PS 笔刷 | 签名模版 | 网页模版 | 达达贴吧
设为首页

加入收藏

联系我们
PhotoShop 教程 | Illustrator 教程 | CorelDraw 教程 | FireWorks 教程 | 3D MAX 教程 | MAYA 教程 | Flash 教程 | After Effects 教程
相关教程
普通教程 分享:Flash制作人物…
普通教程 拼图游戏雏形--分…
普通教程 使用Flash绘制唐老鸭…
普通教程 不用Flash8照样能制…
普通教程 用Flash AS消除位图…
最新更新

不用Flash8照样能…

分享:Flash制作人…

使用Flash绘制唐老…

拼图游戏雏形--…
您现在的位置: 达达派 >> 教程中心 >> FLASH教程 >> 工具篇 >> 教程正文
拼图游戏雏形--分割美女图
作者:佚名 文章来源:网络采集 点击数: 更新时间:2007-5-21 12:54:29
教程录入:猩猩    责任编辑:猩猩  添加到雅虎收藏+
无聊的时候就来把美女分割![由讨厌原创==>无聊+乱整]

能把一张图片分割成若干份,份数由输入数字自由决定。分割后自动随机打乱位置,可以拖到,拖到到正确位置自动吸附,并不允许再抛动。基本能算一个拼图游戏的雏形了吧。但整到这里就不想整了。能用右键加载自己的图片。以下是无聊的代码:
import flash.net.FileReference;
import flash.display.BitmapData;
import flash.geom.Matrix;
/////////////////////////////////
var img_bmp:BitmapData = new BitmapData(mc._width, mc._height);
var txt_fmt:TextFormat = new TextFormat();
txt_fmt.color = 0xff00ff;
txt_fmt.size = 22;
txt_fmt.font = "华文新魏";
/////////////////////
for (var d:Number = 2; d>0; d--) {
this.createTextField("wh_txt"+d, 9000+d, d*100, 20, 50, 26);
this["wh_txt"+d].setNewTextFormat(txt_fmt);
this["wh_txt"+d].border = true;
this["wh_txt"+d].input = true;
this["wh_txt"+d].type = "input";
this["wh_txt"+d].maxChars = 1;
this["wh_txt"+d].restrict("0-9");
this["wh_txt"+d].background = true;
this["wh_txt"+d].borderColor = 0xff9900;
this["wh_txt"+d].backgroundColor = 0x33cccc;
}
Selection.setFocus("wh_txt1");
//////////////////
wh_txt1.onChanged = wh_txt2.onChanged=function () {
if (wh_txt1.text == "") {
  Selection.setFocus("wh_txt1");
} else if (wh_txt2.text == "") {
  Selection.setFocus("wh_txt2");
} else {
  fenge_func(wh_txt1.text, wh_txt2.text);
}
};
////////////////////////
var xwpos:Number = 0;
var yhpos:Number = 0;
function fuwei_func() {
for (var d:Number = xwpos-1; d>=0; d--) {
  for (var c:Number = yhpos-1; c>=0; c--) {
   this["pic_mc"+d+c].removeMovieClip();
  }
}
}
//////
function fenge_func(xw:Number, yh:Number) {
fuwei_func();
xwpos = xw;
yhpos = yh;
img_bmp.draw(mc, new Matrix());
var xy_array:Array = new Array();
var b_num:Number = new Number();
////////////////
for (var d:Number = xw-1; d>=0; d--) {
  for (var c:Number = yh-1; c>=0; c--) {
   this.createEmptyMovieClip("pic_mc"+d+c, 200+d+""+c);
   this["pic_mc"+d+c].lineStyle(1, 0xfff000, 100);
   this["pic_mc"+d+c].beginBitmapFill(img_bmp, new Matrix(), false);
   this["pic_mc"+d+c].moveTo(d*Stage.width/xw, c*Stage.height/yh);
   this["pic_mc"+d+c].lineTo((d+1)*Stage.width/xw, c*Stage.height/yh);
   this["pic_mc"+d+c].lineTo((d+1)*Stage.width/xw, (c+1)*Stage.height/yh);
   this["pic_mc"+d+c].lineTo(d*Stage.width/xw, (c+1)*Stage.height/yh);
   this["pic_mc"+d+c].lineTo(d*Stage.width/xw, c*Stage.height/yh);
   this["pic_mc"+d+c].endFill();
   this["pic_mc"+d+c].obj = new Object();
   this["pic_mc"+d+c].obj = this["pic_mc"+d+c].getBounds(_root);
   this["pic_mc"+d+c].xpos = this["pic_mc"+d+c].obj.xMin;
   this["pic_mc"+d+c].ypos = this["pic_mc"+d+c].obj.yMin;
   ////////////////
   var xy2_array:Array = new Array();
   xy2_array.push(this["pic_mc"+d+c].obj.xMin, this["pic_mc"+d+c].obj.yMin);
   xy_array.push(xy2_array);
   this["pic_mc"+d+c].id = d+""+c;
   //////////////////
   this["pic_mc"+d+c].onPress = function() {
    b_num = this.id;
    this.swapDepths(this._parent.getNextHighestDepth());
    this.startDrag();
   };
  }
}
////////////////
for (var d:Number = xw-1; d>=0; d--) {
  for (var c:Number = yh-1; c>=0; c--) {
   num = Math.floor(Math.random()*xy_array.length);
   this["pic_mc"+d+c]._x = xy_array[num][0]-this["pic_mc"+d+c].xpos;
   this["pic_mc"+d+c]._y = xy_array[num][1]-this["pic_mc"+d+c].ypos;
   xy_array.splice(num, 1);
  }
}
//////////////////
onMouseUp = function () {
  stopDrag();
  if (this["pic_mc"+b_num].hitTest(this["pic_mc"+b_num].xpos+this["pic_mc"+b_num]._width/2, this["pic_mc"+b_num].ypos+this["pic_mc"+b_num]._height/2)) {
   this["pic_mc"+b_num]._x = 0;
   this["pic_mc"+b_num]._y = 0;
   this["pic_mc"+b_num].swapDepths(-this["pic_mc"+b_num].getDepth());
   this["pic_mc"+b_num].enabled = false;
  }
};
////////////
mc._visible = false;
}
/////////////////////////////
var listener:Object = new Object();
////////
var loadpic:MovieClipLoader = new MovieClipLoader();
listener.onLoadInit = function(target:MovieClip) {
target._width = Stage.width;
target._height = Stage.height;
fuwei_func();
wh_txt1.text = "";
wh_txt2.text = "";
Selection.setFocus("wh_txt1");
};
loadpic.addListener(listener);
/////////////////
var fileRef:FileReference = new FileReference();
var allTypes:Array = [];
var 浏览类型:Object = new Object();
浏览类型.description = "浏览类型(*.jpg)";
浏览类型.extension = "*.jpg";
allTypes.push(浏览类型);
listener.onSelect = function(file:FileReference) {
loadpic.loadClip("/"+file.name, mc);
};
fileRef.addListener(listener);
/////////////////////////
var pic_menu:ContextMenu = new ContextMenu();
function browse_func() {
fileRef.browse(allTypes);
}
pic_menu.hideBuiltInItems();
var loadpic_menu:ContextMenuItem = new ContextMenuItem("加载新图片", browse_func);
pic_menu.customItems.push(loadpic_menu);
_root.menu = pic_menu;
swf. fla 下载: 分割图片.rar
  • 上一篇教程: 没有了

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    关于我们 | 帮助(?) | 广告服务 | 版权声明 | 商业合作 | 发展历程 | 联系我们

    Copyright ? 2005-2008 CGFancy.com, All Rights Reserved,达达网络:陕ICP备06010337号

    技术交流:71125455(平面)、545534707(三维),业务合作:71125455