Closed
Bug 929451
Opened 11 years ago
Closed 11 years ago
canvas toDataURL creates green Text when used on white text over transparent background. (linux only)
Categories
(Core :: Graphics: Canvas2D, defect)
Tracking
()
RESOLVED
FIXED
mozilla29
People
(Reporter: vondemleschker, Assigned: roc)
References
(Depends on 1 open bug)
Details
Attachments
(2 files, 1 obsolete file)
(deleted),
patch
|
karlt
:
review-
|
Details | Diff | Splinter Review |
(deleted),
patch
|
roc
:
review+
|
Details | Diff | Splinter Review |
User Agent: Mozilla/5.0 (X11; Linux x86_64; rv:24.0) Gecko/20100101 Firefox/24.0 Iceweasel/24.0 (Beta/Release)
Build ID: 20130918225509
Steps to reproduce:
Create Canvas with white Text and use to DataURL.
<!DOCTYPE html>
<html lang=en>
<head>
<meta charset=utf-8>
<title>Testbench</title>
</head>
<body>
<div id="canvasContainer"><canvas id="canvas" width="1000" height="500"></canvas></div>
<script>
var textCanvas = document.createElement('canvas');
var c = textCanvas.getContext('2d');
c.font = "8pt sans-serif";
c.textAlign = "center";
c.textBaseline = "middle";
c.fillStyle = "white";
c.fillText("Test Text", textCanvas.width / 2, textCanvas.height / 2);
var image = new Image();
image.src = textCanvas.toDataURL();
console.log(image);
console.log(image.src);
</script>
</body>
Actual results:
The resulting DataURL on my machine is:

Which is a greenisch text.
Expected results:
The Image should be white Text with transparent background, as png is a lossless compression there should be no arthefacts.
This only happen under Linux. Windows-FF works well.
Updated•11 years ago
|
Component: Untriaged → Canvas: 2D
Product: Firefox → Core
Updated•11 years ago
|
Status: UNCONFIRMED → NEW
Ever confirmed: true
Assignee | ||
Comment 1•11 years ago
|
||
This should fix it.
Assignee: nobody → roc
Attachment #8356971 -
Flags: review?(bas)
Assignee | ||
Comment 2•11 years ago
|
||
I can't reproduce locally, for some reason.
Comment 3•11 years ago
|
||
Comment on attachment 8356971 [details] [diff] [review]
fix
Review of attachment 8356971 [details] [diff] [review]:
-----------------------------------------------------------------
::: content/canvas/src/CanvasRenderingContext2D.cpp
@@ +918,5 @@
> mTarget = sErrorTarget;
> }
> +
> + if (!mOpaque) {
> + mTarget->SetPermitSubpixelAA(false);
Hrm, in theory for non-opaque surfaces not permitting subpixel AA should be the default. If it's not on Linux we should probably fix that too. Although for now I have no objections against this patch.
Attachment #8356971 -
Flags: review?(bas) → review+
Assignee | ||
Comment 4•11 years ago
|
||
Well, let's fix it properly then.
Assignee | ||
Comment 5•11 years ago
|
||
Nasty low-level bug in the cairo FT code. This _cairo_ft_options_merge function looks quite wrong to me.
Attachment #8356971 -
Attachment is obsolete: true
Attachment #8357710 -
Flags: review?(karlt)
Comment 6•11 years ago
|
||
Yes, _cairo_ft_options_merge is quite wrong [1], but it is more complex than
this.
The way cairo is usually used is as follows:
cairo_ft_font_options_substitute to add surface (screen/print/etc) font
options to an FcPattern.
FcFontRenderPrepare is passed this pattern so that the font configuration
system knows the target for rendering and can set font-specific options:
e.g. select the hinting, antialiasing, and lcd filtering based on the target,
quality of the font, slant, etc.
cairo_ft_font_face_create_for_pattern sets up "other" options based on these
considerations.
It is a bit awkward that the "options" from the scaled_font come from both the
target font_options as well as the gstate font_options from the client, but
usually these come from the surface.
So we have some contention over whether surface font options or fontconfig
preferences should win [1].
Things go more wrong here because the font_face was created for an RGB surface
but used on a grayscale surface.
The way to resolve this is to consider surface font options as indicating the
capabilities/limitations of the surface, and then accept user options that fit
within those capabilities.
[1] https://bugs.freedesktop.org/show_bug.cgi?id=11838
Comment 7•11 years ago
|
||
Comment on attachment 8357710 [details] [diff] [review]
_cairo_ft_font_face_scaled_font_create should honor CAIRO_ANTIALIAS_GRAY set in the font options parameter
The screen font options may indicate that grayscale or rgb antialiasing be the
default or are available, but it is OK for the font-specific options to
override these and request no antialiasing.
Attachment #8357710 -
Flags: review?(karlt) → review-
Comment 8•11 years ago
|
||
Still need to add testcase and add patch to gfx/cairo/README.
Attachment #8358264 -
Flags: review?(roc)
Assignee | ||
Updated•11 years ago
|
Attachment #8358264 -
Flags: review?(roc) → review+
Comment 9•11 years ago
|
||
https://hg.mozilla.org/integration/mozilla-inbound/rev/0b9787508fab
https://hg.mozilla.org/integration/mozilla-inbound/rev/1caab2ff6346
Aa is disabled on Ubuntu 12.04 reftest machines, so this isn't really in-testsuite+ yet, but at least we have a test to run when we have aa.
Flags: in-testsuite+
Comment 10•11 years ago
|
||
https://hg.mozilla.org/mozilla-central/rev/0b9787508fab
https://hg.mozilla.org/mozilla-central/rev/1caab2ff6346
Status: NEW → RESOLVED
Closed: 11 years ago
Resolution: --- → FIXED
Target Milestone: --- → mozilla29
Reporter | ||
Comment 11•11 years ago
|
||
It's really gone in FF29! :)
Thanks for the work guys.
You need to log in
before you can comment on or make changes to this bug.
Description
•