Compartilhar via


Popup Placement Behavior

A Popup control displays content in a separate window that floats over an application. You can specify the position of a Popup relative to a control, the mouse, or the screen by using the PlacementTarget, Placement, PlacementRectangle, HorizontalOffset, and VerticalOffset properties. These properties work together to give you flexibility in specifying the position of the Popup.

ObservaçãoObservação:

O ToolTip e ContextMenu classes também definem essas cinco propriedades e se comportam da mesma forma.

Este tópico contém as seguintes seções.

  • Positioning the Popup
  • Definições de termos: A anatomia de um pop-up
  • How the Properties Work Together
  • When the Popup Encounters the Edge of the Screen
  • Tópicos relacionados

Positioning the Popup

The placement of a Popup can be relative to a UIElement or to the entire screen. The following example creates four Popup controls that are relative to a UIElement—in this case, an image. All of the Popup controls have the PlacementTarget property set to image1, but each Popup has a different value for the placement property.

<Canvas Width="200" Height="150">
  <Image Name="image1"
         Canvas.Left="75" 
         Source="Water_lilies.jpg" Height="200" Width="200"/>
  <Popup IsOpen="True" PlacementTarget="{Binding ElementName=image1}"
         Placement="Bottom">
    <TextBlock FontSize="14" Background="LightGreen">Placement=Bottom</TextBlock>

  </Popup>
  <Popup IsOpen="True" PlacementTarget="{Binding ElementName=image1}"
         Placement="Top">
    <TextBlock FontSize="14" Background="LightGreen">Placement=Top</TextBlock>

  </Popup>
  <Popup IsOpen="True" PlacementTarget="{Binding ElementName=image1}"
         Placement="Left">
    <TextBlock FontSize="14" Background="LightGreen">Placement=Left</TextBlock>

  </Popup>
  <Popup IsOpen="True" PlacementTarget="{Binding ElementName=image1}"
         Placement="Right">
    <TextBlock FontSize="14" Background="LightGreen">Placement=Right</TextBlock>

  </Popup>
</Canvas>

The following illustration shows the image and the Popup controls

Image with four Popups

Imagem com quatro controles de pop-up

This simple example demonstrates how to set the PlacementTarget and Placement properties, but by using the PlacementRectangle, HorizontalOffset, and VerticalOffset properties, you have even more control over where the Popup is positioned.

Definições de termos: A anatomia de um pop-up

The following terms are useful in understanding how the PlacementTarget, Placement, PlacementRectangle, HorizontalOffset, and VerticalOffset properties relate to each other and the Popup:

  • Target object

  • Target area

  • Target origin

  • Popup alignment point

These terms provide a convenient way to refer to various aspects of the Popup and the control that it is associated with.

Target Object

The target object is the element that the Popup is associated with. If the PlacementTarget property is set, it specifies the target object. If PlacementTarget is not set, and the Popup has a parent, the parent is the target object. If there is no PlacementTarget value and no parent, there is no target object, and the Popup is positioned relative to the screen.

The following example creates a Popup that is the child of a Canvas. The example does not set the PlacementTarget property on the Popup. The default value for Placement is PlacementMode.Bottom, so the Popup appears below the Canvas.

<Canvas Margin="5" Background="Red" Width="200" Height="150" >

  <Ellipse Canvas.Top="60" Canvas.Left="50"
           Height="85" Width="60" 
           Fill="Black"/>

  <Popup IsOpen="True" >
    <TextBlock Background="LightBlue" FontSize="18">This is a Popup</TextBlock>
  </Popup>
</Canvas>

The following illustration shows that the Popup is positioned relative to the Canvas.

Popup with no PlacementTarget

Controle Popup sem PlacementTarget

The following example creates a Popup that is the child of a Canvas, but this time the PlacementTarget is set to ellipse1, so the popup appears below the Ellipse.

<Canvas Margin="5" Background="Red" Width="200" Height="150" >

  <Ellipse Name="ellipse1"
           Canvas.Top="60" Canvas.Left="50"
           Height="85" Width="60" 
           Fill="Black"/>

  <Popup IsOpen="True" PlacementTarget="{Binding ElementName=ellipse1}">
    <TextBlock Background="LightBlue" FontSize="18">This is a Popup</TextBlock>
  </Popup>
</Canvas>

The following illustration shows that the Popup is positioned relative to the Ellipse.

Popup with PlacementTarget

Pop-up com posicionamento relativo a uma elipse

ObservaçãoObservação:

Para ToolTip, o valor padrão de Placement é Mouse. For ContextMenu, the default value of Placement is MousePoint. These values are explained later, in "How the Properties Work Together."

