26
Rendering Quality in WebKit's Open Source Graphics Stack Dominik Röttsches [email protected] 01.org/webkit

Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

  • Upload
    others

  • View
    18

  • Download
    0

Embed Size (px)

Citation preview

Page 1: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

Rendering Quality in WebKit's

Open Source Graphics Stack

Dominik Röttsches

[email protected]

01.org/webkit

Page 2: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

AboutWebKit Software Engineer @ Intel Finland, OTC

WebKit Committer

Specialized in Tizen WebKit's Graphics Backend

Page 3: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

In this talkDefine rendering quality

WebKit's 2D rendering stack

Improvements to Tizen WebKit's rendering quality

Page 4: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

Rendering QualitySite looks "as intended by the author"

Text & graphics look accurate & pleasant

Sharp

Readable

Regular spacing & layout

No glitches, artifacts, gaps, irregularities

Page 5: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

"Looks as intended" = Consistencyacross platforms and devices

across browsers

across different screens

with look & feel of the operating system

Page 6: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

Great looking fonts and graphics

create a great user experience.

WebKit Graphics Backend

Page 7: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

WebKit Graphics Backend

... ...

WebKit API

WebCore JSCore

Platform Abstractions

2D

Graphics

Fonts &

Metrics

Text

Shaping

Page 8: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

... ...

WebKit API

WebCore JSCore

Platform Abstractions

2D

Graphics

Fonts &

Metrics

Text

Shaping

WebKit Graphics Stacks

2D Graphics Font & Metrics Text Shaping

Tizen WebKit Cairo FreeType HarfBuzz NG (ex: Pango)

WebKit GTK Cairo FreeType HarfBuzz NG (ex: Pango)

Safari CoreGraphics CoreText CoreText

Chromium Linux Skia FreeType HarfBuzz NG

Chromium Mac Skia CoreText (via Skia) HarfBuzz NG

Qt WebKit QPainter Platform dependent HarfBuzz NG

Page 9: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

What could possibly go wrong?(Downloadable) Fonts

Shadows

Layout, Scaling and Zooming Precision

Page 10: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

Font Selection & Font Antialiasing

Web Fonts & Complex Font Support

Page 11: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

Font Selection & Font Antialiasing

Web Fonts & Complex Font Support

Page 12: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

Shadows in CSS and SVG

Page 13: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend
Page 14: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend
Page 15: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

Baseline Positioning of Text

Page 16: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend
Page 17: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend
Page 18: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend
Page 19: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

Artifacts on Reflections

Page 20: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

Artifacts on Reflections

Page 21: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend
Page 22: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

Fractional Units in Layout4

1 1 1 1

Fractional Units Gone Wrong

Page 23: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

Fractional Units in Layout

Fractional Units Gone Wrong

Sub-pixel Layout to the RescueKeeps account of fractional layout values

Takes into account zooming and scaling

Lays out web page with fractional precision

Renders snapped to device pixels

Page 24: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

Sub-pixel Layout to the RescueKeeps account of fractional layout values

Takes into account zooming and scaling

Lays out web page with fractional precision

Renders snapped to device pixels

Page 25: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

What needs to be done right?Font Selection

Font Aliasing Settings

Web Fonts & Complex Font Rendering

Robust Graphics Backend

Layout, Scaling and Zooming Precision

Page 26: Open Source Graphics Stack - download.tizen.org · About WebKit Software Engineer @ Intel Finland, OTC WebKit Committer Specialized in Tizen WebKit's Graphics Backend

Great User Experience

in Tizen WebKitHigh quality font rendering

Complex font rendering for web fonts

Improvements to Tizen WebKit's graphics backend

Sub pixel layout for accurate scaling and zooming