2014-01-29 224 views
1

我試圖顯示一個按鈕下的彈出。保持彈出窗口範圍內

這是它看起來像現在:

enter image description here 但我希望它留在窗口邊框之內,像這樣(以油漆爲例)

enter image description here

這是我頂並在底部聲明彈出式菜單:

<Grid> 
    <Grid.RowDefinitions> 
     <RowDefinition Height="55" /> 
     <RowDefinition Height="35" /> 
    </Grid.RowDefinitions> 

    <Grid x:Name="AdminContainer" Grid.Row="0"> 
     <Grid.ColumnDefinitions> 
      <ColumnDefinition Width="4*" /> 
      <ColumnDefinition Width="10" /> 
      <ColumnDefinition Width="Auto" /> 
     </Grid.ColumnDefinitions> 

     <Border Background="Transparent"> 
      <Viewbox StretchDirection="DownOnly" Stretch="Uniform" Height="35" HorizontalAlignment="Left" Margin="10,0,0,0"> 
       <ContentControl Content="{StaticResource LynxLogo}" Margin="0,5" /> 
      </Viewbox> 
     </Border> 

     <ToggleButton x:Name="AdminOptionsToggleButton" 
         Grid.Column="2" 
         VerticalAlignment="Center" 
         HorizontalAlignment="Stretch" 
         IsChecked="{Binding mainViewModel.OptionsPopupOpen, Mode=TwoWay}" 
         Style="{StaticResource EmptyToggleButtonStyle}" 
         Cursor="Hand"> 

      <Grid x:Name="AdminPanel" HorizontalAlignment="Right" Height="45" 
        VerticalAlignment="Stretch" Margin="0,0,2,0" > 
       <Grid.Style> 
        <Style> 
         <Setter Property="Grid.Background" Value="Transparent"/> 
         <Style.Triggers> 
          <DataTrigger Binding="{Binding RelativeSource={RelativeSource AncestorType=ToggleButton}, Path=IsMouseOver}" Value="True"> 
           <Setter Property="Grid.Background" Value="#FF404040"/> 
          </DataTrigger> 
          <DataTrigger Binding="{Binding RelativeSource={RelativeSource AncestorType=ToggleButton}, Path=IsChecked}" Value="True"> 
           <Setter Property="Grid.Background" Value="#FF353535"/> 
          </DataTrigger> 
         </Style.Triggers> 
        </Style> 
       </Grid.Style> 

       <Grid.ColumnDefinitions> 
        <ColumnDefinition Width="*" /> 
        <ColumnDefinition Width="45" /> 
       </Grid.ColumnDefinitions> 


       <Border Grid.Column="0" Padding="20,0,0,0"> 
        <Grid> 
         <Grid.RowDefinitions> 
          <RowDefinition Height="*" /> 
          <RowDefinition Height="*" /> 
         </Grid.RowDefinitions> 

         <!--Name--> 
         <TextBlock Grid.Row="0" Text="{Binding adminViewModel.Name}" 
            Style="{StaticResource AdminTextBlockStyle}" VerticalAlignment="Bottom" 
            FontSize="16" /> 
         <!--Status--> 
         <TextBlock Grid.Row="1" Text="{Binding adminViewModel.StatusDescription}" 
            Style="{StaticResource AdminTextBlockStyle}" VerticalAlignment="Bottom" 
            FontSize="13" Margin="0,0,0,1" /> 
        </Grid> 
       </Border> 

       <Border Grid.Column="1" HorizontalAlignment="Right" Margin="3"> 
        <Viewbox StretchDirection="DownOnly"> 
         <Image x:Name="ProfilePicture" Source="/Image/ProfilePictures/profile_placeholder.png" /> 
        </Viewbox> 
       </Border> 
      </Grid> 
     </ToggleButton> 
    </Grid> 

    <views:OptionPopup x:Name="OptionsMenu" PlacementTarget="{Binding ElementName=AdminPanel}" 
         Placement="Bottom" 
         MinWidth="{Binding ActualWidth, ElementName=AdminPanel}" 
         MaxWidth="{Binding ActualWidth, ElementName=AdminContainer}" /> 
+0

儘管這將需要[讀好一點] (http://msdn.microsoft.com/en-us/library/bb613596(v=vs.110).aspx)和試驗和錯誤我相信你可以通過設置'Horizo​​ntalOffset'來實現這一點。 –

+1

通過給'PlacementTarget'彈出不會移出屏幕邊界..這是一個內置函數在WPF ..彈出移出當前窗口或出屏幕? – Sankarann

回答

0

您可以組合使用Syst emParameters.PrimaryScreenHeight和Popup的左上角來計算您有多少空間,並將其設置爲Popup內容的MaxHeight和MaxWidth。

1

我固定它通過設置佈局定製:

<views:OptionPopup x:Name="OptionsMenuPopup" 
    PlacementTarget="{Binding ElementName=AdminPanel}" 
    Placement="Custom" 
    MinWidth="{Binding ActualWidth, ElementName=AdminPanel}" 
    MaxWidth="{Binding ActualWidth, ElementName=AdminContainer}" /> 

而且在我的用戶的代碼構造函數後面我加

OptionsMenuPopup.CustomPopupPlacementCallback += (Size popupSize, Size targetSize, Point offset) => 
      new[] { new CustomPopupPlacement() { Point = new Point(targetSize.Width - popupSize.Width, targetSize.Height) } };