我在博客上有一篇关于如何制作这个确切组件Here的文章。
您创建一个基本的自定义MXML组件(在这种情况下扩展VBox)。您可以指定一个编程皮肤,这是斜角和渐变被应用的位置。
编程皮肤完成了它在updateDisplayList函数中的绘制。
下面是一些代码(其余是我的博客上,有一个演示)
var g:Graphics = graphics;
var cn:Number = this.getStyle("cornerRadius");
var crtl:Number = this.getStyle("cornerRadiusTopLeft") > 0 ? this.getStyle("cornerRadiusTopLeft") : cn;
var crtr:Number = this.getStyle("cornerRadiusTopRight") > 0 ? this.getStyle("cornerRadiusTopRight") : cn;
var crbl:Number = this.getStyle("cornerRadiusBottomLeft") > 0 ? this.getStyle("cornerRadiusBottomLeft") : cn;
var crbr:Number = this.getStyle("cornerRadiusBottomRight") > 0 ? this.getStyle("cornerRadiusBottomRight") : cn;
var gradFrom:Number = this.getStyle("gradientFrom");
var gradTo:Number = this.getStyle("gradientTo");
var b:EdgeMetrics = borderMetrics;
var w:Number = unscaledWidth - b.left - b.right;
var h:Number = unscaledHeight - b.top - b.bottom;
var m:Matrix = verticalGradientMatrix(0, 0, w, h);
g.clear();
g.beginGradientFill("linear", [gradFrom, gradTo], [1, 1], [0, 255], m);
g.lineStyle(1,borderColor,1,true,LineScaleMode.NORMAL,CapsStyle.ROUND,JointStyle.ROUND);
GraphicsUtil.drawRoundRectComplex(g, b.left, b.top, w, h, crtl, crtr, crbl, crbr);
g.endFill();
}
的演示,看看Here。希望这可以帮助。
非常感谢您! :)我从来没有使用GraphicsUtil,似乎是什么伎俩。 – camurgo 2009-10-05 18:45:54
您不需要GraphicsUtil类。 “drawRoundRectComplex”是图形对象的一个不良记录功能。 http://livedocs.adobe.com/flex/3/html/help.html?content=Drawing_Vector_Graphics_5.html – Glenn 2009-10-05 19:41:10
好点 - 有时Adobe会提供太多的做事方法。这是我的一个旧项目的一些代码 - 我发誓我现在会更好了! - Casp – 2009-10-05 20:22:43