mirror of
https://github.com/sourcegit-scm/sourcegit.git
synced 2024-12-24 20:57:19 -08:00
refactor: use the same control between image preview view and image diff view
This commit is contained in:
parent
45b93a117e
commit
dbce8eebde
3 changed files with 14 additions and 93 deletions
|
@ -28,9 +28,9 @@
|
||||||
<TextBlock Classes="monospace" Text="{DynamicResource Text.Diff.Binary.Old}" Margin="8,0" FontSize="10"/>
|
<TextBlock Classes="monospace" Text="{DynamicResource Text.Diff.Binary.Old}" Margin="8,0" FontSize="10"/>
|
||||||
</Border>
|
</Border>
|
||||||
|
|
||||||
<TextBlock Grid.Column="1" Classes="monospace" Text="{Binding OldImageSize}" Margin="8,0,0,0"/>
|
<TextBlock Classes="monospace" Text="{Binding OldImageSize}" Margin="8,0,0,0"/>
|
||||||
<TextBlock Grid.Column="2" Classes="monospace" Text="{Binding OldFileSize}" Foreground="{DynamicResource Brush.FG2}" Margin="16,0,0,0" HorizontalAlignment="Right"/>
|
<TextBlock Classes="monospace" Text="{Binding OldFileSize}" Foreground="{DynamicResource Brush.FG2}" Margin="16,0,0,0" HorizontalAlignment="Right"/>
|
||||||
<TextBlock Grid.Column="3" Classes="monospace" Text="{DynamicResource Text.Bytes}" Foreground="{DynamicResource Brush.FG2}" Margin="2,0,0,0"/>
|
<TextBlock Classes="monospace" Text="{DynamicResource Text.Bytes}" Foreground="{DynamicResource Brush.FG2}" Margin="2,0,0,0"/>
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
|
|
||||||
<Border Grid.Row="1" Margin="0,12,0,0" Effect="drop-shadow(0 0 8 #A0000000)">
|
<Border Grid.Row="1" Margin="0,12,0,0" Effect="drop-shadow(0 0 8 #A0000000)">
|
||||||
|
@ -51,9 +51,9 @@
|
||||||
<TextBlock Classes="monospace" Text="{DynamicResource Text.Diff.Binary.New}" Margin="8,0" FontSize="10"/>
|
<TextBlock Classes="monospace" Text="{DynamicResource Text.Diff.Binary.New}" Margin="8,0" FontSize="10"/>
|
||||||
</Border>
|
</Border>
|
||||||
|
|
||||||
<TextBlock Grid.Column="1" Classes="monospace" Text="{Binding NewImageSize}" Margin="8,0,0,0"/>
|
<TextBlock Classes="monospace" Text="{Binding NewImageSize}" Margin="8,0,0,0"/>
|
||||||
<TextBlock Grid.Column="2" Classes="monospace" Text="{Binding NewFileSize}" Foreground="{DynamicResource Brush.FG2}" Margin="16,0,0,0" HorizontalAlignment="Right"/>
|
<TextBlock Classes="monospace" Text="{Binding NewFileSize}" Foreground="{DynamicResource Brush.FG2}" Margin="16,0,0,0" HorizontalAlignment="Right"/>
|
||||||
<TextBlock Grid.Column="3" Classes="monospace" Text="{DynamicResource Text.Bytes}" Foreground="{DynamicResource Brush.FG2}" Margin="2,0,0,0"/>
|
<TextBlock Classes="monospace" Text="{DynamicResource Text.Bytes}" Foreground="{DynamicResource Brush.FG2}" Margin="2,0,0,0"/>
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
|
|
||||||
<Border Grid.Row="1" Margin="0,12,0,0" Effect="drop-shadow(0 0 8 #A0000000)">
|
<Border Grid.Row="1" Margin="0,12,0,0" Effect="drop-shadow(0 0 8 #A0000000)">
|
||||||
|
|
|
@ -58,9 +58,14 @@
|
||||||
</DataTemplate>
|
</DataTemplate>
|
||||||
|
|
||||||
<DataTemplate DataType="m:RevisionImageFile">
|
<DataTemplate DataType="m:RevisionImageFile">
|
||||||
<Border Background="{DynamicResource Brush.Window}" Effect="drop-shadow(0 0 8 #A0000000)" Margin="0,8" VerticalAlignment="Center" HorizontalAlignment="Center">
|
<Border Margin="0,8" VerticalAlignment="Center" HorizontalAlignment="Center" Effect="drop-shadow(0 0 8 #A0000000)">
|
||||||
<Border BorderThickness="1" BorderBrush="{DynamicResource Brush.Border1}" Margin="8">
|
<Border Background="{DynamicResource Brush.Window}">
|
||||||
<v:RevisionImageFileView Source="{Binding Image}" RenderOptions.BitmapInterpolationMode="HighQuality"/>
|
<Border BorderThickness="1" BorderBrush="{DynamicResource Brush.Border1}" Margin="8">
|
||||||
|
<Grid>
|
||||||
|
<v:ImageContainer/>
|
||||||
|
<Image Source="{Binding Image}" Stretch="Uniform" VerticalAlignment="Center" RenderOptions.BitmapInterpolationMode="HighQuality"/>
|
||||||
|
</Grid>
|
||||||
|
</Border>
|
||||||
</Border>
|
</Border>
|
||||||
</Border>
|
</Border>
|
||||||
</DataTemplate>
|
</DataTemplate>
|
||||||
|
|
|
@ -164,90 +164,6 @@ namespace SourceGit.Views
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public class RevisionImageFileView : Control
|
|
||||||
{
|
|
||||||
public static readonly StyledProperty<Bitmap> SourceProperty =
|
|
||||||
AvaloniaProperty.Register<RevisionImageFileView, Bitmap>(nameof(Source), null);
|
|
||||||
|
|
||||||
public Bitmap Source
|
|
||||||
{
|
|
||||||
get => GetValue(SourceProperty);
|
|
||||||
set => SetValue(SourceProperty, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
static RevisionImageFileView()
|
|
||||||
{
|
|
||||||
AffectsMeasure<RevisionImageFileView>(SourceProperty);
|
|
||||||
}
|
|
||||||
|
|
||||||
public override void Render(DrawingContext context)
|
|
||||||
{
|
|
||||||
if (_bgBrush == null)
|
|
||||||
{
|
|
||||||
var maskBrush = new SolidColorBrush(ActualThemeVariant == ThemeVariant.Dark ? 0xFF404040 : 0xFFBBBBBB);
|
|
||||||
var bg = new DrawingGroup()
|
|
||||||
{
|
|
||||||
Children =
|
|
||||||
{
|
|
||||||
new GeometryDrawing() { Brush = maskBrush, Geometry = new RectangleGeometry(new Rect(0, 0, 12, 12)) },
|
|
||||||
new GeometryDrawing() { Brush = maskBrush, Geometry = new RectangleGeometry(new Rect(12, 12, 12, 12)) },
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
_bgBrush = new DrawingBrush(bg)
|
|
||||||
{
|
|
||||||
AlignmentX = AlignmentX.Left,
|
|
||||||
AlignmentY = AlignmentY.Top,
|
|
||||||
DestinationRect = new RelativeRect(new Size(24, 24), RelativeUnit.Absolute),
|
|
||||||
Stretch = Stretch.None,
|
|
||||||
TileMode = TileMode.Tile,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
context.FillRectangle(_bgBrush, new Rect(Bounds.Size));
|
|
||||||
|
|
||||||
var source = Source;
|
|
||||||
if (source != null)
|
|
||||||
context.DrawImage(source, new Rect(source.Size), new Rect(8, 8, Bounds.Width - 16, Bounds.Height - 16));
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override void OnPropertyChanged(AvaloniaPropertyChangedEventArgs change)
|
|
||||||
{
|
|
||||||
base.OnPropertyChanged(change);
|
|
||||||
|
|
||||||
if (change.Property.Name == "ActualThemeVariant")
|
|
||||||
{
|
|
||||||
_bgBrush = null;
|
|
||||||
InvalidateVisual();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected override Size MeasureOverride(Size availableSize)
|
|
||||||
{
|
|
||||||
var source = Source;
|
|
||||||
if (source == null)
|
|
||||||
return availableSize;
|
|
||||||
|
|
||||||
var w = availableSize.Width - 16;
|
|
||||||
var h = availableSize.Height - 16;
|
|
||||||
var size = source.Size;
|
|
||||||
if (size.Width <= w)
|
|
||||||
{
|
|
||||||
if (size.Height <= h)
|
|
||||||
return new Size(size.Width + 16, size.Height + 16);
|
|
||||||
else
|
|
||||||
return new Size(h * size.Width / size.Height + 16, availableSize.Height);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
var scale = Math.Max(size.Width / w, size.Height / h);
|
|
||||||
return new Size(size.Width / scale + 16, size.Height / scale + 16);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private DrawingBrush _bgBrush = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
public class RevisionTextFileView : TextEditor
|
public class RevisionTextFileView : TextEditor
|
||||||
{
|
{
|
||||||
protected override Type StyleKeyOverride => typeof(TextEditor);
|
protected override Type StyleKeyOverride => typeof(TextEditor);
|
||||||
|
|
Loading…
Reference in a new issue