当前位置: 首页 > 图文教程 > Flash动画 > ActionScript > Flash AS文本字段的透明度alpha变换

ActionScript
FLASH AS3与网页JS参数值传递的问题
Flash AS3的parameters对象处理网页参数
Flash教程 认识Flash ActionScript的环境
Flash ActionScript编程基础
Flash AS3代码实现鼠标跟随喷枪涂鸦效果
falsh 跨域调用配置
Flash AS3.0 实例教程 喷泉动画特效
AS3 Loader与URLLoader的比较
ColorTransform类调整显示对象的颜色值
Flash AS3 快速制作烟雾动画
Flash AS3 制作文字飞出动画
ActionScript 学习小心得
ActionScript3.0读取网页FlashVars中的参数的问题
通过实例学习AS3.0:案例三
通过实例学习Flash AS3.0:案例四
通过实例学习Flash AS3.0:案例五
通过实例学习Flash AS3.0:案例六
Flash教程:认识Flash ActionScript的环境
Flash as入门(1):认识AS面板
Flash as入门(3):AS基本语法

ActionScript 中的 Flash AS文本字段的透明度alpha变换


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-30   浏览: 216 ::
收藏到网摘: n/a

因为TextField不支持对alpha的变换,因此需要对其进行一些操作,有两种方法:

第一是使用BitmapData去绘制,然后对Bitmap进行操作,这个方法代码量稍微偏多,这里不做赘述。

第二种是使用ColorMatrixFilter过滤器。

//Code:
  1. package com.drore.map.view
  2. {
  3.  import flash.display.Sprite;
  4.  import flash.events.Event;
  5.  import flash.text.TextField;
  6.  import flash.filters.ColorMatrixFilter;
  7.  
  8.  /**
  9.   * 动态生成鼠标提示
  10.   * @author Dada http://www.asflex.cn
  11.   * @version 5.0
  12.   * @copy Drore http://www.drore.com
  13.   */
  14.  public class MouseTip extends Sprite
  15.  {
  16.   private var txtTips:TextField = new TextField();
  17.   public function MouseTip()
  18.   {
  19.    addEventListener(Event.ENTER_FRAME, init);
  20.   }
  21.   private function init(event:Event):void
  22.   {
  23.    removeEventListener(Event.ENTER_FRAME, init);
  24.    txtTips.selectable = false;
  25.    txtTips.tabEnabled = false;
  26.    txtTips.mouseEnabled = false;
  27.    txtTips.cacheAsBitmap = true;
  28.    txtTips.multiline = false;
  29.    //设置滤镜
  30.    txtTips.filters=[new ColorMatrixFilter];
  31.    addChild(txtTips);
  32.   }
  33.   //设置提示文字
  34.   public function setText(txt:String):void
  35.   {
  36.    txtTips.text = txt;
  37.    txtTips.width = txtTips.textWidth + 10;
  38.    drawBg();
  39.   }
  40.   //绘制背景
  41.   private function drawBg():void
  42.   {
  43.    graphics.clear();
  44.    graphics.beginFill(0xF3E789, .8);
  45.    graphics.lineStyle(1, 0xFFFF00);
  46.    graphics.drawRoundRect( -5, -5, txtTips.textWidth + 15, txtTips.textHeight + 15, 10, 10);
  47.    graphics.endFill();
  48.   }
  49.  }
  50.  
  51. }

使用方法:

//Code:
  1. //鼠标提示框
  2. private var mtips:MouseTip = new MouseTip();
  3. mtips.setText("This is a test sentense.");
  4. //使用TweenLite对mtips进行alipa缓动
  5. TweenLite.to(mtips, .3, { alpha:0 } );