package
{
import com.tweener.transitions.Tweener; import flash.display.Bitmap;
import flash.display.BitmapData;
import flash.display.Sprite;
import flash.events.MouseEvent;
import flash.geom.PerspectiveProjection;
import flash.geom.Point;
import flash.utils.getDefinitionByName;
import flash.utils.setTimeout; /**
* @author Frost.Yen
* @E-mail 871979853@qq.com
* @create 2015-7-29 下午4:53:03
*
*/
[SWF(width="1024",height="768",backgroundColor = "0x000000")]
public class FlipCard extends Sprite
{
[Embed(source="card.png")]
private var _card:Class;
[Embed(source="back.jpg")]
private var _back:Class;
public function FlipCard()
{
initViews();
}
private function initViews():void
{
var cardClass:Class = getDefinitionByName("FlipCard__card") as Class;
var backClass:Class = getDefinitionByName("FlipCard__back") as Class;
var cardBitmap:Bitmap = new cardClass();
var backBitmap:Bitmap = new backClass(); for(var i:int = 0;i<18;i++){
var card:Card = new Card();
var backBmp:Bitmap = new Bitmap();
var cardBmp:Bitmap = new Bitmap();
var backBmpd:BitmapData = new BitmapData(backBitmap.width,backBitmap.height);
var cardBmpd:BitmapData = new BitmapData(cardBitmap.width,cardBitmap.height);
backBmpd.draw(backBitmap);
cardBmpd.draw(cardBitmap);
backBmp.bitmapData = backBmpd;
cardBmp.bitmapData = cardBmpd;
cardBmp.width = backBmp.width = 79;
cardBmp.height = backBmp.height = 115;
card.getCard(cardBmp,backBmp);
card.x = 200 + i%6*110+79*0.5;
card.y = 100 + Math.floor(i/6)*140+115*0.5;
this.addChild(card);
var perspective:PerspectiveProjection = new PerspectiveProjection();
perspective.projectionCenter = new Point(card.x,card.y)
card.transform.perspectiveProjection = perspective;
}
setTimeout(turnTheCard,1000*2);
}
private function onCardClick(e:MouseEvent):void
{
turnTween(e.currentTarget as Card);
}
private function turnTheCard():void
{
for(var i:int = 0;i<this.numChildren;i++){
turnTween(this.getChildAt(i) as Card);
this.getChildAt(i).addEventListener(MouseEvent.CLICK,onCardClick);
}
}
private function turnTween(card:Card):void
{
Tweener.addTween(card,{rotationY:90,time:0.3,transition:"linear",onComplete:onComplete,onCompleteParams:[card]});
function onComplete(obj:Card):void
{
obj.swapCard();
Tweener.addTween(obj,{rotationY:180,time:0.3,transition:"linear",onComplete:function():void{obj.rotationY = 0;obj.setRotationY();}});
}
}
}
}
import flash.display.Bitmap;
import flash.display.Sprite; class Card extends Sprite{
private var _back:Sprite;
private var _card:Sprite;
private var _rotationY:Number;
public function Card(){
_back = new Sprite();
_card = new Sprite();
this.addChild(_back);
this.addChild(_card);
}
public function getCard(card:Bitmap,back:Bitmap):void
{
card.x = back.x = -back.width*0.5;
card.y = back.y = -back.height*0.5;
_card.addChild(card);
_back.addChild(back);
} public function swapCard():void
{
this.swapChildren(_card,_back);
setRotationY();
}
public function setRotationY():void
{
if(this.rotationY == 90){
_card.rotationY = _back.rotationY = 180;
}else if(this.rotationY == 0){
_card.rotationY = _back.rotationY = 0;
}
}
}