Target Area

The target area is the area on the screen that the Popup is relative to. In the previous examples, the Popup is aligned with the bounds of the target object, but in some cases, the Popup is aligned to other bounds, even if the Popup has a target object. If the PlacementRectangle property is set, the target area is different than the bounds of the target object.

The following example creates two Canvas objects, each one containing a Rectangle and a Popup. In both cases, the target object for the Popup is the Canvas. The Popup in the first Canvas has the PlacementRectangle set, with its X, Y, Width, and Height properties set to 50, 50, 50, and 100, respectively. The Popup in the second Canvas does not have the PlacementRectangle set. As a result, the first Popup is positioned below the PlacementRectangle and the second Popup is positioned below the Canvas. Each Canvas also contains a Rectangle that has the same bounds as the PlacementRectangle for the first Popup. Note that the PlacementRectangle does not create a visible element in the application; the example creates a Rectangle to represent the PlacementRectangle.

<StackPanel Orientation="Horizontal" Margin="50,50,0,0">

  <Canvas Width="200" Height="200" Background="Red">
    <Rectangle Canvas.Top="50" Canvas.Left="50" 
               Width="50" Height="100"
               Stroke="White" StrokeThickness="3"/>
    <Popup IsOpen="True" PlacementRectangle="50,50,50,100">
      <TextBlock FontSize="14" Background="Yellow"
                 Width="140" TextWrapping="Wrap">
        This is a popup with a PlacementRectangle.
      </TextBlock>
    </Popup>
  </Canvas>

  <Canvas Width="200" Height="200" Background="Red" Margin="30,0,0,0">
    <Rectangle Canvas.Top="50" Canvas.Left="50" 
               Width="50" Height="100"
               Stroke="White" StrokeThickness="3"/>
    <Popup IsOpen="True">
      <TextBlock FontSize="14" Background="Yellow"
                 Width="140" TextWrapping="Wrap">
        This is a popup without a PlacementRectangle.
      </TextBlock>
    </Popup>
  </Canvas>

</StackPanel>

The following illustration shows the result of the preceding example.

Pop-up com e sem PlacementRectangle

Pop-up com e sem PlacementRectangle

Target Origin and Popup Alignment Point

The target origin and popup alignment point are reference points on the target area and popup, respectively, that are used for positioning. You can use the HorizontalOffset and VerticalOffset properties to offset the popup from the target area. The HorizontalOffset and VerticalOffset are relative to the target origin and the popup alignment point. The value of the Placement property determines where the target origin and popup alignment point are located.

O exemplo a seguir cria um Popup e define o HorizontalOffset e VerticalOffset propriedades para 20. The Placement propriedade é conjunto para Bottom (o padrão), então, a origem de destino é o canto inferior esquerdo da área de destino e o ponto de alinhamento de pop-up é o canto superior esquerdo das Popup.

<Canvas Width="200" Height="200" Background="Yellow" Margin="20">
  <Popup IsOpen="True" Placement="Bottom"
         HorizontalOffset="20" VerticalOffset="20">
    <TextBlock FontSize="14" Background="#42F3FD">
      This is a popup.
    </TextBlock>
  </Popup>
</Canvas>

The following illustration shows the result of the preceding example.

Popup with HorizontalOffset and VerticalOffset

Posicionamento de pop-up com ponto de alinhamento de origem de destino

How the Properties Work Together

The values of PlacementTarget, PlacementRectangle, and Placement need to be considered together to figure out the correct target area, target origin, and popup alignment point. For example, if the value of Placement is Mouse, there is no target object, the PlacementRectangle is ignored, and the target area is the bounds of the mouse pointer. On the other hand, if Placement is Bottom, the PlacementTarget or parent determines the target object and PlacementRectangle determines the target area.

The following table describes the target object, target area, target origin, and popup alignment point and indicates whether PlacementTarget and PlacementRectangle are used for each PlacementMode enumeration value.

PlacementMode

Target object

Target area

Target origin

Popup alignment point

Absolute

Não aplicável. PlacementTarget é ignorado.

The screen, or PlacementRectangle if it is set. The PlacementRectangle is relative to the screen.

The top-left corner of the target area.

The top-left corner of the Popup.

AbsolutePoint

Não aplicável. PlacementTarget é ignorado.

The screen, or PlacementRectangle if it is set. The PlacementRectangle is relative to the screen.

The top-left corner of the target area.

The top-left corner of the Popup.

Bottom

PlacementTarget or parent.

The target object, or PlacementRectangle if it is set. The PlacementRectangle is relative to the target object.

