mirror of
https://github.com/sourcegit-scm/sourcegit.git
synced 2024-12-24 20:57:19 -08:00
feature<Launcher>: add ChromeTabShape; new titlebar theme for Launcher
This commit is contained in:
parent
f98b73eaea
commit
7106f3b978
4 changed files with 74 additions and 55 deletions
38
src/Helpers/ChromeTabShape.cs
Normal file
38
src/Helpers/ChromeTabShape.cs
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
using System;
|
||||||
|
using System.Windows;
|
||||||
|
using System.Windows.Media;
|
||||||
|
using System.Windows.Shapes;
|
||||||
|
|
||||||
|
namespace SourceGit.Helpers {
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Chrome like tab shape
|
||||||
|
/// </summary>
|
||||||
|
public class ChromeTabShape : Shape {
|
||||||
|
protected override Geometry DefiningGeometry => MakeGeometry();
|
||||||
|
|
||||||
|
public ChromeTabShape() {
|
||||||
|
Stretch = Stretch.None;
|
||||||
|
StrokeThickness = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
private Geometry MakeGeometry() {
|
||||||
|
var geo = new StreamGeometry();
|
||||||
|
var cornerSize = new Size(4, 4);
|
||||||
|
var cornerAngle = Math.PI / 2;
|
||||||
|
using (var ctx = geo.Open()) {
|
||||||
|
ctx.BeginFigure(new Point(-5.1, ActualHeight), true, true);
|
||||||
|
ctx.ArcTo(new Point(-1.1, ActualHeight - 4), cornerSize, cornerAngle, false, SweepDirection.Counterclockwise, false, true);
|
||||||
|
ctx.LineTo(new Point(-1.1, 4), false, true);
|
||||||
|
ctx.ArcTo(new Point(2.9, 0), cornerSize, cornerAngle, false, SweepDirection.Clockwise, false, true);
|
||||||
|
ctx.LineTo(new Point(ActualWidth - 2.9, 0), false, true);
|
||||||
|
ctx.ArcTo(new Point(ActualWidth + 1.1, 4), cornerSize, cornerAngle, false, SweepDirection.Clockwise, false, true);
|
||||||
|
ctx.LineTo(new Point(ActualWidth + 1.1, ActualHeight - 4), false, true);
|
||||||
|
ctx.ArcTo(new Point(ActualWidth + 5.1, ActualHeight), cornerSize, cornerAngle, false, SweepDirection.Counterclockwise, false, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
geo.Freeze();
|
||||||
|
return geo;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -3,10 +3,10 @@
|
||||||
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
|
||||||
<SolidColorBrush x:Key="Brush.Logo" Color="#FFF05133"/>
|
<SolidColorBrush x:Key="Brush.Logo" Color="#FFF05133"/>
|
||||||
|
|
||||||
<SolidColorBrush x:Key="Brush.TitleBar" Color="#FF303030"/>
|
<SolidColorBrush x:Key="Brush.TitleBar" Color="#FF202020"/>
|
||||||
<SolidColorBrush x:Key="Brush.Window" Color="#FF252525"/>
|
<SolidColorBrush x:Key="Brush.Window" Color="#FF252525"/>
|
||||||
<SolidColorBrush x:Key="Brush.NewPageHover" Color="#FF404040"/>
|
<SolidColorBrush x:Key="Brush.NewPageHover" Color="#FF404040"/>
|
||||||
<SolidColorBrush x:Key="Brush.PageTabHover" Color="#80505050"/>
|
<SolidColorBrush x:Key="Brush.PageTabHover" Color="#FF404040"/>
|
||||||
<SolidColorBrush x:Key="Brush.Popup" Color="#FF252525"/>
|
<SolidColorBrush x:Key="Brush.Popup" Color="#FF252525"/>
|
||||||
<SolidColorBrush x:Key="Brush.Contents" Color="#FF1B1B1B"/>
|
<SolidColorBrush x:Key="Brush.Contents" Color="#FF1B1B1B"/>
|
||||||
<SolidColorBrush x:Key="Brush.Badge" Color="#FF8F8F8F"/>
|
<SolidColorBrush x:Key="Brush.Badge" Color="#FF8F8F8F"/>
|
||||||
|
|
|
@ -6,6 +6,7 @@
|
||||||
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||||
xmlns:source="clr-namespace:SourceGit"
|
xmlns:source="clr-namespace:SourceGit"
|
||||||
xmlns:local="clr-namespace:SourceGit.UI"
|
xmlns:local="clr-namespace:SourceGit.UI"
|
||||||
|
xmlns:helpers="clr-namespace:SourceGit.Helpers"
|
||||||
xmlns:converters="clr-namespace:SourceGit.Converters"
|
xmlns:converters="clr-namespace:SourceGit.Converters"
|
||||||
mc:Ignorable="d"
|
mc:Ignorable="d"
|
||||||
MinWidth="800" MinHeight="600"
|
MinWidth="800" MinHeight="600"
|
||||||
|
@ -37,7 +38,7 @@
|
||||||
</Border.Style>
|
</Border.Style>
|
||||||
|
|
||||||
<!-- Window Content -->
|
<!-- Window Content -->
|
||||||
<Grid Background="{StaticResource Brush.Window}">
|
<Grid>
|
||||||
<Grid.RowDefinitions>
|
<Grid.RowDefinitions>
|
||||||
<RowDefinition Height="32"/>
|
<RowDefinition Height="32"/>
|
||||||
<RowDefinition Height="*"/>
|
<RowDefinition Height="*"/>
|
||||||
|
@ -50,6 +51,12 @@
|
||||||
<ColumnDefinition Width="200"/>
|
<ColumnDefinition Width="200"/>
|
||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
|
|
||||||
|
<Border Grid.Column="0" Grid.ColumnSpan="3" Height="4" VerticalAlignment="Bottom" Margin="0,0,0,-4" Background="{StaticResource Brush.TitleBar}">
|
||||||
|
<Border.Effect>
|
||||||
|
<DropShadowEffect ShadowDepth="1" Direction="90" Opacity=".5" Color="Black"/>
|
||||||
|
</Border.Effect>
|
||||||
|
</Border>
|
||||||
|
|
||||||
<!-- Tabs -->
|
<!-- Tabs -->
|
||||||
<ScrollViewer x:Name="openedTabsScroller" Grid.Column="0" HorizontalScrollBarVisibility="Hidden" VerticalScrollBarVisibility="Disabled" CanContentScroll="True">
|
<ScrollViewer x:Name="openedTabsScroller" Grid.Column="0" HorizontalScrollBarVisibility="Hidden" VerticalScrollBarVisibility="Disabled" CanContentScroll="True">
|
||||||
<TabControl x:Name="openedTabs" Padding="0" SnapsToDevicePixels="True" ItemsSource="{Binding ElementName=me, Path=Tabs}" SizeChanged="OpenedTabsSizeChanged">
|
<TabControl x:Name="openedTabs" Padding="0" SnapsToDevicePixels="True" ItemsSource="{Binding ElementName=me, Path=Tabs}" SizeChanged="OpenedTabsSizeChanged">
|
||||||
|
@ -58,16 +65,16 @@
|
||||||
<Setter Property="Template">
|
<Setter Property="Template">
|
||||||
<Setter.Value>
|
<Setter.Value>
|
||||||
<ControlTemplate TargetType="{x:Type TabControl}">
|
<ControlTemplate TargetType="{x:Type TabControl}">
|
||||||
<StackPanel Orientation="Horizontal" Margin="6,4,4,0">
|
<StackPanel Orientation="Horizontal" Margin="8,4,4,0">
|
||||||
<StackPanel Orientation="Horizontal" IsItemsHost="True" SnapsToDevicePixels="True" KeyboardNavigation.TabIndex="1"/>
|
<StackPanel Orientation="Horizontal" IsItemsHost="True" SnapsToDevicePixels="True" KeyboardNavigation.TabIndex="1"/>
|
||||||
<Button Margin="4,0,0,0" Click="NewTab" ToolTip="NEW PAGE" Width="24" Height="24" WindowChrome.IsHitTestVisibleInChrome="True">
|
<Button Margin="4,0,0,0" Click="NewTab" ToolTip="NEW PAGE" WindowChrome.IsHitTestVisibleInChrome="True">
|
||||||
<Button.Style>
|
<Button.Style>
|
||||||
<Style TargetType="{x:Type Button}" BasedOn="{x:Null}">
|
<Style TargetType="{x:Type Button}" BasedOn="{x:Null}">
|
||||||
<Setter Property="Opacity" Value="1"/>
|
<Setter Property="Opacity" Value="1"/>
|
||||||
<Setter Property="Template">
|
<Setter Property="Template">
|
||||||
<Setter.Value>
|
<Setter.Value>
|
||||||
<ControlTemplate>
|
<ControlTemplate>
|
||||||
<Border x:Name="newTabBG" BorderThickness="0" Background="Transparent" CornerRadius="2">
|
<Border x:Name="newTabBG" Width="20" Height="20" BorderThickness="0" Background="Transparent" CornerRadius="2">
|
||||||
<Path Width="14" Height="14" Style="{StaticResource Style.Icon}" Data="{StaticResource Icon.NewTab}" Fill="{StaticResource Brush.FG1}"/>
|
<Path Width="14" Height="14" Style="{StaticResource Style.Icon}" Data="{StaticResource Icon.NewTab}" Fill="{StaticResource Brush.FG1}"/>
|
||||||
</Border>
|
</Border>
|
||||||
|
|
||||||
|
@ -163,28 +170,21 @@
|
||||||
<Setter Property="Template">
|
<Setter Property="Template">
|
||||||
<Setter.Value>
|
<Setter.Value>
|
||||||
<ControlTemplate TargetType="{x:Type TabItem}">
|
<ControlTemplate TargetType="{x:Type TabItem}">
|
||||||
<Grid SnapsToDevicePixels="True" WindowChrome.IsHitTestVisibleInChrome="True" ToolTip="{Binding Tooltip}">
|
<Grid x:Name="Container" SnapsToDevicePixels="True" WindowChrome.IsHitTestVisibleInChrome="True" ToolTip="{Binding Tooltip}">
|
||||||
<Border x:Name="BG" Margin="-1,0" SnapsToDevicePixels="True" Background="Transparent" CornerRadius="4,4,0,0"/>
|
<helpers:ChromeTabShape
|
||||||
|
x:Name="BG"
|
||||||
|
Width="{Binding ElementName=Container,Path=ActualWidth}"
|
||||||
|
Height="{Binding ElementName=Container,Path=ActualHeight}"
|
||||||
|
Fill="Transparent">
|
||||||
|
<helpers:ChromeTabShape.Effect>
|
||||||
|
<DropShadowEffect ShadowDepth="1" Direction="90" Opacity=".5" Color="Black"/>
|
||||||
|
</helpers:ChromeTabShape.Effect>
|
||||||
|
</helpers:ChromeTabShape>
|
||||||
|
|
||||||
<Path
|
<Border
|
||||||
x:Name="CornerLeft"
|
x:Name="Hover"
|
||||||
Width="6"
|
Margin="-1,0"
|
||||||
Height="6"
|
Background="Transparent"/>
|
||||||
HorizontalAlignment="Left"
|
|
||||||
VerticalAlignment="Bottom"
|
|
||||||
Margin="-6,0,0,0"
|
|
||||||
Data="M 0,6 L 6,6 6,0 C 6,0 6,6 0,6 Z"
|
|
||||||
Fill="Transparent"/>
|
|
||||||
|
|
||||||
<Path
|
|
||||||
x:Name="CornerRight"
|
|
||||||
Width="6"
|
|
||||||
Height="6"
|
|
||||||
HorizontalAlignment="Right"
|
|
||||||
VerticalAlignment="Bottom"
|
|
||||||
Margin="0,0,-6,0"
|
|
||||||
Data="M 0,0 L 0,6 6,6 C 6,6 0,6 0,0 Z"
|
|
||||||
Fill="Transparent"/>
|
|
||||||
|
|
||||||
<ContentPresenter
|
<ContentPresenter
|
||||||
x:Name="ContentSite"
|
x:Name="ContentSite"
|
||||||
|
@ -202,33 +202,13 @@
|
||||||
<ControlTemplate.Triggers>
|
<ControlTemplate.Triggers>
|
||||||
<Trigger Property="IsSelected" Value="True">
|
<Trigger Property="IsSelected" Value="True">
|
||||||
<Setter Property="Panel.ZIndex" Value="2"/>
|
<Setter Property="Panel.ZIndex" Value="2"/>
|
||||||
<Setter TargetName="BG" Property="Background" Value="{StaticResource Brush.Window}"/>
|
<Setter TargetName="BG" Property="Fill" Value="{StaticResource Brush.Window}"/>
|
||||||
<Setter TargetName="CornerLeft" Property="Fill" Value="{StaticResource Brush.Window}"/>
|
|
||||||
<Setter TargetName="CornerRight" Property="Fill" Value="{StaticResource Brush.Window}"/>
|
|
||||||
</Trigger>
|
</Trigger>
|
||||||
|
|
||||||
<Trigger Property="IsSelected" Value="False">
|
<Trigger Property="IsSelected" Value="False">
|
||||||
<Setter Property="Panel.ZIndex" Value="-1"/>
|
<Setter Property="Panel.ZIndex" Value="-1"/>
|
||||||
</Trigger>
|
|
||||||
|
|
||||||
<MultiTrigger>
|
|
||||||
<MultiTrigger.Conditions>
|
|
||||||
<Condition Property="IsSelected" Value="False"/>
|
|
||||||
<Condition Property="IsMouseOver" Value="True"/>
|
|
||||||
</MultiTrigger.Conditions>
|
|
||||||
<Setter Property="Panel.ZIndex" Value="1"/>
|
|
||||||
<Setter TargetName="BG" Property="Background" Value="{StaticResource Brush.PageTabHover}"/>
|
|
||||||
<Setter TargetName="CornerLeft" Property="Fill" Value="{StaticResource Brush.PageTabHover}"/>
|
|
||||||
<Setter TargetName="CornerRight" Property="Fill" Value="{StaticResource Brush.PageTabHover}"/>
|
|
||||||
</MultiTrigger>
|
|
||||||
|
|
||||||
<MultiTrigger>
|
|
||||||
<MultiTrigger.Conditions>
|
|
||||||
<Condition Property="IsSelected" Value="False"/>
|
|
||||||
<Condition Property="IsMouseOver" Value="False"/>
|
|
||||||
</MultiTrigger.Conditions>
|
|
||||||
<Setter TargetName="Splitter" Property="Visibility" Value="Visible"/>
|
<Setter TargetName="Splitter" Property="Visibility" Value="Visible"/>
|
||||||
</MultiTrigger>
|
</Trigger>
|
||||||
</ControlTemplate.Triggers>
|
</ControlTemplate.Triggers>
|
||||||
</ControlTemplate>
|
</ControlTemplate>
|
||||||
</Setter.Value>
|
</Setter.Value>
|
||||||
|
@ -304,7 +284,7 @@
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|
||||||
<!-- Pages -->
|
<!-- Pages -->
|
||||||
<ItemsControl Grid.Row="1" ItemsSource="{Binding ElementName=me, Path=Tabs}">
|
<ItemsControl Grid.Row="1" ItemsSource="{Binding ElementName=me, Path=Tabs}" Background="{StaticResource Brush.Window}">
|
||||||
<ItemsControl.ItemsPanel>
|
<ItemsControl.ItemsPanel>
|
||||||
<ItemsPanelTemplate>
|
<ItemsPanelTemplate>
|
||||||
<Grid/>
|
<Grid/>
|
||||||
|
|
|
@ -10,6 +10,7 @@ using System.Windows;
|
||||||
using System.Windows.Controls;
|
using System.Windows.Controls;
|
||||||
using System.Windows.Input;
|
using System.Windows.Input;
|
||||||
using System.Windows.Media;
|
using System.Windows.Media;
|
||||||
|
using System.Windows.Shapes;
|
||||||
|
|
||||||
namespace SourceGit.UI {
|
namespace SourceGit.UI {
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue