WPF(自适应圆)

        在WPF中可以实现椭圆,利用Ellipse或者Border。但是要实现圆,就必须设定固定的长宽,然后根据长宽设置对应的倒角才可以实现圆。如果这样设计,就固定了长宽,不能根据界面自适应调整。所以我们可以根据绑定和转换器将实际的长宽转换为对应的倒角。

    using System;
    using System.Globalization;
    using System.Windows.Data;

    [ValueConversion(typeof(double), typeof(double[]))]
    public class RoundMathConverter : IMultiValueConverter
    {
        public object Convert(object[] values, Type targetType, object parameter, CultureInfo culture)
        {
            if (values.Length < 2)
            {
                throw new NotImplementedException();
            }
            double.TryParse(values[0].ToString(), out double d1);
            double.TryParse(values[1].ToString(), out double d2);
            if (d1 * d2 == 0)
            {
                return double.NaN;
            }
            return Math.Min(d1, d2);
        }

        public object[] ConvertBack(object value, Type[] targetTypes, object parameter, CultureInfo culture)
        {
            throw new NotImplementedException();
        }
    }

    [ValueConversion(typeof(System.Windows.CornerRadius), typeof(double[]))]
    public class RoundRadiusConverter : IMultiValueConverter
    {
        public object Convert(object[] values, Type targetType, object parameter, CultureInfo culture)
        {
            if (values.Length < 2)
            {
                throw new NotImplementedException();
            }
            double.TryParse(values[0].ToString(), out double d1);
            double.TryParse(values[1].ToString(), out double d2);
            double ratio = 1;
            if (values.Length >= 3)
            {
                double.TryParse(values[2].ToString(), out ratio);
            }
            return new System.Windows.CornerRadius(Math.Min(d1, d2) * ratio / 2);
        }

        public object[] ConvertBack(object value, Type[] targetTypes, object parameter, CultureInfo culture)
        {
            throw new NotImplementedException();
        }
    }

1.椭圆

    using System.Windows;
    using System.Windows.Controls;

    /// <summary>
    /// EllipseBorder.xaml 的交互逻辑
    /// </summary>
    public partial class EllipseBorder : Border
    {
        public static readonly DependencyProperty RadiusRatioProperty = 
            DependencyProperty.Register(nameof(RadiusRatio), typeof(float), typeof(EllipseBorder), new FrameworkPropertyMetadata(1f));

        public float RadiusRatio
        {
            get { return (float)GetValue(RadiusRatioProperty); }
            set { SetValue(RadiusRatioProperty, value); }
        }

        public EllipseBorder()
        {
            InitializeComponent();
        }
    }
<Border x:Class="WpfApp360.CustomControl.EllipseBorder" 
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
        xmlns:local="clr-namespace:WpfApp360.Converter" 
        xmlns:con="clr-namespace:WpfApp360.Converter" 
        d:DesignHeight="450" d:DesignWidth="800" mc:Ignorable="d">
    <Border.CornerRadius>
        <MultiBinding>
            <MultiBinding.Converter>
                <con:RoundRadiusConverter />
            </MultiBinding.Converter>
            <Binding Path="ActualWidth" RelativeSource="{RelativeSource Self}" />
            <Binding Path="ActualHeight" RelativeSource="{RelativeSource Self}" />
            <Binding Path="RadiusRatio" RelativeSource="{RelativeSource Self}" />
        </MultiBinding>
    </Border.CornerRadius>
</Border>

可通过设置RadiusRatio来控制倒角的比例。 

2.圆 

由于圆需要根据ActualHeight和ActualWidth 来设置元素的Width和Height,但是这两者之间会互相影响,所以我们不能和椭圆一样来定义一个Border。下面我们设计一个圆形Button,在Button模板中定义一个Border。

<Button x:Class="WpfApp360.CustomControl.RoundButton" 
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
        xmlns:con="clr-namespace:WpfApp360.Converter" 
        d:DesignHeight="400" d:DesignWidth="400" mc:Ignorable="d">
    <Button.Template>
        <ControlTemplate TargetType="Button">
            <Border Background="{TemplateBinding Background}" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}">
                <Border.CornerRadius>
                    <MultiBinding>
                        <MultiBinding.Converter>
                            <con:RoundRadiusConverter />
                        </MultiBinding.Converter>
                        <Binding Path="ActualWidth" RelativeSource="{RelativeSource TemplatedParent}" />
                        <Binding Path="ActualHeight" RelativeSource="{RelativeSource TemplatedParent}" />
                    </MultiBinding>
                </Border.CornerRadius>
                <Border.Width>
                    <MultiBinding>
                        <MultiBinding.Converter>
                            <con:RoundMathConverter />
                        </MultiBinding.Converter>
                        <Binding Path="ActualWidth" RelativeSource="{RelativeSource TemplatedParent}" />
                        <Binding Path="ActualHeight" RelativeSource="{RelativeSource TemplatedParent}" />
                    </MultiBinding>
                </Border.Width>
                <Border.Height>
                    <MultiBinding>
                        <MultiBinding.Converter>
                            <con:RoundMathConverter />
                        </MultiBinding.Converter>
                        <Binding Path="ActualWidth" RelativeSource="{RelativeSource TemplatedParent}" />
                        <Binding Path="ActualHeight" RelativeSource="{RelativeSource TemplatedParent}" />
                    </MultiBinding>
                </Border.Height>
                <ContentPresenter HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}" />
            </Border>
        </ControlTemplate>
    </Button.Template>
</Button>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
C# WPF 中实现页面的自适应分辨率,可以采取以下几个步骤: 1. 使用相对布局:使用 XAML 中的布局容器(如 Grid、StackPanel、WrapPanel 等),并设置控件的行、列以及其他布局属性,以实现自适应布局。 2. 使用 Grid 中的行和列定义:通过设置 Grid 中的行和列的定义,可以让控件根据窗口大小自动调整位置和大小。可以使用 "*" 表示自动调整大小的列或行,使用具体数值(如 "200")表示固定大小的列或行。 3. 使用 ViewBox 控件:ViewBox 是一个用于缩放其内容的容器控件。将需要自适应分辨率的内容放置在 ViewBox 中,并设置 Stretch 属性为 Uniform 或 UniformToFill,即可实现内容的自动缩放。 4. 响应窗口大小改变事件:在窗口的 SizeChanged 事件中编写代码,根据窗口的大小变化,调整控件的位置和大小来实现自适应分辨率。 5. 使用 VisualStateManager:通过使用 VisualStateManager,可以在不同的状态下应用不同的布局。根据窗口大小或其他条件,设置不同的视觉状态,在不同的状态下使用不同的布局。 6. 使用分辨率相关信息:可以通过 System.Windows.Forms.Screen 类获取当前屏幕的分辨率信息,并根据该信息调整控件的布局和大小。 综上所述,以上是一些常用的方法来实现 C# WPF 页面的自适应分辨率。根据具体的需求和场景,可以选择适合的方法来实现页面的自适应

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Bridge_go

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值