■ ViewportBehavior 엘리먼트의 IsAlwaysOn/IsFullyInViewport/IsInViewport 속성을 사용해 부모 엘리먼트에서 자식 엘리먼트의 진입/이탈 여부를 구하는 방법을 보여준다.
※ 비주얼 스튜디오에서 TestProject(Unpackaged) 모드로 빌드한다.
※ TestProject.csproj 프로젝트 파일에서 WindowsPackageType 태그를 None으로 추가했다.
▶ MainPage.xaml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 |
<?xml version="1.0" encoding="utf-8"?> <Page x:Class="TestProject.MainPage" Name="RootElement" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:mxi="using:Microsoft.Xaml.Interactivity" xmlns:ctwb="using:CommunityToolkit.WinUI.Behaviors" Background="{ThemeResource ApplicationPageBackgroundThemeBrush}" FontFamily="나눔고딕코딩" FontSize="16"> <Grid Margin="10" RowSpacing="10"> <Grid.RowDefinitions> <RowDefinition Height="Auto" /> <RowDefinition Height="*" /> <RowDefinition Height="Auto" /> </Grid.RowDefinitions> <TextBlock Grid.Row="0" HorizontalAlignment="Center" IsHitTestVisible="False" Text="Scroll to see the effect" /> <ScrollViewer Grid.Row="1" BorderThickness="1" BorderBrush="{ThemeResource ControlStrongStrokeColorDefaultBrush}"> <Grid Height="2000"> <Border Width="200" Height="200" Background="{ThemeResource AccentFillColorTertiaryBrush}"> <mxi:Interaction.Behaviors> <ctwb:ViewportBehavior x:Name="viewportBehavior" IsAlwaysOn="True" /> </mxi:Interaction.Behaviors> <Rectangle Width="100" Height="100" Fill="{ThemeResource AccentFillColorDefaultBrush}" /> </Border> </Grid> </ScrollViewer> <StackPanel Grid.Row="2" HorizontalAlignment="Center"> <TextBlock> <Run Text="IsFullyInViewport :" /> <Run FontWeight="SemiBold" Text="{x:Bind viewportBehavior.IsFullyInViewport, Mode=OneWay}" /> </TextBlock> <TextBlock> <Run Text="IsInViewport :" /> <Run FontWeight="SemiBold" Text="{x:Bind viewportBehavior.IsInViewport, Mode=OneWay}" /> </TextBlock> </StackPanel> </Grid> </Page> |