[ActionScript 3.0] 翻牌效果,运用语法rotationY,PerspectiveProjection的更多相关文章

  1. [ActionScript 3.0] 喷泉效果

    pall为水珠影片剪辑 var count:int = 500; var zl:Number = 0.5; var balls:Array; balls = new Array(); for (var ...

  2. [ActionScript 3.0] 幻灯片效果实例

    package com.fylibs.components.effects { import com.fylibs.utils.LoaderQueues; import com.tweener.tra ...

  3. [ActionScript 3.0] 正则表达式

    正则表达式: 正则表达式最早是由数学家Stephen Kleene在对自然语言的递增研究成果的基础上,于1956提出来的.具有完整语法的正则表达式,主要使用在字符串的格式的匹配方面上,后来也逐渐应用到 ...

  4. ActionScript 3.0入门:Hello World、文件读写、数据存储(SharedObject)、与JS互调

    近期项目中可能要用到Flash存取数据,并与JS互调,所以就看了一下ActionScript 3.0,现把学习结果分享一下,希望对新手有帮助. 目录 ActionScript 3.0简介 Hello ...

  5. [转]ActionScript 3.0入门:Hello World、文件读写、数据存储(SharedObject)、与JS互调

    本文转自:http://www.cnblogs.com/artwl/p/3396330.html 近期项目中可能要用到Flash存取数据,并与JS互调,所以就看了一下ActionScript 3.0, ...

  6. css3之3D翻牌效果

      最近一直在学css3,发现他真的是越来越牛逼.现在的css3已经不在是以前的css了,它能做出的功能效果是我们没法想象的了.它可以实现flash,可以制作一些js能做出来的效果,还可以写出ps做出 ...

  7. Cocos2d-x实现简单的翻牌效果

    触发器互联网影响找了很多.有自己的点重写一个复杂的sprite类来实现.简单的操作来对引擎的使用CCOrbitCamera实现,但是,也存在一些问题,后变反了. 我在用的仅仅是一个简单的翻牌效果,点击 ...

  8. css3 翻牌效果

    <!DOCTYPE html> <head> <meta http-equiv="Content-Type" content="text/h ...

  9. HTML5 CSS3专题 诱人的实例 CSS3打造百度贴吧的3D翻牌效果

    首先感谢w3cfuns的老师~ 今天给大家带来一个CSS3制作的翻牌效果,就是鼠标移到元素上,感觉可以看到元素背后的信息.大家如果制作考验记忆力的连连看.扑克类的游戏神马的,甚至给女朋友写一些话语,放 ...

随机推荐

  1. SSH(安全协议外壳)介绍及Linux SSH免密登录

    SSH(安全外壳协议) SSH 为 Secure Shell 的缩写,是一种网络安全协议,专为远程登录会话和其他网络服务提供安全性的协议.通过使用 SSH,可以把传输的数据进行加密,有效防止远程管理过 ...

  2. [poj2104]kth-number(归并树求区间第k大)

    复杂度:$O(nlog^3n)$ #include<cstdio> #include<cstring> #include<algorithm> #include&l ...

  3. 对加密的了解(DES/3DES/AES区别 )

    DES 1977年1月,美国政府颁布:采纳IBM公司设计的方案作为非机密数据的正式. 目前在国内,随着三金工程尤其是金卡工程的启动,DES算法在POS.ATM.磁卡及智能卡(IC卡).加油站.高速公路 ...

  4. 小程序开发运营必看:微信小程序平台运营规范

    一.原则及相关说明 ​ 微信最核心的价值,就是连接——提供一对一.一对多和多对多的连接方式,从而实现人与人.人与智能终端.人与社交化娱乐.人与硬件设备的连接,同时连接服务.资讯.商业. ​ 微信团队一 ...

  5. 对图片进行X,Y轴的翻转,黑白色转变

    做完了修改图片的程序.用的Winfrom做的.昨天基本完成,记录一下使用的东西. 首先是将需要加载的图片放入picturebox控件,这里用到了openfiledialog 打开文件对话框 strin ...

  6. 在git bash中使用命令行调用tortoisegit提交代码或查看日志

    Tortoisegit commit / show log命令行 TortoiseGitProc.exe /command:commit TortoiseGitProc.exe /command:lo ...

  7. Smarty配置与实例化

    在smarty文件夹下建立一个test文件夹,test下建立如下: 编辑test.php如下: <?php require('../smarty/Smarty.class.php'); $sma ...

  8. [GO]tcp网络通信和实现

    服务端的代码 package main import ( "net" "fmt" ) func main() { //监听 listener, err := n ...

  9. [GO]字符串的使用

    package main import ( "fmt" "strings" ) func main() { //判断字符串1是否包含字符串2,如果包含则返回tr ...

  10. HDU 6069 Counting Divisors (素数+筛法)

    题意:给定 l,r,k,让你求,其中 l <= r <= 1e12, r-l <= 1e6, k <= 1e7. 析:首先这个题肯定不能暴力,但是给定的区间较小,可以考虑筛选, ...