Loupe de l'application Windows Store
-
20-12-2019 - |
Question
Je travaille sur une application de dessin pour Windows 8.1 et avait besoin d'un moyen simple d'afficher la zone touchée par l'utilisateur.Évidemment, il est difficile de voir où vous dessinez lorsque vous utilisez votre doigt.Ce que je devais faire était de pouvoir rendre un élément cible sous forme de bitmap et l'afficher à l'utilisateur afin de pouvoir voir où ils dessinent.Ce que je suis venu, c'est dans la réponse ci-dessous.
La solution
Le code est ci-dessous.Pour l'utiliser, ajoutez simplement le contrôle de XAML (ou de manière programmable) où que vous souhaitiez et définissez la propriété cible sur le contrôle que vous souhaitez prévisualiser.
Par exemple, dans mon cas, je dessine au sommet d'un webview, j'ai donc défini la vision Web comme la cible et ajouté la loupe comme un frère de sodage à la WEBVIEW.
public class Magnifier : Grid
{
public Magnifier() : base()
{
this.Canvas = new Canvas();
Border border = new Border();
border.HorizontalAlignment = HorizontalAlignment.Left;
border.VerticalAlignment = VerticalAlignment.Top;
border.Child = this.Canvas;
border.BorderBrush = new SolidColorBrush(Colors.Red);
border.BorderThickness = new Thickness(10);
border.Background = new SolidColorBrush(Colors.Black);
this.Children.Add(border);
this.border = border;
}
public async Task<object> Update(int x, int y)
{
this.Visibility = Visibility.Visible;
// changes the amount of magnification
int magnification = 2;
// render the preview of the target
RenderTargetBitmap bitmap = new RenderTargetBitmap();
await bitmap.RenderAsync(this.Target);
this.Canvas.Width = this.PreviewWidth;
this.Canvas.Height = this.PreviewHeight;
double w = this.PreviewWidth / (2 * magnification);
double h = this.PreviewHeight / (2 * magnification);
ImageBrush brush = new ImageBrush();
brush.ImageSource = bitmap;
double scaleX = this.Target.ActualWidth / this.PreviewWidth;
double scaleY = this.Target.ActualHeight / this.PreviewHeight;
TransformGroup transform = new TransformGroup();
TranslateTransform translate = new TranslateTransform();
translate.X = -(x - w) / scaleX;
translate.Y = -(y - h) / scaleY;
transform.Children.Add(translate);
ScaleTransform scale = new ScaleTransform();
scale.ScaleX = scaleX * magnification;
scale.ScaleY = scaleY * magnification;
transform.Children.Add(scale);
brush.Transform = transform;
Rectangle rect = new Rectangle();
rect.Width = this.PreviewWidth;
rect.Height = this.PreviewHeight;
rect.Fill = brush;
this.Canvas.Children.Clear();
this.Canvas.Children.Add(rect);
Ellipse centerDot = new Ellipse();
centerDot.Width = 6;
centerDot.Height = 6;
centerDot.Fill = new SolidColorBrush(Colors.Red);
Canvas.SetLeft(centerDot, this.PreviewWidth / 2 - 3);
Canvas.SetTop(centerDot, this.PreviewHeight / 2 - 3);
this.Canvas.Children.Add(centerDot);
return null;
}
public Canvas Canvas { get; set; }
public int PreviewWidth { get; set; }
public int PreviewHeight { get; set; }
private Border border = null;
public FrameworkElement Target { get; set; }
}