업데이트: 2007년 11월
이 예제에서는 BitmapEffectInput 속성을 사용하여 Image 일부분에 BitmapEffect를 적용하는 방법을 보여 줍니다.
예제
다음 예제에서는 시각적 콘텐츠 일부분에 효과를 적용하는 두 가지 방법을 보여 줍니다.
<Page xmlns="https://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="https://schemas.microsoft.com/winfx/2006/xaml">
<Page.Resources>
<BitmapImage x:Key="sourceImage" UriSource="/images/WaterLilies.jpg"/>
</Page.Resources>
<StackPanel>
<DockPanel>
<StackPanel DockPanel.Dock="Left">
<TextBlock>AreaToApplyEffect=".25,.25,.50,.50"</TextBlock>
<TextBlock>AreaToApplyEffectUnits="RelativeToBoundingBox"</TextBlock>
</StackPanel>
<Image Width="360" Source="{StaticResource sourceImage}" Margin="10" DockPanel.Dock="Left">
<Image.BitmapEffect>
<!-- <BitmapEffectGroup> would go here if you wanted to apply more
then one effect to the TextBox. However, in this example only
one effect is being applied so BitmapEffectGroup does not need
to be included. -->
<!-- Effect to Apply to the Image -->
<EmbossBitmapEffect Relief="0.8" LightAngle="320" />
</Image.BitmapEffect>
<Image.BitmapEffectInput>
<!-- BitmapEffectInput is used to apply the bitmap effect to a specified
region of the visual. When this property is not used, the effect
is applied to the entire visual.
AreaToApplyEffect is a rectangular area in which to apply the effect.
- When AreaToApplyEffectUnits is "Absolute", the rectangle is read as
pixel coordinates within the visual.
- When AreaToApplyEffectUnits is "RelativeToBoundingBox",
the rectangle values are relative to the entire bounding box.
Values range between 0 and 1, where (0,0) is the top-left corner
and (1,1) is the bottom-right corner. -->
<BitmapEffectInput AreaToApplyEffect=".25,.25,.50,.50" AreaToApplyEffectUnits="RelativeToBoundingBox"/>
</Image.BitmapEffectInput>
</Image>
</DockPanel>
<DockPanel>
<StackPanel DockPanel.Dock="Left">
<TextBlock>AreaToApplyEffect="90,66,180,135"</TextBlock>
<TextBlock>AreaToApplyEffectUnits="Absolute"</TextBlock>
</StackPanel>
<Image Width="360" Source="{StaticResource sourceImage}" Margin="10" DockPanel.Dock="Left">
<Image.BitmapEffect>
<!-- <BitmapEffectGroup> would go here if you wanted to apply more
then one effect to the TextBox. However, in this example only
one effect is being applied so BitmapEffectGroup does not need
to be included. -->
<!-- Effect to Apply to the Image -->
<EmbossBitmapEffect Relief="0.8" LightAngle="320" />
</Image.BitmapEffect>
<Image.BitmapEffectInput>
<!-- BitmapEffectInput is used to apply the bitmap effect to a specified
region of the visual. When this property is not used, the effect
is applied to the entire visual.
AreaToApplyEffect is a rectangular area in which to apply the effect.
- When AreaToApplyEffectUnits is "Absolute", the rectangle is read as
pixel coordinates within the visual.
- When AreaToApplyEffectUnits is "RelativeToBoundingBox",
the rectangle values are relative to the entire bounding box.
Values range between 0 and 1, where (0,0) is the top-left corner
and (1,1) is the bottom-left corner. -->
<BitmapEffectInput AreaToApplyEffect="90,66,180,135" AreaToApplyEffectUnits="Absolute"/>
</Image.BitmapEffectInput>
</Image>
</DockPanel>
</StackPanel>
</Page>
다음 그림에서는 이미지 중간에만 적용된 볼록 효과를 보여 줍니다.