package skins { import mx.skins.Border; import mx.utils.ColorUtil; public class AccordionButton extends Border { private var colBackground: uint = 0xFFFFFF; private var colBorder: uint = 0; private var borderThickness: uint = 1; private var borderAlpha: Number = 1; private var backgroundAlpha: Number = 1; private var arrColor: uint = 0xFFFFFF; private var isUp: Boolean = false; override protected function updateDisplayList(unscaledWidth:Number, unscaledHeight:Number):void { graphics.clear(); colBorder= getStyle('borderColor'); arrColor = ColorUtil.adjustBrightness(colBorder, -50); colBackground = getStyle('fillColors')[0]; switch (name) { case "skin": break; case "overSkin": colBackground = getStyle('downFillColors')[0]; case "downSkin": arrColor = getStyle('arrColor'); break; } if (name.indexOf('elected') > 0) { isUp = true; } //drawRoundRect(0, 0, unscaledWidth - 1, unscaledHeight-2, 0, colBackground, backgroundAlpha); with (graphics) { lineStyle(borderThickness, colBorder, borderAlpha); beginFill(colBackground, backgroundAlpha); moveTo(1, unscaledHeight-3); curveTo(0, 0, unscaledHeight-3, 0); lineTo(unscaledWidth-2, 0); lineTo(unscaledWidth - 2, unscaledHeight - 3); lineTo(1, unscaledHeight-3); endFill(); } var cX: Number = unscaledWidth - 8; var cY: Number = unscaledHeight / 2 - 1; with (graphics) { if (isUp) { cY -= 3; lineStyle(2, arrColor, borderAlpha); moveTo(cX - 3, cY + 3); lineTo(cX, cY); lineTo(cX + 3, cY + 3); cY += 4; moveTo(cX - 3, cY + 3); lineTo(cX, cY); lineTo(cX + 3, cY + 3); } else { lineStyle(2, arrColor, borderAlpha); moveTo(cX - 3, cY - 3); lineTo(cX, cY); lineTo(cX + 3, cY - 3); cY += 4; moveTo(cX - 3, cY - 3); lineTo(cX, cY); lineTo(cX + 3, cY - 3); } } } } }