using System.Globalization; using System.Windows.Data; namespace Melskin.Converters; /// /// 将0.0-1.0范围的浮点数值转换为0%-100%百分比字符串的转换器。 /// 此转换器用于将饱和度和亮度值显示为百分比格式,提供更直观的用户界面。 /// public class PercentageConverter : IValueConverter { /// /// 单例实例,用于访问已创建的PercentageConverter对象。 /// 通过使用此静态只读属性,可以在不重复创建转换器实例的情况下,在应用程序中的任何地方方便地引用和使用该转换器。 /// public static readonly PercentageConverter Instance = new(); /// public object Convert(object? value, System.Type targetType, object? parameter, CultureInfo culture) { if (value is double doubleValue) { // 将 0.0-1.0 的值转换为 0-100 的百分比字符串 return $"{Math.Round(doubleValue * 100.0)}%"; } return "0%"; } /// public object ConvertBack(object? value, System.Type targetType, object? parameter, CultureInfo culture) { if (value is not string percentStr) return DependencyProperty.UnsetValue; // 移除 '%' 符号并尝试解析 if (double.TryParse(percentStr.TrimEnd('%'), out var percent)) { var clampedPercent = Math.Max(0, Math.Min(100, percent)); return clampedPercent / 100.0; // 转换回 0.0-1.0 范围 } // 如果转换失败,返回 UnsetValue 以保留原值 return DependencyProperty.UnsetValue; } }