Desativando a seleção de texto em DocumentViewer
-
21-08-2019 - |
Pergunta
Pergunta simples. Como você desativar a seleção de texto de DocumentViewer no WPF? Esta é a característica que um documento XPS é exibido pelo espectador e, em seguida, o texto pode ser destacado via mouse. O texto destacado também podem ser copiados mas eu já tenha desativado isso. Eu só não sei como desativar o realce.
Obrigado!
Solução
Nós resolvemos isso, substituindo o ControlTemplate do ScrollViewer incorporado no controle DocumentViewer. Insira o estilo abaixo em "Window.Resources":
<Style TargetType="{x:Type ScrollViewer}" x:Key="CustomScrollPresenter">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type ScrollViewer}">
<Grid Background="{TemplateBinding Panel.Background}">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*" />
<ColumnDefinition Width="Auto" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="*" />
<RowDefinition Height="Auto" />
</Grid.RowDefinitions>
<Rectangle Grid.Column="1" Grid.Row="1" Fill="{DynamicResource {x:Static SystemColors.ControlBrushKey}}" />
<ScrollContentPresenter
PreviewMouseLeftButtonDown="ScrollContentPresenter_PreviewMouseLeftButtonDown"
Grid.Column="0"
Grid.Row="0"
Margin="{TemplateBinding Control.Padding}"
Content="{TemplateBinding ContentControl.Content}"
ContentTemplate="{TemplateBinding ContentControl.ContentTemplate}"
CanContentScroll="{TemplateBinding ScrollViewer.CanContentScroll}" />
<ScrollBar
x:Name="PART_VerticalScrollBar"
Grid.Column="1"
Grid.Row="0"
Minimum="0"
Maximum="{TemplateBinding ScrollViewer.ScrollableHeight}"
ViewportSize="{TemplateBinding ScrollViewer.ViewportHeight}"
Value="{Binding Path=VerticalOffset, Mode=OneWay, RelativeSource={RelativeSource Mode=TemplatedParent}}"
Visibility="{TemplateBinding ScrollViewer.ComputedVerticalScrollBarVisibility}"
Cursor="Arrow" AutomationProperties.AutomationId="VerticalScrollBar" />
<ScrollBar
x:Name="PART_HorizontalScrollBar"
Orientation="Horizontal" Grid.Column="0" Grid.Row="1" Minimum="0"
Maximum="{TemplateBinding ScrollViewer.ScrollableWidth}" ViewportSize="{TemplateBinding ScrollViewer.ViewportWidth}" Value="{Binding Path=HorizontalOffset, Mode=OneWay, RelativeSource={RelativeSource Mode=TemplatedParent}}" Visibility="{TemplateBinding ScrollViewer.ComputedHorizontalScrollBarVisibility}" Cursor="Arrow" AutomationProperties.AutomationId="HorizontalScrollBar" />
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
Em seguida, substituir o estilo de ScrollViewer com ele na ControlTemplate para DocumentViewer:
<Style
x:Key="MyDVStyleExtend"
BasedOn="{StaticResource {x:Type DocumentViewer}}"
TargetType="{x:Type DocumentViewer}">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="DocumentViewer">
<Border BorderThickness="2,2,2,2"
BorderBrush="SlateBlue" Focusable="False">
<Grid Background="{StaticResource GridBackground}"
KeyboardNavigation.TabNavigation="Local">
<Grid.ColumnDefinitions>
<ColumnDefinition Width ="*"/>
</Grid.ColumnDefinitions>
<ScrollViewer Style="{StaticResource CustomScrollPresenter}" Grid.Column ="0"
CanContentScroll="True"
HorizontalScrollBarVisibility="Auto"
x:Name="PART_ContentHost"
IsTabStop="True"/>
</Grid>
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
Em seguida, crie uma função para o "PreviewMouseLeftButtonDown =" ScrollContentPresenter_PreviewMouseLeftButtonDown "" atributo declarado no estilo CustomScrollPresenter.
private void ScrollContentPresenter_PreviewMouseLeftButtonDown(object sender, MouseButtonEventArgs e)
{
e.Handled = true;
}
Outras dicas
Outra maneira seria adicionar por exemplo um DockPanel:
<DockPanel Name="pnlTouchTaker"
VerticalAlignment="Bottom" HorizontalAlignment="Left"
Background="Transparent">
</DockPanel>
encontra-se "acima" os IT'S DocumentViewer e definir a largura e a altura para a largura real e a altura do conteúdo scrollviewer em e.g. O carregamento da página do evento.
Você pode ter que adicionar lógica adicional, se usar opções de zoom e barra de ferramentas horizontal se torna visível.
Você pode usar IsFocusable = false. Mas a caixa de pesquisa será desativado também ...
Implementar o seguinte código no xaml.cs parte (DocumentViewerInstance x:. Nome da sua DocumentViewer em sua XAML)
DocumentViewerInstance.GetType().GetProperty("IsSelectionEnabled", BindingFlags.Instance | BindingFlags.NonPublic).SetValue(DocumentViewerInstance, false, null);
Você pode usar o IsFocusable=false
ou IsHitTestVisible = false
ou lidar com qualquer evento de pré-visualização (por exemplo, em resposta aceita) para desativar a seleção, mas os hiperlinks não vai funcionar! Se você definir IsSelectionEnabled = false, a seleção será desativada, mas hyperlinks vai funcionar também. (Aviso! IsSelectionEnabled pode ser alterado para o verdadeiro valor depois de definir falsa, então você deve verificar o valor muitas vezes.)