The bottom-left corner of the target area.

The top-left corner of the Popup.

Center

PlacementTarget or parent.

The target object, or PlacementRectangle if it is set. The PlacementRectangle is relative to the target object.

The center of the target area.

The center of the Popup.

Custom

PlacementTarget or parent.

The target object, or PlacementRectangle if it is set. The PlacementRectangle is relative to the target object.

Defined by the CustomPopupPlacementCallback.

Defined by the CustomPopupPlacementCallback.

Left

PlacementTarget or parent.

The target object, or PlacementRectangle if it is set. The PlacementRectangle is relative to the target object.

The top-left corner of the target area.

The top-right corner of the Popup.

Mouse

Não aplicável. PlacementTarget é ignorado.

Os limites do ponteiro do mouse. PlacementRectangle é ignorado.

The bottom-left corner of the target area.

The top-left corner of the Popup.

MousePoint

Não aplicável. PlacementTarget é ignorado.

Os limites do ponteiro do mouse. PlacementRectangle é ignorado.

The top-left corner of the target area.

The top-left corner of the Popup.

Relative

PlacementTarget or parent.

The target object, or PlacementRectangle if it is set. The PlacementRectangle is relative to the target object.

The top-left corner of the target area.

The top-left corner of the Popup.

RelativePoint

PlacementTarget or parent.

The target object, or PlacementRectangle if it is set. The PlacementRectangle is relative to the target object.

The top-left corner of the target area.

The top-left corner of the Popup.

Right

PlacementTarget or parent.

The target object, or PlacementRectangle if it is set. The PlacementRectangle is relative to the target object.

The top-right corner of the target area.

The top-left corner of the Popup.

Top

PlacementTarget or parent.

The target object, or PlacementRectangle if it is set. The PlacementRectangle is relative to the target object.

The top-left corner of the target area.

The bottom-left corner of the Popup.

The following illustrations show the Popup, target area, target origin, and popup alignment point for each PlacementMode value. In each figure, the target area is yellow, and the Popup is blue.

Placement is Absolute or AbsolutePoint

Pop-up com posicionamento Absolute ou AbsolutePoint

Placement is Bottom

Pop-up com posicionamento Bottom

Placement is Center

Pop-up com posicionamento Center

Placement is Left

Pop-up com posicionamento Left

Placement is Mouse

Pop-up com posicionamento Mouse

Placement is MousePoint

Pop-up com posicionamento MousePoint

Placement is Relative or RelativePoint

Pop-up com posicionamento Relative ou RelativePoint

Placement is Right

Pop-up com posicionamento Right

Placement is Top

Pop-up com posicionamento Top

When the Popup Encounters the Edge of the Screen

For security reasons, a Popup cannot be hidden by the edge of a screen. One of the following three things happens when the Popup encounters a screen edge:

  • The popup realigns itself along the screen edge that would obscure the Popup.

  • The popup uses a different popup alignment point.

  • The popup uses a different target origin and popup alignment point.

These options are described further later in this section.

The behavior of the Popup when it encounters a screen edge depends on the value of the Placement property and which screen edge the popup encounters. The following table summarizes the behavior when the Popup encounters a screen edge for each PlacementMode value.

PlacementMode

Top edge

Bottom edge

Left edge

Right edge

Absolute

Aligns to the top edge.

Aligns to the bottom edge.

Aligns to the left edge.

Aligns to the right edge.

AbsolutePoint

Aligns to the top edge.

The popup alignment point changes to the bottom-left corner of the Popup.

Aligns to the left edge.

The popup alignment point changes to the top-right corner of the Popup.

Bottom

Aligns to the top edge.

The target origin changes to the top-left corner of the target area and the popup alignment point changes to the bottom-left corner of the Popup.

Aligns to the left edge.

Aligns to the right edge.

Center

Aligns to the top edge.

Aligns to the bottom edge.

Aligns to the left edge.

Aligns to the right edge.

Left

Aligns to the top edge.

Aligns to the bottom edge.

The target origin changes to the top-right corner of the target area and the popup alignment point changes to the top-left corner of the Popup.

Aligns to the right edge.

Mouse

Aligns to the top edge.

The target origin changes to the top-left corner of the target area (the bounds of the mouse pointer) and the popup alignment point changes to the bottom-left corner of the Popup.

Aligns to the left edge.

Aligns to the right edge.

MousePoint

Aligns to the top edge.

The popup alignment point changes to the bottom-left corner of the Popup.

Aligns to the left edge.

The popup alignment point changes to the top-right corner of the popup.

Relative

Aligns to the top edge.

