当前位置: 首页 > news >正文

Flutter 3.29.0 版本对颜色Color做出的改动 Display P3你了解吗

Color的更改

  • 添加一个枚举字段,指定其ColorSpace。
  • 添加API以使用规范化的浮点颜色组件。
  • 删除使用可能导致数据丢失的8位无符号整数颜色组件的API。

ColorSpace 的更改

  • 添加displayP3属性。

Display P3是苹果为平衡广色域与消费级显示需求优化的色彩标准,通过扩展色域和兼容性设计,提升了视觉体验,尤其适合创意工作者和高质量媒体消费。

在支持广色域的屏幕上(如 iPhone、iPad Pro),使用 ColorSpace 显示更丰富的颜色:

// 使用 Display P3 颜色空间
const p3Red = Color(0xFFFF0000, colorSpace: ColorSpace.displayP3);
Container(
  color: p3Red,
  width: 100,
  height: 100,
);

加载图片时指定颜色空间,确保色彩正确显示:

Image.asset(
  'assets/photo_p3.jpg',
  colorSpace: ColorSpace.displayP3, // 明确指定 P3 色域
);

在不同颜色空间之间转换颜色值(需结合 Color 类或第三方库):

// 假设将 sRGB 颜色转换为 P3 颜色空间
Color sRGBColor = Colors.red;
Color p3Color = sRGBColor.toColorSpace(ColorSpace.displayP3);
Color.fromARGB 修改为 Color.from 方式来调用 ,
// 之前:从四个整数的低8位构造sRGB颜色。
final magenta = Color.fromARGB(0xff, 0xff, 0x0, 0xff);

// 之后 使用归一化浮点分量构造颜色。
final magenta = Color.from(alpha: 1.0, red: 1.0, green: 0.0, blue: 1.0);
Implementors of Color 的改动

Color中添加了新方法,因此任何实现Color的类都会中断,必须实现新方法,例如Color.a和Color.b。

class Foo implements Color {
  int _red;

  
  double get r => _red / 255.0;
}
Opacity 透明度
// 之前创建一个颜色的半透明度
final x = color.withOpacity(0.5);

// After: Create a new color with the specified alpha channel value,
// accounting for the current or specified color space.
final x = color.withValues(alpha: 0.5);
Color 中 ColorSpace

使用颜色并对颜色分量执行任何类型计算的客户端现在应该在执行计算之前首先检查颜色空间分量。

现在可以使用新的Color.withValues方法来执行颜色空间转换。

// Before
double redRatio(Color x, Color y) => x.red / y.red;

// After
double redRatio(Color x, Color y) {
  final xPrime = x.withValues(colorSpace: ColorSpace.extendedSRGB);
  final yPrime = y.withValues(colorSpace: ColorSpace.extendedSRGB);
  return xPrime.r / yPrime.r;
}

相关文章:

  • 【面试】Java 中的 BIO、NIO 和 AIO:区别、使用及实例
  • 功能丰富的自动化任务软件zTasker_2.1.0_绿色版_屏蔽强制更新闪退
  • 基于GIS(地理信息系统)技术的智能交通系统的设计与实现
  • Python 网络爬虫的应用
  • C# 13与.NET 9革新及工业开发应用
  • 数据库原理与使用基础教程
  • 使用Docker将ros1自定义消息通过rosjava_bootstrap生成jar包
  • SQL经典题型
  • 4-1.jvm的类加载
  • 基于大数据的气象数据分析与可视化系统设计与实现【爬虫海量数据,LSTM预测】
  • Vue核心知识:KeepLive全方位分析
  • shell场景题
  • 通往 AI 之路:Python 机器学习入门-语法基础
  • 基于51单片机超声波测量报警LCD1602显示( proteus仿真+程序+设计报告+讲解视频)
  • 塔子哥Python算法基础课
  • Conda 环境搭建实战:从基础到进阶
  • flutter AnimationController 动画使用总结
  • [创业之路-329]:华为铁三角实施的步骤
  • uiautomatorviewer定位元素报Unexpected ... UI hierarchy
  • stm32week5
  • 国家统计局:中美大幅降低关税有利于双方贸易增长,也有利于世界经济复苏
  • 新华社千笔楼:地方文旅宣传应走出“魔性尬舞”的流量焦虑
  • 古稀之年的设计家吴国欣:重拾水彩,触摸老上海文脉
  • 人民网:激发博物馆创新活力,让“过去”拥有“未来”
  • 蔡建忠已任昆山市副市长、市公安局局长
  • 自然资源部:不动产登记累计化解遗留问题房屋2000多万套