2011-08-24 33 views
5

Tengo un proyecto en el que me gustaría poder tener una información sobre herramientas en algún control que incluiría algunos controles como textbox y datepicker. La idea sería tener algún tipo de ventana emergente con gráficos limitados, pero algunos controles pueden interactuar.WPF Tooltip con controles

Sé cómo agregar una información sobre herramientas 'normal' a un control, pero cuando te mueves, la información sobre herramientas desaparece para que no pueda interactuar con ella.

¿Esto es posible? Si es así, ¿cómo y si no, hay alguna alternativa a esto?

Gracias

Respuesta

10

se debe utilizar un Popup en lugar de un Ejemplo ToolTip

. Un Popup se abre cuando el ratón se mueve sobre el TextBox y permanece abierta mientras el ratón está sobre el TextBox o la Popup

<TextBox Name="textBox" 
     Text="Popup On Mouse Over" 
     HorizontalAlignment="Left"/> 
<Popup PlacementTarget="{Binding ElementName=textBox}" 
     Placement="Bottom"> 
    <Popup.IsOpen> 
     <MultiBinding Mode="OneWay" Converter="{StaticResource BooleanOrConverter}"> 
      <Binding Mode="OneWay" ElementName="textBox" Path="IsMouseOver"/> 
      <Binding RelativeSource="{RelativeSource Self}" Path="IsMouseOver" /> 
     </MultiBinding> 
    </Popup.IsOpen> 
    <StackPanel> 
     <TextBox Text="Some Text.."/> 
     <DatePicker/> 
    </StackPanel> 
</Popup> 

IS utiliza un BooleanOrConverter

public class BooleanOrConverter : IMultiValueConverter 
{ 
    public object Convert(object[] values, Type targetType, object parameter, System.Globalization.CultureInfo culture) 
    { 
     foreach (object booleanValue in values) 
     { 
      if (booleanValue is bool == false) 
      { 
       throw new ApplicationException("BooleanOrConverter only accepts boolean as datatype"); 
      } 
      if ((bool)booleanValue == true) 
      { 
       return true; 
      } 
     } 
     return false; 
    } 
    public object[] ConvertBack(object value, Type[] targetTypes, object parameter, System.Globalization.CultureInfo culture) 
    { 
     throw new NotSupportedException(); 
    } 
} 

actualización
Para Haga esto para una celda en DataGrid tiene algunas opciones. Dos de ellos deben agregar Popup dentro de DataTemplates para DataGridTemplateColumn, o puede agregarlo al DataGridCell Template. Aquí hay un ejemplo de lo posterior. Será necesario configurar SelectionMode = "single" y SelectionUnit = "celda" en la DataGrid

<DataGrid SelectionMode="Single" 
      SelectionUnit="Cell" 
      ...> 
    <DataGrid.CellStyle> 
     <Style TargetType="DataGridCell"> 
      <Setter Property="Template"> 
       <Setter.Value> 
        <ControlTemplate TargetType="{x:Type DataGridCell}"> 
         <Grid> 
          <Border BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}" SnapsToDevicePixels="True"> 
           <ContentPresenter SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}"/> 
          </Border> 
          <Popup PlacementTarget="{Binding RelativeSource={RelativeSource TemplatedParent}}" 
            Placement="Right" 
            IsOpen="{Binding RelativeSource={RelativeSource TemplatedParent}, Path=IsSelected}"> 
           <StackPanel> 
            <TextBox Text="Some Text.."/> 
            <DatePicker/> 
           </StackPanel> 
          </Popup> 
         </Grid>         
        </ControlTemplate> 
       </Setter.Value> 
      </Setter> 
     </Style>  
    </DataGrid.CellStyle> 
    <!--...--> 
</DataGrid> 
+0

Se puede hacer esto en un DatagridRow o debería utilizar un TemplateColumn con un bloque de texto en su lugar? –

+0

Claro, ¿cómo quieres que funcione? ¿Cuándo debería ser visible el 'Popup', etc.? –

+0

Quiero abrir la ventana emergente cuando se selecciona una celda. Cuando esto se haga, habrá una pequeña ventana emergente con opciones disponibles. –