背景:#EDF0F5 #FAFBE6 #FFF2E2 #FDE6E0 #F3FFE1 #DAFAF3 #EAEAEF 默认  
阅读内容

创建自己的ProgressBar组件

[日期:2008-05-11] 来源:  作者: [字体: ]

  今天在flash gamer群与一朋友讨论组件的制作,今天在硬盘里翻了翻,找到了几个用mx2004做的组件。

这个是纯as的ProgressBar
as文件

 /** 
* looding bar 

* @作者 章精设(zjs35) 
* @版本 v1 
*/ 
import fc.graphics.draw2d.Rect; 
import fc.graphics.draw2d.GDI; 
import fc.graphics.*; 
import fc.text.DrawString; 
import fc.utils.Delegate; 
import fc.events.EventDispatcher; 
import mx.core.UIObject; 
[Event("complete")] 
[Event("progress")] 
[TagName("ProgressBar")] 
[IconFile("ProgressBar.png")] 
class ProgressBar extends UIObject { 
  private var dispatchEvent:Function; 
  public var addEventListener:Function; 
  public var removeEventListener:Function; 
  private var _bar:GDI; 
  private var _str:DrawString; 
  private var _mc:MovieClip; 
  var _source:Object; 
  var _id:Number; 
  var bar:MovieClip; 
   
  public function ProgressBar() { 
    EventDispatcher.initialize(this); 
  } 
  function get source() { 
    return getSource(); 
  } 
  [Inspectable(defaultvalue="")] 
  function set source(x) { 
    setSource(x); 
  } 
  function getSource(Void) { 
    return _source; 
  } 
  function setSource(val):Void { 
    if (typeof (val) == "string") { 
      val = eval(val); 
    } 
    if (val != null && val != undefined && val != "") { 
      _source = val; 
      //trace([_source, typeof (_source)]); 
      _id = setInterval(this, "setProgress", 80); 
      dispatchEvent({type:"progress", value:0, target:this}); 
    } 
  } 
  function setProgress() { 
    if (!_visible) { 
      _visible = true; 
    } 
    var p1 = _source.getBytesLoaded(); 
    var p2 = _source.getBytesTotal(); 
    var p = fc.math.Num.point(p1/p2, 2)*100; 
    _mc._xscale = p; 
    var s = "加载 "+p+"%"; 
    dispatchEvent({type:"progress", value:p, target:this}); 
    _str.reset(s); 
    if (p>=100) { 
      dispatchEvent({type:"complete", value:_source, target:this}); 
      clearInterval(_id); 
      complete(); 
    } 
  } 
  function complete() { 
    _bar.target = _mc; 
    _bar.clear(); 
    _bar.target = this; 
    _bar.clear(); 
    _str.clear(); 
    init(); 
  } 
  public function init() { 
    super.init(); 
    //width = bar._width; 
    //height = bar._height; 
    bar._visible = false; 
  } 
  function draw() { 
    //loading条的尺寸 
    var _w = __width; 
    var _h = __height; 
    //文本创建 
    _str = new DrawString(); 
    _str.target = this; 
    _str.format(0x333333, "Tahoma", 11); 
    _str.draw("加载 0%"); 
    _str.setXy(_w, (_h-_str.height)/2); 
    _bar = GDI.getInstance(); 
    //背景 
    _bar.target = this; 
    _bar.fill(new SolidBrush(Color.fill, 100), new Rect(0, 0, _w, _h)); 
    _bar.line(new Pen(1, 0x919999, 100), new Rect(0, 0, _w, _h)); 
    _bar.line(new Pen(1, 0xd5dddd, 100), new Rect(2, 2, _w-2, _h-2)); 
    //loading条 
    _mc = this.createEmptyMovieClip("back", this.getNextHighestDepth()); 
    _bar.target = _mc; 
    _bar.fill(new SolidBrush(Color.line, 40), new Rect(2, 2, _w-2, _h-2)); 
    _mc._xscale = 0; 
    //_visible = false; 
  } 
  function size() { 
    super.size(); 
  } 
}

图示

图片如下:

 

图片如下:

阅读:
录入:admin

推荐 】 【 打印
上一篇:平滑播放FLV视频文件
下一篇:Timeline类
相关新闻      
本文评论       全部评论
发表评论
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款


点评: 字数
姓名:
内容查询