オーバーライドされた updateDisplayList 関数によって Flex で ColumnChart をカスタマイズすると、凡例の色が表示されなくなりました。下の写真でわかるように:
http://i41.tinypic.com/mim35d.png
私は何かを逃しましたか?
ありがとう。
オーバーライドされた updateDisplayList 関数によって Flex で ColumnChart をカスタマイズすると、凡例の色が表示されなくなりました。下の写真でわかるように:
http://i41.tinypic.com/mim35d.png
私は何かを逃しましたか?
ありがとう。
ソースコードを調べたい場合は、これが私がしたことです。
保護された関数updateDisplayList(unscaledWidth:Number、unscaledHeight:Number):void {super.updateDisplayList(unscaledWidth、unscaledHeight);をオーバーライドします。
var fill:IFill;
var state:String = "";
if (_data is ChartItem && _data.hasOwnProperty('fill'))
{
state = _data.currentState;
fill = _data.fill;
}
else
fill = GraphicsUtilities.fillFromStyle(getStyle('fill'));
var color:uint;
var adjustedRadius:Number = 0;
color = ColorUtil.adjustBrightness2(GraphicsUtilities.colorFromFill(fill),-20);
fill = new SolidColor(color);
adjustedRadius = getStyle('adjustedRadius');
if (!adjustedRadius)
adjustedRadius = 0;
var stroke:IStroke = getStyle("stroke");
var w:Number = stroke ? stroke.weight / 2 : 0;
var rc:Rectangle = new Rectangle(w - adjustedRadius, w - adjustedRadius, width - 2 * w + adjustedRadius * 2, height - 2 * w + adjustedRadius * 2);
var g:Graphics = graphics;
g.clear();
g.moveTo(rc.left,rc.top);
if (stroke)
stroke.apply(g);
if (fill)
fill.begin(g,rc);
g.lineTo(rc.right-5,rc.top);
g.lineTo(rc.right-5,rc.bottom);
g.lineTo(rc.left+5,rc.bottom);
g.lineTo(rc.left+5,rc.top);
if (fill)
fill.end(g);
}
legendMarkerRenderer を使用して、凡例マーカーをフォーマットできます。この記事では、下に向かう方法を示しています: http://livedocs.adobe.com/flex/3/html/help.html?content=charts_formatting_13.html
また、独自の LegendItem を作成して、LegendItem をさらにカスタマイズすることもできます: http://livedocs.adobe.com/flex/3/langref/mx/charts/LegendItem.html
凡例をカスタマイズする例: 凡例 でシリーズを除外する方法 (Flex)