内容字号:默认大号超大号

段落设置:取消段首缩进段首缩进

字体设置:切换到微软雅黑切换到宋体

业界
软件
手机
数码
电脑
学院
测评
图赏
视频
游戏
原创
直播
 AI
5G
苹果
微软
iPhone
Win10
精准搜索请尝试:精确搜索

谷歌 Chrome 新增开发者工具,帮助开发对色盲友好的页面

2020/3/13 8:30:10来源:开源中国作者:-责编:骑士评论:

Chrome开发者透露了正在开发中的一个可以帮助开发者使网站对色盲更加友好的开发者工具 Color Vision Deficiency(CVD,色觉障碍/色盲)。

根据ColourBlindAwareness.org的说法,目前全球大约有3亿色盲人群。新的Chrome将通过DevTools在任何给定的网页上模拟全色盲、红色盲与绿色盲等色盲人群看到的样式。需要包括以下内容:

  • 引入Chrome DevTools协议(CDP)API(Emulation#setEmulatedColorVisionDeficiency),以支持通过CDP以编程方式启用这些模拟。

  • 引入新的Puppeteer API,以编程方式支持通过CDP进行这些模拟。

  • 在DevTools colorpicker小部件中展开对比度检查器,以检查已知色盲之间的对比度问题。

  • 向可访问性审核添加一个Lighthouse测试,以使用新功能,并检查每个模拟的对比级别。

长期而言,CVD理想情况下将在Blink Renderer级别获得一级支持,因此可以在不更改文档或不影响计算样式的情况下将过滤器应用于文档。以下是一个简单的示例,该示例使用GraphicsContext::SetColorFilter无条件添加过滤器:

diff --git a/third_party/blink/renderer/platform/graphics/graphics_context.cc b/third_party/blink/renderer/platform/graphics/graphics_context.cc
index 7cbbd9656eff..d700d15a5cb4 100644
--- a/third_party/blink/renderer/platform/graphics/graphics_context.cc
+++ b/third_party/blink/renderer/platform/graphics/graphics_context.cc
@@ -113,6 +113,16 @@ GraphicsContext::GraphicsContext(PaintController& paint_controller,
   paint_state_stack_.push_back(std::make_unique<GraphicsContextState>());
   paint_state_ = paint_state_stack_.back().get();
+  // clang-format off
+  const float kAchromatopsiaColorMatrix[20] = {
+      0.299f, 0.587f, 0.114f, 0.000f, 0.000f,
+      0.299f, 0.587f, 0.114f, 0.000f, 0.000f,
+      0.299f, 0.587f, 0.114f, 0.000f, 0.000f,
+      0.000f, 0.000f, 0.000f, 1.000f, 0.000f,
+  };
+  // clang-format on
+  paint_state_->SetColorFilter(SkColorFilters::Matrix(matrix));
+
   if (ContextDisabled()) {
     DEFINE_STATIC_LOCAL(SkCanvas*, null_sk_canvas,
                         (SkMakeNullCanvas().release()));

预计Chrome 82会加入该工具,不过目前可以使用Canary版本体验。

相关文章

关键词:Chrome浏览器谷歌

IT之家,软媒旗下科技门户网站 - 爱科技,爱这里。

Copyright (C)RuanMei.com, All Rights Reserved.

软媒公司版权所有