feat: refactor control bar.
This commit is contained in:
@@ -3,63 +3,59 @@
|
||||
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
||||
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
||||
xmlns:u="https://irihi.tech/ursa"
|
||||
xmlns:viewModels="clr-namespace:Ursa.Demo.ViewModels"
|
||||
x:CompileBindings="True"
|
||||
x:DataType="viewModels:ElasticWrapPanelDemoViewModel"
|
||||
mc:Ignorable="d" d:DesignWidth="800" d:DesignHeight="450"
|
||||
x:Class="Ursa.Demo.Pages.ElasticWrapPanelDemo">
|
||||
<Grid>
|
||||
<DockPanel>
|
||||
<TextBlock Text="一个优化奇怪的WrapPanel" DockPanel.Dock="Top" FontWeight="Bold" />
|
||||
<StackPanel DockPanel.Dock="Top" Orientation="Horizontal">
|
||||
<TextBlock Text="排列方式" VerticalAlignment="Center" />
|
||||
<ComboBox x:Name="CmbOrientation" Width="90" SelectedIndex="1">
|
||||
<Orientation>Vertical</Orientation>
|
||||
<Orientation>Horizontal</Orientation>
|
||||
</ComboBox>
|
||||
<TextBlock Text="水平滚动条" VerticalAlignment="Center" />
|
||||
<ComboBox x:Name="ScrollViewHVisb" Width="90" SelectedIndex="0">
|
||||
<ScrollBarVisibility>Auto</ScrollBarVisibility>
|
||||
<ScrollBarVisibility>Disabled</ScrollBarVisibility>
|
||||
<ScrollBarVisibility>Hidden</ScrollBarVisibility>
|
||||
<ScrollBarVisibility>Visible</ScrollBarVisibility>
|
||||
</ComboBox>
|
||||
<TextBlock Text="垂直滚动条" VerticalAlignment="Center" />
|
||||
<ComboBox x:Name="ScrollViewVVisb" Width="90" SelectedIndex="0">
|
||||
<ScrollBarVisibility>Auto</ScrollBarVisibility>
|
||||
<ScrollBarVisibility>Disabled</ScrollBarVisibility>
|
||||
<ScrollBarVisibility>Hidden</ScrollBarVisibility>
|
||||
<ScrollBarVisibility>Visible</ScrollBarVisibility>
|
||||
</ComboBox>
|
||||
</StackPanel>
|
||||
<StackPanel DockPanel.Dock="Top" Orientation="Horizontal">
|
||||
<CheckBox x:Name="chkFillWidth" IsChecked="True" Content="水平平铺"
|
||||
VerticalAlignment="Center" VerticalContentAlignment="Center"
|
||||
Margin="0,0,10,0" />
|
||||
<TextBlock Text="宽度" VerticalAlignment="Center" />
|
||||
<Grid>
|
||||
<!-- <Rectangle x:Name="Rect1" Width="100" Visibility="Collapsed" /> -->
|
||||
<Rectangle x:Name="Rect1" Width="100" />
|
||||
<TextBox x:Name="txtItemWidth" MinWidth="60" Height="22" VerticalContentAlignment="Center"
|
||||
Text="{Binding ElementName=Rect1,Path=Width,Mode=TwoWay}" />
|
||||
</Grid>
|
||||
<CheckBox x:Name="chkFillHeight" IsChecked="True" Content="垂直平铺"
|
||||
VerticalAlignment="Center" VerticalContentAlignment="Center"
|
||||
Margin="0,0,10,0" />
|
||||
<TextBlock Text="高度" VerticalAlignment="Center" />
|
||||
<Grid>
|
||||
<TextBox x:Name="txtItemHeight" MinWidth="60" Height="22" VerticalContentAlignment="Center"
|
||||
Text="{Binding ElementName=Rect1,Path=Height,Mode=TwoWay}" />
|
||||
</Grid>
|
||||
<TextBlock Text="* 数字可填入NaN" Foreground="Red" VerticalAlignment="Center" />
|
||||
<StackPanel DockPanel.Dock="Top" x:Name="ControlBar">
|
||||
<StackPanel Orientation="Horizontal">
|
||||
<TextBlock Text="Orientation" />
|
||||
<ComboBox ItemsSource="{Binding Orientations}"
|
||||
SelectedItem="{Binding SelectedOrientation}" />
|
||||
<TextBlock Text="HorizontalScrollBar" />
|
||||
<ComboBox ItemsSource="{Binding HScrollBarVisibilities}"
|
||||
SelectedItem="{Binding HorizontalVisibility}" />
|
||||
<TextBlock Text="VerticalScrollBar" />
|
||||
<ComboBox ItemsSource="{Binding VScrollBarVisibilities}"
|
||||
SelectedItem="{Binding VerticalVisibility}" />
|
||||
</StackPanel>
|
||||
<StackPanel Orientation="Horizontal">
|
||||
<CheckBox IsChecked="{Binding IsFillHorizontal}"
|
||||
Content="IsFillHorizontal" />
|
||||
<TextBlock Text="ItemWidth" />
|
||||
<TextBox Text="{Binding ItemWidth}" />
|
||||
<CheckBox IsChecked="{Binding IsFillVertical}"
|
||||
Content="IsFillVertical" />
|
||||
<TextBlock Text="ItemHeight" />
|
||||
<TextBox Text="{Binding ItemHeight}" />
|
||||
</StackPanel>
|
||||
<StackPanel.Styles>
|
||||
<Style Selector="StackPanel#ControlBar > StackPanel > TextBlock">
|
||||
<Setter Property="VerticalAlignment" Value="Center" />
|
||||
<Setter Property="Margin" Value="10 0" />
|
||||
</Style>
|
||||
<Style Selector="StackPanel#ControlBar > StackPanel > TextBox">
|
||||
<Setter Property="Width" Value="100" />
|
||||
</Style>
|
||||
<Style Selector="StackPanel#ControlBar > StackPanel > ComboBox">
|
||||
<Setter Property="Width" Value="130" />
|
||||
</Style>
|
||||
</StackPanel.Styles>
|
||||
</StackPanel>
|
||||
|
||||
<TabControl>
|
||||
<TabItem Header="平铺Demo">
|
||||
<TabControl>
|
||||
<TabItem Header="情景1(高度充满)">
|
||||
<u:ElasticWrapPanel x:Name="ElasticWrapPanel" Grid.Row="3"
|
||||
IsFillHorizontal="{Binding ElementName=chkFillWidth,Path=IsChecked,Mode=TwoWay}"
|
||||
IsFillVertical="{Binding ElementName=chkFillHeight,Path=IsChecked,Mode=TwoWay}"
|
||||
ItemWidth="{Binding ElementName=Rect1,Path=Width}"
|
||||
ItemHeight="{Binding ElementName=Rect1,Path=Height}"
|
||||
Orientation="{Binding ElementName=CmbOrientation,Path=SelectedValue}">
|
||||
<u:ElasticWrapPanel x:Name="ElasticWrapPanel"
|
||||
IsFillHorizontal="{Binding IsFillHorizontal}"
|
||||
IsFillVertical="{Binding IsFillVertical}"
|
||||
ItemWidth="{Binding ItemWidth}"
|
||||
ItemHeight="{Binding ItemHeight}"
|
||||
Orientation="{Binding SelectedOrientation}">
|
||||
<DockPanel MinHeight="35" Margin="0,0,5,2">
|
||||
<DockPanel.Background>
|
||||
<LinearGradientBrush EndPoint="1,0.5" StartPoint="0,0.5">
|
||||
@@ -137,17 +133,13 @@
|
||||
</u:ElasticWrapPanel>
|
||||
</TabItem>
|
||||
<TabItem Header="情景2(高度Auto)">
|
||||
<Grid>
|
||||
<Grid.RowDefinitions>
|
||||
<RowDefinition Height="auto" />
|
||||
<RowDefinition />
|
||||
</Grid.RowDefinitions>
|
||||
<Grid RowDefinitions="auto,*">
|
||||
<u:ElasticWrapPanel
|
||||
IsFillHorizontal="{Binding ElementName=chkFillWidth,Path=IsChecked,Mode=TwoWay}"
|
||||
IsFillVertical="{Binding ElementName=chkFillHeight,Path=IsChecked,Mode=TwoWay}"
|
||||
ItemWidth="{Binding ElementName=Rect1,Path=Width}"
|
||||
ItemHeight="{Binding ElementName=Rect1,Path=Height}"
|
||||
Orientation="{Binding ElementName=CmbOrientation,Path=SelectedValue}">
|
||||
IsFillHorizontal="{Binding IsFillHorizontal}"
|
||||
IsFillVertical="{Binding IsFillVertical}"
|
||||
ItemWidth="{Binding ItemWidth}"
|
||||
ItemHeight="{Binding ItemHeight}"
|
||||
Orientation="{Binding SelectedOrientation}">
|
||||
<DockPanel MinHeight="35" Margin="0,0,5,2">
|
||||
<DockPanel.Background>
|
||||
<LinearGradientBrush EndPoint="1,0.5" StartPoint="0,0.5">
|
||||
@@ -225,21 +217,21 @@
|
||||
</DockPanel>
|
||||
</u:ElasticWrapPanel>
|
||||
<Border Grid.Row="1" BorderThickness="1" BorderBrush="Red" Margin="0,4">
|
||||
<Label Content="这里是VS扩展git源码提交部分界面不实现!" />
|
||||
<Label Content="This is blank" />
|
||||
</Border>
|
||||
</Grid>
|
||||
</TabItem>
|
||||
<TabItem Header="情景3(ScrollView中表现)">
|
||||
<Border Grid.Row="3" Margin="70,30" BorderBrush="Red" BorderThickness="1">
|
||||
<Border Margin="70,30" BorderBrush="Red" BorderThickness="1">
|
||||
<ScrollViewer
|
||||
HorizontalScrollBarVisibility="{Binding ElementName=ScrollViewHVisb,Path=SelectedValue}"
|
||||
VerticalScrollBarVisibility="{Binding ElementName=ScrollViewVVisb,Path=SelectedValue}">
|
||||
HorizontalScrollBarVisibility="{Binding HorizontalVisibility}"
|
||||
VerticalScrollBarVisibility="{Binding VerticalVisibility}">
|
||||
<u:ElasticWrapPanel x:Name="ElasticWrapPanel3"
|
||||
IsFillHorizontal="{Binding ElementName=chkFillWidth,Path=IsChecked,Mode=TwoWay}"
|
||||
IsFillVertical="{Binding ElementName=chkFillHeight,Path=IsChecked,Mode=TwoWay}"
|
||||
ItemWidth="{Binding ElementName=Rect1,Path=Width}"
|
||||
ItemHeight="{Binding ElementName=Rect1,Path=Height}"
|
||||
Orientation="{Binding ElementName=CmbOrientation,Path=SelectedValue}">
|
||||
IsFillHorizontal="{Binding IsFillHorizontal}"
|
||||
IsFillVertical="{Binding IsFillVertical}"
|
||||
ItemWidth="{Binding ItemWidth}"
|
||||
ItemHeight="{Binding ItemHeight}"
|
||||
Orientation="{Binding SelectedOrientation}">
|
||||
<DockPanel MinHeight="35" Margin="0,0,5,2">
|
||||
<DockPanel.Background>
|
||||
<LinearGradientBrush EndPoint="1,0.5" StartPoint="0,0.5">
|
||||
@@ -352,13 +344,13 @@
|
||||
<TabItem Header="一个">
|
||||
<StackPanel x:Name="UnifornGrid1">
|
||||
<ScrollViewer
|
||||
HorizontalScrollBarVisibility="{Binding ElementName=ScrollViewHVisb,Path=SelectedValue}"
|
||||
VerticalScrollBarVisibility="{Binding ElementName=ScrollViewVVisb,Path=SelectedValue}">
|
||||
HorizontalScrollBarVisibility="{Binding HorizontalVisibility}"
|
||||
VerticalScrollBarVisibility="{Binding VerticalVisibility}">
|
||||
<DockPanel>
|
||||
<Label Content="WrapPanel" Background="#FFCBCBEA" DockPanel.Dock="Top" />
|
||||
<WrapPanel ItemWidth="{Binding ElementName=Rect1,Path=Width}"
|
||||
ItemHeight="{Binding ElementName=Rect1,Path=Height}"
|
||||
Orientation="{Binding ElementName=CmbOrientation,Path=SelectedValue}">
|
||||
<WrapPanel ItemWidth="{Binding ItemWidth}"
|
||||
ItemHeight="{Binding ItemHeight}"
|
||||
Orientation="{Binding SelectedOrientation}">
|
||||
<DockPanel Margin="0,2" Width="{Binding ElementName=Rect2,Path=Width}"
|
||||
Height="{Binding ElementName=Rect2,Path=Height}">
|
||||
<TextBlock Text="内容1" VerticalAlignment="Center" />
|
||||
@@ -400,16 +392,17 @@
|
||||
</DockPanel>
|
||||
</ScrollViewer>
|
||||
<ScrollViewer
|
||||
HorizontalScrollBarVisibility="{Binding ElementName=ScrollViewHVisb,Path=SelectedValue}"
|
||||
VerticalScrollBarVisibility="{Binding ElementName=ScrollViewVVisb,Path=SelectedValue}">
|
||||
HorizontalScrollBarVisibility="{Binding HorizontalVisibility}"
|
||||
VerticalScrollBarVisibility="{Binding VerticalVisibility}">
|
||||
<DockPanel>
|
||||
<Label Content="ElasticWrapPanel" Background="#FFB4F1AA" DockPanel.Dock="Top" />
|
||||
<Label Content="ElasticWrapPanel" Background="#FFB4F1AA"
|
||||
DockPanel.Dock="Top" />
|
||||
<u:ElasticWrapPanel
|
||||
IsFillHorizontal="{Binding ElementName=chkFillWidth,Path=IsChecked,Mode=TwoWay}"
|
||||
IsFillVertical="{Binding ElementName=chkFillHeight,Path=IsChecked,Mode=TwoWay}"
|
||||
ItemWidth="{Binding ElementName=Rect1,Path=Width}"
|
||||
ItemHeight="{Binding ElementName=Rect1,Path=Height}"
|
||||
Orientation="{Binding ElementName=CmbOrientation,Path=SelectedValue}">
|
||||
IsFillHorizontal="{Binding IsFillHorizontal}"
|
||||
IsFillVertical="{Binding IsFillVertical}"
|
||||
ItemWidth="{Binding ItemWidth}"
|
||||
ItemHeight="{Binding ItemHeight}"
|
||||
Orientation="{Binding SelectedOrientation}">
|
||||
<DockPanel Margin="0,2" Width="{Binding ElementName=Rect2,Path=Width}"
|
||||
Height="{Binding ElementName=Rect2,Path=Height}">
|
||||
<TextBlock Text="内容1" VerticalAlignment="Center" />
|
||||
@@ -455,13 +448,13 @@
|
||||
<TabItem Header="多个">
|
||||
<StackPanel x:Name="UnifornGrid2">
|
||||
<ScrollViewer
|
||||
HorizontalScrollBarVisibility="{Binding ElementName=ScrollViewHVisb,Path=SelectedValue}"
|
||||
VerticalScrollBarVisibility="{Binding ElementName=ScrollViewVVisb,Path=SelectedValue}">
|
||||
HorizontalScrollBarVisibility="{Binding HorizontalVisibility}"
|
||||
VerticalScrollBarVisibility="{Binding VerticalVisibility}">
|
||||
<DockPanel>
|
||||
<Label Content="WrapPanel" Background="#FFCBCBEA" DockPanel.Dock="Top" />
|
||||
<WrapPanel ItemWidth="{Binding ElementName=Rect1,Path=Width}"
|
||||
ItemHeight="{Binding ElementName=Rect1,Path=Height}"
|
||||
Orientation="{Binding ElementName=CmbOrientation,Path=SelectedValue}">
|
||||
<WrapPanel ItemWidth="{Binding ItemWidth}"
|
||||
ItemHeight="{Binding ItemHeight}"
|
||||
Orientation="{Binding SelectedOrientation}">
|
||||
<DockPanel Margin="0,2" Width="{Binding ElementName=Rect2,Path=Width}"
|
||||
Height="{Binding ElementName=Rect2,Path=Height}">
|
||||
<TextBlock Text="内容1" VerticalAlignment="Center" />
|
||||
@@ -540,16 +533,17 @@
|
||||
</DockPanel>
|
||||
</ScrollViewer>
|
||||
<ScrollViewer
|
||||
HorizontalScrollBarVisibility="{Binding ElementName=ScrollViewHVisb,Path=SelectedValue}"
|
||||
VerticalScrollBarVisibility="{Binding ElementName=ScrollViewVVisb,Path=SelectedValue}">
|
||||
HorizontalScrollBarVisibility="{Binding HorizontalVisibility}"
|
||||
VerticalScrollBarVisibility="{Binding VerticalVisibility}">
|
||||
<DockPanel>
|
||||
<Label Content="ElasticWrapPanel" Background="#FFB4F1AA" DockPanel.Dock="Top" />
|
||||
<Label Content="ElasticWrapPanel" Background="#FFB4F1AA"
|
||||
DockPanel.Dock="Top" />
|
||||
<u:ElasticWrapPanel
|
||||
IsFillHorizontal="{Binding ElementName=chkFillWidth,Path=IsChecked,Mode=TwoWay}"
|
||||
IsFillVertical="{Binding ElementName=chkFillHeight,Path=IsChecked,Mode=TwoWay}"
|
||||
ItemWidth="{Binding ElementName=Rect1,Path=Width}"
|
||||
ItemHeight="{Binding ElementName=Rect1,Path=Height}"
|
||||
Orientation="{Binding ElementName=CmbOrientation,Path=SelectedValue}">
|
||||
IsFillHorizontal="{Binding IsFillHorizontal}"
|
||||
IsFillVertical="{Binding IsFillVertical}"
|
||||
ItemWidth="{Binding ItemWidth}"
|
||||
ItemHeight="{Binding ItemHeight}"
|
||||
Orientation="{Binding SelectedOrientation}">
|
||||
<DockPanel Margin="0,2" Width="{Binding ElementName=Rect2,Path=Width}"
|
||||
Height="{Binding ElementName=Rect2,Path=Height}">
|
||||
<TextBlock Text="内容1" VerticalAlignment="Center" />
|
||||
@@ -634,17 +628,5 @@
|
||||
</TabItem>
|
||||
</TabControl>
|
||||
</DockPanel>
|
||||
<Border HorizontalAlignment="Right" VerticalAlignment="Top" IsHitTestVisible="False"
|
||||
BorderBrush="Blue" Background="#FF56AFFD" Margin="5,5,5,5" BorderThickness="1"
|
||||
TextElement.FontFamily="微软雅黑" TextElement.FontWeight="Thin" Opacity="0.35"
|
||||
TextElement.Foreground="White" Padding="4">
|
||||
<StackPanel>
|
||||
<TextBlock Text="ElasticWrapPanel控件" />
|
||||
<TextBlock Text="IsFillHorizontal属性:有ItemWidth情况下水平平铺" />
|
||||
<TextBlock Text="IsFillVertical属性:有ItemHeight情况下水平平铺" />
|
||||
<TextBlock Text="ElasticWrapPanel.FixToRB:水平排列元素时则向右对齐换行" />
|
||||
<TextBlock TextAlignment="Right" Text="垂直排列元素时则向底部对齐换行" />
|
||||
</StackPanel>
|
||||
</Border>
|
||||
</Grid>
|
||||
</UserControl>
|
||||
@@ -1,6 +1,5 @@
|
||||
using Avalonia;
|
||||
using Avalonia.Controls;
|
||||
using Avalonia.Markup.Xaml;
|
||||
using Avalonia.Controls;
|
||||
using Ursa.Demo.ViewModels;
|
||||
|
||||
namespace Ursa.Demo.Pages;
|
||||
|
||||
@@ -9,5 +8,6 @@ public partial class ElasticWrapPanelDemo : UserControl
|
||||
public ElasticWrapPanelDemo()
|
||||
{
|
||||
InitializeComponent();
|
||||
DataContext = new ElasticWrapPanelDemoViewModel();
|
||||
}
|
||||
}
|
||||
@@ -1,7 +1,42 @@
|
||||
using CommunityToolkit.Mvvm.ComponentModel;
|
||||
using System.Collections.ObjectModel;
|
||||
using Avalonia.Controls.Primitives;
|
||||
using Avalonia.Layout;
|
||||
using CommunityToolkit.Mvvm.ComponentModel;
|
||||
|
||||
namespace Ursa.Demo.ViewModels;
|
||||
|
||||
public class ElasticWrapPanelDemoViewModel : ObservableObject
|
||||
public partial class ElasticWrapPanelDemoViewModel : ObservableObject
|
||||
{
|
||||
[ObservableProperty] private Orientation _selectedOrientation;
|
||||
[ObservableProperty] private ScrollBarVisibility _horizontalVisibility;
|
||||
[ObservableProperty] private ScrollBarVisibility _verticalVisibility;
|
||||
[ObservableProperty] private ObservableCollection<Orientation> _orientations = null!;
|
||||
[ObservableProperty] private ObservableCollection<ScrollBarVisibility> _hScrollBarVisibilities = null!;
|
||||
[ObservableProperty] private ObservableCollection<ScrollBarVisibility> _vScrollBarVisibilities = null!;
|
||||
|
||||
[ObservableProperty] private bool _isFillHorizontal;
|
||||
[ObservableProperty] private bool _isFillVertical;
|
||||
[ObservableProperty] private double _itemWidth;
|
||||
[ObservableProperty] private double _itemHeight;
|
||||
|
||||
|
||||
public ElasticWrapPanelDemoViewModel()
|
||||
{
|
||||
SelectedOrientation = Orientation.Horizontal;
|
||||
HorizontalVisibility = VerticalVisibility = ScrollBarVisibility.Auto;
|
||||
Orientations = new ObservableCollection<Orientation>() { Orientation.Horizontal, Orientation.Vertical };
|
||||
HScrollBarVisibilities = new ObservableCollection<ScrollBarVisibility>()
|
||||
{
|
||||
ScrollBarVisibility.Disabled,
|
||||
ScrollBarVisibility.Auto,
|
||||
ScrollBarVisibility.Hidden,
|
||||
ScrollBarVisibility.Visible
|
||||
};
|
||||
VScrollBarVisibilities = new ObservableCollection<ScrollBarVisibility>(HScrollBarVisibilities);
|
||||
|
||||
IsFillHorizontal = true;
|
||||
IsFillVertical = false;
|
||||
ItemWidth = 100d;
|
||||
ItemHeight = double.NaN;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user