在Flex中如何在Sprite上进行裁剪/剪切?
<?xml version="1.0" encoding="utf-8"?>
<mx:WindowedApplication xmlns:mx="http://www.adobe.com/2006/mxml" layout="vertical" creationComplete="Init()">
<mx:Script>
<![CDATA[
public function Init():void {
var spr:Sprite=new Sprite();
uic.addChild(spr);
uic.graphics.lineStyle(2,0);
uic.graphics.moveTo(22, 22);
uic.graphics.lineTo(2222, 2222);
}
]]>
</mx:Script>
<mx:Panel title="StackOverflow">
<mx:UIComponent width="200" height="200" id="uic"/>
</mx:Panel>
</mx:WindowedApplication>
请注意,lineTo完全离开了UIComponent和Panel。
我该如何裁切/裁剪UIComponent或Sprite或Panel?
(来源:liquidfeline.com)
我意识到我可以将硬编码2222更改为更合理的值,但是我需要一个通用的解决方案,因为实际项目不涉及我可以更改的硬编码值,但可以处理动态数据。
最佳答案
使用口罩。
var mask:Shape = new Shape();
with(mask.graphics)
{
beginFill(0xFFFFFF, 1); // white, opaque
drawRect(0, 0, width, height);
endFill();
}
uic.mask = mask;