在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? apache-flex - 裁剪/剪切 Sprite-LMLPHP
(来源: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;

10-08 11:04