整理一个AS2.0的Graphics类

 

以下是Graphics.as类代码段:
/*
* Name:Graphics.as
* Author:Kinglong
* Email:qiankinglong@hotmail.com
* Date:2004-11-4
* Ver:0.60
*/
class com.klstudio.Graphic* **tends MovieClip {
private var __clr:Number;
private var __mc:MovieClip;
private var __thick:Number;
function Graphics(_mc:MovieClip) {
  if (_mc == undefined || _mc == null) {
   this.__mc = _root;
  } else {
   this.__mc = _mc;
  }
  this.setColor(0x000000);
  this.setThick(1);
}
//设置线框色;
public function setColor(_color:Number):Void {
  this.__clr = _color;
}
//设置线框宽度;
public function setThick(_thick:Number):Void {
  this.__thick = _thick;
}
//画直线;
public function drawLine(_x1:Number, _y1:Number, _x2:Number, _y2:Number, _a:Number):Void {
  if (arguments.length<4) {
   trace("※错误※"+newline+"参数不足!");
  } else {
   if (_a == undefined || _a == null) {
    _a = 100;
   }
   this.__mc.lineStyle(this.__thick, this.__clr, _a);
   this.__mc.moveTo(_x1, _y1);
   this.__mc.lineTo(_x2, _y2);
  }
}
//画矩形;
public function drawRect(_x0:Number, _y0:Number, _w:Number, _h:Number, _a:Number):Void {
  if (arguments.length<4) {
   trace("※错误※"+newline+"参数不足!");
  } else {
   if (_a == undefined || _a == null) {
    _a = 100;
   }
   this.__mc.lineStyle(this.__thick, this.__clr, _a);
   this.__mc.moveTo(_x0, _y0);
   this.__mc.lineTo(_x0+_w, _y0);
   this.__mc.lineTo(_x0+_w, _y0+_h);
   this.__mc.lineTo(_x0, _y0+_h);
   this.__mc.lineTo(_x0, _y0);
  }
}
//填充矩形;
public function fillRect(_x0:Number, _y0:Number, _w:Number, _h:Number, _a:Number):Void {
  if (arguments.length<4) {
   trace("※错误※"+newline+"参数不足!");
  } else {
   if (_a == undefined || _a == null) {
    _a = 100;
   }
   this.__mc.lineStyle();
   this.__mc.moveTo(_x0, _y0);
   this.__mc.beginFill(this.__clr, _a);
   this.__mc.lineTo(_x0+_w, _y0);
   this.__mc.lineTo(_x0+_w, _y0+_h);
   this.__mc.lineTo(_x0, _y0+_h);
   this.__mc.lineTo(_x0, _y0);
   this.__mc.endFill();
  }
}
//画曲线;
public function drawCurve(_sx:Number, _sy:Number, _cx:Number, _cy:Number, _ex:Number, _ey:Number, _a:Number):Void {
  if (arguments.length<6) {
   trace("※错误※"+newline+"参数不足!");
  } else {
   if (_a == undefined || _a == null) {
    _a = 100;
   }
   this.__mc.lineStyle(this.__thick, this.__clr, _a);
   this.__mc.moveTo(_sx, _sy);
   this.__mc.curveTo(_cx, _cy, _ex, _ey);
  }
}
//画椭圆;
function drawOval(_x0:Number, _y0:Number, _w:Number, _h:Number, _a:Number):Void {
  if (arguments.length<4) {
   trace("※错误※"+newline+"参数不足!");
  } else {
   if (_a == undefined || _a == null) {
    _a = 100;
   }
   var j:Number = _w*0.70711;
   var n:Number = _h*0.70711;
   var i:Number = j-(_h-n)*_w/_h;
   var m:Number = n-(_w-j)*_h/_w;
   this.__mc.lineStyle(this.__thick, this.__clr, _a);
   this.__mc.moveTo(_x0+_w, _y0);
   this.__mc.curveTo(_x0+_w, _y0-m, _x0+j, _y0-n);
   this.__mc.curveTo(_x0+i, _y0-_h, _x0, _y0-_h);
   this.__mc.curveTo(_x0-i, _y0-_h, _x0-j, _y0-n);
   this.__mc.curveTo(_x0-_w, _y0-m, _x0-_w, _y0);
   this.__mc.curveTo(_x0-_w, _y0+m, _x0-j, _y0+n);
   this.__mc.curveTo(_x0-i, _y0+_h, _x0, _y0+_h);
   this.__mc.curveTo(_x0+i, _y0+_h, _x0+j, _y0+n);
   this.__mc.curveTo(_x0+_w, _y0+m, _x0+_w, _y0);
  }
}
//填充椭圆;
function fillOval(_x0:Number, _y0:Number, _w:Number, _h:Number, _a:Number):Void {
  if (arguments.length<4) {
   trace("※错误※"+newline+"参数不足!");
  } else {
   if (_a == undefined || _a == null) {
    _a = 100;
   }
   var j:Number = _w*0.70711;
   var n:Number = _h*0.70711;
   var i:Number = j-(_h-n)*_w/_h;
   var m:Number = n-(_w-j)*_h/_w;
   this.__mc.lineStyle();
   this.__mc.moveTo(_x0+_w, _y0);
   this.__mc.beginFill(this.__clr, _a);
   this.__mc.curveTo(_x0+_w, _y0-m, _x0+j, _y0-n);
   this.__mc.curveTo(_x0+i, _y0-_h, _x0, _y0-_h);
   this.__mc.curveTo(_x0-i, _y0-_h, _x0-j, _y0-n);
   this.__mc.curveTo(_x0-_w, _y0-m, _x0-_w, _y0);
   this.__mc.curveTo(_x0-_w, _y0+m, _x0-j, _y0+n);
   this.__mc.curveTo(_x0-i, _y0+_h, _x0, _y0+_h);
   this.__mc.curveTo(_x0+i, _y0+_h, _x0+j, _y0+n);
   this.__mc.curveTo(_x0+_w, _y0+m, _x0+_w, _y0);
   this.__mc.endFill();
  }
}
//画圆形;
function drawCircle(_r:Number, _x0:Number, _y0:Number, _a:Number):Void {
  if (arguments.length<3) {
   trace("※错误※"+newline+"参数不足!");
  } else {
   if (_a == undefined || _a == null) {
    _a = 100;
   }
   this.__mc.lineStyle(this.__thick, this.__clr, _a);
   this.__mc.moveTo(_x0+_r, _y0);
   var _s:Number = Math.tan(22.5*Math.PI/180);
   for (var angle = 45; angle<=360; angle += 45) {
    var endX:Number = _r*Math.cos(angle*Math.PI/180);
    var endY:Number = _r*Math.sin(angle*Math.PI/180);
    var cX:Number = endX+_r*_s*Math.cos((angle-90)*Math.PI/180);
    var cY:Number = endY+_r*_s*Math.sin((angle-90)*Math.PI/180);
    this.__mc.curveTo(cX+_x0, cY+_y0, endX+_x0, endY+_y0);
   }
  }
}
//填充圆形;
function fillCircle(_r:Number, _x0:Number, _y0:Number, _a:Number):Void {
  if (arguments.length<3) {
   trace("※错误※"+newline+"参数不足!");
  } else {
   if (_a == undefined || _a == null) {
    _a = 100;
   }
   this.__mc.lineStyle();
   this.__mc.moveTo(_x0+_r, _y0);
   var _s:Number = Math.tan(22.5*Math.PI/180);
   this.__mc.beginFill(this.__clr, _a);
   for (var angle = 45; angle<=360; angle += 45) {
    var endX:Number = _r*Math.cos(angle*Math.PI/180);
    var endY:Number = _r*Math.sin(angle*Math.PI/180);
    var cX:Number = endX+_r*_s*Math.cos((angle-90)*Math.PI/180);
    var cY:Number = endY+_r*_s*Math.sin((angle-90)*Math.PI/180);
    this.__mc.curveTo(cX+_x0, cY+_y0, endX+_x0, endY+_y0);
   }
   this.__mc.endFill();
  }
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值