Aligns to the bottom edge.

Aligns to the left edge.

Aligns to the right edge.

RelativePoint

Aligns to the top edge.

The popup alignment point changes to the bottom-left corner of the Popup.

Aligns to the left edge.

The popup alignment point changes to the top-right corner of the popup.

Right

Aligns to the top edge.

Aligns to the bottom edge.

Aligns to the left edge.

The target origin changes to the top-left corner of the target area and the popup alignment point changes to the top-right corner of the Popup.

Top

The target origin changes to the bottom-left corner of the target area and the popup alignment point changes to the top-left corner of the Popup. In effect, this is the same as when Placement is Bottom.

Aligns to the bottom edge.

Aligns to the left edge.

Aligns to the right edge.

Aligning to the Screen Edge

A Popup can align to the edge of the screen by repositioning itself so the entire Popup is visible on the screen. When this occurs, the distance between the target origin and popup alignment point might differ from the values of HorizontalOffset and VerticalOffset. When Placement is Absolute, Center, or Relative, the Popup aligns itself to every screen edge. Por exemplo, suponha que um Popup tem Placement definido como Relative e VerticalOffset definido como 100. Se a borda inferior da tela oculta toda ou parte do Popup, o Popup Reposiciona a mesmo ao longo da borda inferior da tela e a distância vertical entre a origem de destino e pop-up Alinhamento ponto é menor que 100. A ilustração a seguir demonstra isso.

Popup aligns to the edge of the screen

Pop-up alinhado à borda da tela

Changing the Popup Alignment Point

If Placement is AbsolutePoint, RelativePoint, or MousePoint, the popup alignment point changes when the popup encounters the bottom or right screen edge.

The following illustration demonstrates that when the bottom screen edge hides all or part of the Popup, the popup alignment point is the bottom-left corner of the Popup.

Popup encounters bottom edge of the screen and changes the popup alignment point

Novo ponto de alinhamento devido à borda inferior da tela

The following illustration demonstrates that when the Popup is hidden by the right screen edge, the popup alignment point is the top-right corner of the Popup.

Popup encounters right edge of the screen and changes the popup alignment point

Novo ponto de alinhamento de pop-up devido à borda da tela

If the Popup encounters the bottom and right screen edges, the popup alignment point is the bottom-right corner of the Popup.

Changing the Target Origin and Popup Alignment Point

When Placement is Bottom, Left, Mouse, Right, or Top, the target origin and popup alignment point change if a certain screen edge is encountered. The screen edge that causes the position to change depends on the PlacementMode value.

The following illustration demonstrates that when Placement is Bottom and the Popup encounters the bottom screen edge, the target origin is the top-left corner of the target area and the popup alignment point is the bottom-left corner of the Popup.

Placement is Bottom and the popup encounters the bottom edge of the screen

Novo ponto de alinhamento devido à borda inferior da tela

The following illustration demonstrates that when Placement is Left and the Popup encounters the left screen edge, the target origin is the top-right corner of the target area and the popup alignment point is the top-left corner of the Popup.

Placement is Left and the popup encounters the left edge of the screen

Novo ponto de alinhamento devido à borda esquerda da tela

The following illustration demonstrates that when Placement is Right and the Popup encounters the right screen edge, the target origin is the top-left corner of the target area and the popup alignment point is the top-right corner of the Popup.

Placement is Right and the popup encounters the right edge of the screen

Novo ponto de alinhamento devido à borda direita da tela

The following illustration demonstrates that when Placement is Top and the Popup encounters the top screen edge, the target origin is the bottom-left corner of the target area and the popup alignment point is the top-left corner of the Popup.

Placement is Top and the popup encounters the top edge of the screen

Novo ponto de alinhamento devido à borda superior da tela

The following illustration demonstrates that when Placement is Mouse and the Popup encounters the bottom screen edge, the target origin is the top-left corner of the target area (the bounds of the mouse pointer) and the popup alignment point is the bottom-left corner of the Popup.

Placement is Mouse and the popup encounters the bottom edge of the screen

Novo ponto de alinhamento devido à borda da tela perto do mouse

Customizing Popup Placement

You can customize the target origin and popup alignment point by setting the Placement property to Custom. Then define a CustomPopupPlacementCallback delegate that returns a set of possible placement points and primary axes (in order of preference) for the Popup. The point that shows the largest portion of the Popup is selected. The position of the Popup is automatically adjusted if the Popup is hidden by the edge of the screen. Para um exemplo, consulte Como: Specify a Custom Popup Position.

Consulte também

Tarefas

Exemplo de posicionamento de Popup