主要代码:
package {
import flash.display.Sprite;
import flash.events.MouseEvent;
import flash.text.TextField;
import flash.net.URLVariables;
import flash.net.URLRequest;
import flash.events.Event;
import flash.display.BitmapData;
import flash.geom.Rectangle;
import flash.geom.Point;
import flash.display.DisplayObject;
import flash.display.Bitmap;
public class Init extends Sprite {
var rects:Array,
numRects:int = stage.stageWidth / _width,
_width:Number = 20,
_height:Number = 80,
_rotation:int = 0,
_vr:Number = 3;
public function Init() {
init();
}
function init():void
{
rects = new Array();
var bitmap:BitmapData = new slider();
var _point = new Point();
for(var i:int = 0; i < numRects; i++)
{
var _rect = new Rectangle(i * _width, 0, _width, 80);
var smallBD:BitmapData = new BitmapData(_width, 80);
smallBD.copyPixels(bitmap, _rect, _point);
//var d:Bitmap = new Bitmap(smallBD);
var rect:Rect = new Rect(smallBD, _width, _height);
rect.x = i * _width + _width / 2;
addChild(rect);
rects.push(rect);
}
addEventListener(Event.ENTER_FRAME, onEnterFrame);
}
function onEnterFrame(e:Event):void
{
for(var i:int = 0; i < numRects; i++)
{
rects[i].rotationY += _vr;
}
_rotation += _vr;
if(_rotation % 180 == 0)
{
removeEventListener(Event.ENTER_FRAME, onEnterFrame);
}
}
}
}
这是 rect 类:
package {
import flash.display.Sprite;
import flash.utils.ByteArray;
import flash.display.Bitmap;
import flash.display.BitmapData;
public class Rect extends Sprite {
private var bitmap:BitmapData,
_width:Number,
_height:Number;
public function Rect(bitmap:BitmapData, width:Number = 20, height:Number = 80) {
this.bitmap = bitmap;
this._width = width;
this._height = height;
init();
}
function init():void
{
graphics.beginBitmapFill(bitmap, null, true, true);
graphics.drawRect(-_width / 2, 0, _width , _height);
graphics.endFill();
}
}
}
我将导入的图像分成几块,每一块都添加到每个矩形精灵,所以我正在制作旋转效果,但问题是当我制作它时我无法将精灵居中,所以我做了(-_width / 2)
- 技巧将每个精灵按 x 轴居中,然后添加到 x 位置添加_width / 2
,但我无法弄清楚图像变形的原因,您可以通过获取 780 x 80 图像来尝试此代码