* Patch for Mac OS X Text Drawing
@ 2005-01-14 20:39 Arthur G.P. Schuster
2005-01-16 0:39 ` Steven Tamm
0 siblings, 1 reply; 17+ messages in thread
From: Arthur G.P. Schuster @ 2005-01-14 20:39 UTC (permalink / raw)
[-- Attachment #1: Type: text/plain, Size: 695 bytes --]
Hello,
this is the first patch I have ever sent (and also the first time I
used Ediff), so be kind. I found out (at
<http://developer.apple.com/qa/qa2001/qa1193.html>) how to draw text
with Quartz 2D without changing any of the old QuickDraw code. The
advantage of Quartz is much better anti-aliasing. And because I
desperately wanted this anti-aliasing in Emacs Carbon, I searched for
the relevant section in the code and added a few lines as suggested by
Apple. It works on my computer (running Mac OS 10.3.7), but I have no
idea about the consequences for others, as I don't really know how
Emacs works internally.
I hope it helps to make Emacs more user-friendly on the Mac,
Arthur.
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: macterm.c.diff --]
[-- Type: text/x-patch, Size: 605 bytes --]
*** /tmp/ediff5861-oC Fri Jan 14 21:23:26 2005
--- /Users/aschus/Developer/emacs/src/macterm.c Fri Jan 14 19:07:09 2005
***************
*** 724,729 ****
--- 724,734 ----
char *buf;
int nchars, mode, bytes_per_char;
{
+ #ifdef MAC_OSX
+ UInt32 newFlags = kQDUseCGTextRendering;
+ UInt32 savedFlags = SwapQDTextFlags(newFlags);
+ #endif
+
SetPortWindowPort (w);
mac_set_colors (gc);
***************
*** 735,740 ****
--- 740,749 ----
MoveTo (x, y);
DrawText (buf, 0, nchars * bytes_per_char);
+
+ #ifdef MAC_OSX
+ SwapQDTextFlags(savedFlags);
+ #endif
}
[-- Attachment #3: Type: text/plain, Size: 142 bytes --]
_______________________________________________
Emacs-devel mailing list
Emacs-devel@gnu.org
http://lists.gnu.org/mailman/listinfo/emacs-devel
^ permalink raw reply [flat|nested] 17+ messages in thread
* Re: Patch for Mac OS X Text Drawing
2005-01-14 20:39 Patch for Mac OS X Text Drawing Arthur G.P. Schuster
@ 2005-01-16 0:39 ` Steven Tamm
2005-01-16 8:04 ` Arthur G.P. Schuster
` (2 more replies)
0 siblings, 3 replies; 17+ messages in thread
From: Steven Tamm @ 2005-01-16 0:39 UTC (permalink / raw)
Cc: emacs-devel
I've checked in a change that allows for anti-aliasing, but makes it
optional (personally I only use it for large fonts). I added the
variable:
mac-allow-anti-aliasing
This is defaulted to nil, meaning don't use core graphics to render
text. When set to non-nil, (setq mac-use-core-graphics t), it will
enable the core graphics rendering flag and will anti-alias text if
that is enabled on your computer for the font you are trying to
display. I'm not a big fan of the name, because there is some basic
anti-aliasing done in the operating system: but calling it
mac-enable-core-graphics was too technical.
Thanks,
-Steven
On Jan 14, 2005, at 12:39 PM, Arthur G.P. Schuster wrote:
> Hello,
>
> this is the first patch I have ever sent (and also the first time I
> used Ediff), so be kind. I found out (at
> <http://developer.apple.com/qa/qa2001/qa1193.html>) how to draw text
> with Quartz 2D without changing any of the old QuickDraw code. The
> advantage of Quartz is much better anti-aliasing. And because I
> desperately wanted this anti-aliasing in Emacs Carbon, I searched for
> the relevant section in the code and added a few lines as suggested by
> Apple. It works on my computer (running Mac OS 10.3.7), but I have no
> idea about the consequences for others, as I don't really know how
> Emacs works internally.
>
> I hope it helps to make Emacs more user-friendly on the Mac,
>
> Arthur.
>
> *** /tmp/ediff5861-oC Fri Jan 14 21:23:26 2005
> --- /Users/aschus/Developer/emacs/src/macterm.c Fri Jan 14 19:07:09
> 2005
> ***************
> *** 724,729 ****
> --- 724,734 ----
> char *buf;
> int nchars, mode, bytes_per_char;
> {
> + #ifdef MAC_OSX
> + UInt32 newFlags = kQDUseCGTextRendering;
> + UInt32 savedFlags = SwapQDTextFlags(newFlags);
> + #endif
> +
> SetPortWindowPort (w);
>
> mac_set_colors (gc);
> ***************
> *** 735,740 ****
> --- 740,749 ----
>
> MoveTo (x, y);
> DrawText (buf, 0, nchars * bytes_per_char);
> +
> + #ifdef MAC_OSX
> + SwapQDTextFlags(savedFlags);
> + #endif
> }
>
>
> _______________________________________________
> Emacs-devel mailing list
> Emacs-devel@gnu.org
> http://lists.gnu.org/mailman/listinfo/emacs-devel
^ permalink raw reply [flat|nested] 17+ messages in thread
* Re: Patch for Mac OS X Text Drawing
2005-01-16 0:39 ` Steven Tamm
@ 2005-01-16 8:04 ` Arthur G.P. Schuster
2005-01-17 3:18 ` YAMAMOTO Mitsuharu
2005-01-18 15:40 ` Piet van Oostrum
2 siblings, 0 replies; 17+ messages in thread
From: Arthur G.P. Schuster @ 2005-01-16 8:04 UTC (permalink / raw)
Cc: emacs-devel
Steven Tamm <steventamm@mac.com> writes:
> I've checked in a change that allows for anti-aliasing, but makes it
> optional (personally I only use it for large fonts).
Thank you very much, without some background knowledge I couldn't have
created such an elegant solution. BTW, I use ProFont at size 10 as
"default" font and Lucida Grande as "variable-pitch" font, although at
size 11 to compensate for the rather heavy ProFont.
Arthur
^ permalink raw reply [flat|nested] 17+ messages in thread
* Re: Patch for Mac OS X Text Drawing
2005-01-16 0:39 ` Steven Tamm
2005-01-16 8:04 ` Arthur G.P. Schuster
@ 2005-01-17 3:18 ` YAMAMOTO Mitsuharu
2005-01-17 5:31 ` Steven Tamm
2005-01-18 15:40 ` Piet van Oostrum
2 siblings, 1 reply; 17+ messages in thread
From: YAMAMOTO Mitsuharu @ 2005-01-17 3:18 UTC (permalink / raw)
Cc: Arthur G.P. Schuster, emacs-devel
>>>>> On Sat, 15 Jan 2005 16:39:19 -0800, Steven Tamm <steventamm@mac.com> said:
> I've checked in a change that allows for anti-aliasing, but makes it
> optional (personally I only use it for large fonts). I added the
> variable: mac-allow-anti-aliasing
I'd prefer specifying kQDUseCGTextMetrics as in
http://lists.gnu.org/archive/html/emacs-devel/2003-08/msg00139.html
http://lists.gnu.org/archive/html/bug-gnu-emacs/2004-07/msg00095.html
(Emulations of the srcCopy text transfer mode in them are no longer
needed because a recent change obviated the use of this mode.)
because that makes bold faces have the same width as their normal
ones. But that requires additional modifications because the metrics
are no longer compatible between two kinds of rendering engines:
QuickDraw and Quartz 2D. One way to do such modification would be
devising XLFD foundry names as "-apple quartz2d-..." or "-apple
cg-..." (or whatever).
Maybe we need to determine the followings:
* What do we choose?
- Kind of rendering engines?
- Use of anti-aliasing?
- Or both?
* How do we choose?
- By compilation option?
- By XLFD?
- By specifying the maximum font size by a lisp variable?
- ...
And its customization should not be too complicated.
I'd suggest two candidates:
1. Choose the kind of rendering engines by XLFD.
I already have a prototype for this strategy.
2. Fix the kind of rendering engines at a compilation time (Quartz
2D by default for >= 10.2), and control only the use of
anti-aliasing by a lisp variable. The variable is a list of
pairs of a regexp and a font size. And it overrides the system
provided setting of the maximum font size that uses
non-anti-aliased fonts for those that match the regexp.
I've been thinking about the former, but now I'm inclined to push the
latter.
YAMAMOTO Mitsuharu
mituharu@math.s.chiba-u.ac.jp
^ permalink raw reply [flat|nested] 17+ messages in thread
* Re: Patch for Mac OS X Text Drawing
2005-01-17 3:18 ` YAMAMOTO Mitsuharu
@ 2005-01-17 5:31 ` Steven Tamm
2005-01-17 11:21 ` YAMAMOTO Mitsuharu
0 siblings, 1 reply; 17+ messages in thread
From: Steven Tamm @ 2005-01-17 5:31 UTC (permalink / raw)
Cc: Arthur G.P. Schuster, emacs-devel
I'd rather not invest too much in this as the whole thing should be
replaced with ATSUI. With emacs22 and the switch to UTF8, it'll make
sense to redo all the font metric calculations. I put some time into
this, and now that I'm healthier, I'll start working on it some more.
However, adding the quick and dirty anti-aliasing seemed
straightforward enough. Switching over with every text call seemed
like overkill, but I wanted to make it based on a variable. With
reflection it should be a frame property; that'll make the use of
CGTextMetrics practical.
It seems odd to specify a regexp that includes font, including font
size, and then also specify a minimum font size. Perhaps relying on
the system preferences (or on Silk) would be enough?
-Steven
On Jan 16, 2005, at 7:18 PM, YAMAMOTO Mitsuharu wrote:
>>>>>> On Sat, 15 Jan 2005 16:39:19 -0800, Steven Tamm
>>>>>> <steventamm@mac.com> said:
>
>> I've checked in a change that allows for anti-aliasing, but makes it
>> optional (personally I only use it for large fonts). I added the
>> variable: mac-allow-anti-aliasing
>
> I'd prefer specifying kQDUseCGTextMetrics as in
>
> http://lists.gnu.org/archive/html/emacs-devel/2003-08/msg00139.html
> http://lists.gnu.org/archive/html/bug-gnu-emacs/2004-07/msg00095.html
> (Emulations of the srcCopy text transfer mode in them are no longer
> needed because a recent change obviated the use of this mode.)
>
> because that makes bold faces have the same width as their normal
> ones. But that requires additional modifications because the metrics
> are no longer compatible between two kinds of rendering engines:
> QuickDraw and Quartz 2D. One way to do such modification would be
> devising XLFD foundry names as "-apple quartz2d-..." or "-apple
> cg-..." (or whatever).
>
> Maybe we need to determine the followings:
>
> * What do we choose?
>
> - Kind of rendering engines?
> - Use of anti-aliasing?
> - Or both?
>
> * How do we choose?
>
> - By compilation option?
> - By XLFD?
> - By specifying the maximum font size by a lisp variable?
> - ...
>
> And its customization should not be too complicated.
>
> I'd suggest two candidates:
>
> 1. Choose the kind of rendering engines by XLFD.
> I already have a prototype for this strategy.
>
> 2. Fix the kind of rendering engines at a compilation time (Quartz
> 2D by default for >= 10.2), and control only the use of
> anti-aliasing by a lisp variable. The variable is a list of
> pairs of a regexp and a font size. And it overrides the system
> provided setting of the maximum font size that uses
> non-anti-aliased fonts for those that match the regexp.
>
> I've been thinking about the former, but now I'm inclined to push the
> latter.
>
> YAMAMOTO Mitsuharu
> mituharu@math.s.chiba-u.ac.jp
>
>
> _______________________________________________
> Emacs-devel mailing list
> Emacs-devel@gnu.org
> http://lists.gnu.org/mailman/listinfo/emacs-devel
^ permalink raw reply [flat|nested] 17+ messages in thread
* Re: Patch for Mac OS X Text Drawing
2005-01-17 5:31 ` Steven Tamm
@ 2005-01-17 11:21 ` YAMAMOTO Mitsuharu
0 siblings, 0 replies; 17+ messages in thread
From: YAMAMOTO Mitsuharu @ 2005-01-17 11:21 UTC (permalink / raw)
Cc: Arthur G.P. Schuster, emacs-devel
>>>>> On Sun, 16 Jan 2005 21:31:47 -0800, Steven Tamm <steventamm@mac.com> said:
> With reflection it should be a frame property; that'll make the use
> of CGTextMetrics practical.
We need different XFontStruct (MacFontStruct) structures for the fonts
that have different metrics. And the correspondence between a font
name and an XFontStruct structure is currently not frame-dependent
(although it is display-dependent on X11).
I don't know whether users want to use different kinds of rendering
engines per frame.
> It seems odd to specify a regexp that includes font, including font
> size, and then also specify a minimum font size. Perhaps relying on
> the system preferences (or on Silk) would be enough?
My intention was to enable users to use information in XLFD such as
family or registry for specifying the limit of anti-aliasing. It was
also an analogy from the variable face-font-rescale-alist.
But anyway, it turned out that my plan had a defect. I thought about
calling SetAntiAliasedTextEnabled within every text drawing call. But
it did not always work when Quartz 2D rendering was enabled: it worked
with "Monaco", but not with "Lucida sans typewriter".
YAMAMOTO Mitsuharu
mituharu@math.s.chiba-u.ac.jp
^ permalink raw reply [flat|nested] 17+ messages in thread
* Re: Patch for Mac OS X Text Drawing
2005-01-16 0:39 ` Steven Tamm
2005-01-16 8:04 ` Arthur G.P. Schuster
2005-01-17 3:18 ` YAMAMOTO Mitsuharu
@ 2005-01-18 15:40 ` Piet van Oostrum
2005-01-19 11:48 ` YAMAMOTO Mitsuharu
2 siblings, 1 reply; 17+ messages in thread
From: Piet van Oostrum @ 2005-01-18 15:40 UTC (permalink / raw)
[-- Attachment #1: Type: text/plain, Size: 1188 bytes --]
>>>>> Steven Tamm <steventamm@mac.com> (ST) wrote:
ST> I've checked in a change that allows for anti-aliasing, but makes it
ST> optional (personally I only use it for large fonts). I added the variable:
ST> mac-allow-anti-aliasing
ST> This is defaulted to nil, meaning don't use core graphics to render text.
ST> When set to non-nil, (setq mac-use-core-graphics t), it will enable the
Of course here you mean mac-allow-anti-alias
ST> core graphics rendering flag and will anti-alias text if that is enabled on
ST> your computer for the font you are trying to display. I'm not a big fan of
ST> the name, because there is some basic anti-aliasing done in the operating
ST> system: but calling it mac-enable-core-graphics was too technical.
It took a few hours for me to get used to it, but now I am starting to like
it.
I had hoped that this would solve the MacOSX bug where if you have some
italic text in a window which later is overwritten with spaces (like
happens in gnus summaries for me), small parts of the righthand side of
characters (those that stick out of the rectangular box) are not properly
erased. Also some characters are cutoff at the right. See the screen dump
[-- Attachment #2: screendump --]
[-- Type: image/png, Size: 16971 bytes --]
[-- Attachment #3: Type: text/plain, Size: 110 bytes --]
--
Piet van Oostrum <piet@cs.uu.nl>
URL: http://www.cs.uu.nl/~piet [PGP]
Private email: piet@vanoostrum.net
[-- Attachment #4: Type: text/plain, Size: 142 bytes --]
_______________________________________________
Emacs-devel mailing list
Emacs-devel@gnu.org
http://lists.gnu.org/mailman/listinfo/emacs-devel
^ permalink raw reply [flat|nested] 17+ messages in thread
* Re: Patch for Mac OS X Text Drawing
2005-01-18 15:40 ` Piet van Oostrum
@ 2005-01-19 11:48 ` YAMAMOTO Mitsuharu
2005-01-21 7:57 ` YAMAMOTO Mitsuharu
0 siblings, 1 reply; 17+ messages in thread
From: YAMAMOTO Mitsuharu @ 2005-01-19 11:48 UTC (permalink / raw)
Cc: emacs-devel
[-- Attachment #1: Type: text/plain, Size: 917 bytes --]
>>>>> On Tue, 18 Jan 2005 16:40:24 +0100, Piet van Oostrum <piet@cs.uu.nl> said:
> I had hoped that this would solve the MacOSX bug where if you have
> some italic text in a window which later is overwritten with spaces
> (like happens in gnus summaries for me), small parts of the
> righthand side of characters (those that stick out of the
> rectangular box) are not properly erased. Also some characters are
> cutoff at the right.
The X11 version does handle that case. Basically, we can also do the
same thing on Mac OS X/Carbon (try the attached patch). But this is
not enough when used with anti-aliasing, because text drawing is no
longer idempotent: if the same text is drawn several times onto the
same place, it gets thicker. You will notice that cursor movement
makes some characters look like in bold face as in the attached
screenshot.
YAMAMOTO Mitsuharu
mituharu@math.s.chiba-u.ac.jp
[-- Attachment #2: screenshot.png --]
[-- Type: image/png, Size: 3302 bytes --]
[-- Attachment #3: diff-overhang-experiment.gz --]
[-- Type: application/octet-stream, Size: 1198 bytes --]
[-- Attachment #4: Type: text/plain, Size: 142 bytes --]
_______________________________________________
Emacs-devel mailing list
Emacs-devel@gnu.org
http://lists.gnu.org/mailman/listinfo/emacs-devel
^ permalink raw reply [flat|nested] 17+ messages in thread
* Re: Patch for Mac OS X Text Drawing
2005-01-19 11:48 ` YAMAMOTO Mitsuharu
@ 2005-01-21 7:57 ` YAMAMOTO Mitsuharu
2005-01-22 2:52 ` Richard Stallman
[not found] ` <200501210353.j0L3rbj16707@church.math.s.chiba-u.ac.jp>
0 siblings, 2 replies; 17+ messages in thread
From: YAMAMOTO Mitsuharu @ 2005-01-21 7:57 UTC (permalink / raw)
Cc: emacs-devel
>>>>> On Wed, 19 Jan 2005 20:48:47 +0900, YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> said:
>> I had hoped that this would solve the MacOSX bug where if you have
>> some italic text in a window which later is overwritten with spaces
> The X11 version does handle that case. Basically, we can also do
> the same thing on Mac OS X/Carbon (try the attached patch). But
> this is not enough when used with anti-aliasing, because text
> drawing is no longer idempotent: if the same text is drawn several
> times onto the same place, it gets thicker.
The patch below works for me. Carbon Emacs users can test it with the
previously posted macterm.c patch. (Note that the macterm.c patch is
experimental, and only works for one-byte fonts.)
Could someone check if the following change makes sense?
YAMAMOTO Mitsuharu
mituharu@math.s.chiba-u.ac.jp
Index: src/dispextern.h
===================================================================
RCS file: /cvsroot/emacs/emacs/src/dispextern.h,v
retrieving revision 1.192
diff -c -r1.192 dispextern.h
*** src/dispextern.h 10 Jan 2005 13:30:46 -0000 1.192
--- src/dispextern.h 21 Jan 2005 05:03:17 -0000
***************
*** 1193,1198 ****
--- 1193,1203 ----
/* Slice */
struct glyph_slice slice;
+ /* Non-null means the horizontal clipping region starts from the
+ left edge of *clip_head, and ends with the right edge of
+ *clip_tail, not including their overhangs. */
+ struct glyph_string *clip_head, *clip_tail;
+
struct glyph_string *next, *prev;
};
Index: src/xdisp.c
===================================================================
RCS file: /cvsroot/emacs/emacs/src/xdisp.c,v
retrieving revision 1.966
diff -c -r1.966 xdisp.c
*** src/xdisp.c 19 Jan 2005 10:05:28 -0000 1.966
--- src/xdisp.c 21 Jan 2005 05:03:18 -0000
***************
*** 1776,1781 ****
--- 1776,1799 ----
r.height = s->row->visible_height;
}
+ if (s->clip_head)
+ if (r.x < s->clip_head->x)
+ {
+ if (r.width >= s->clip_head->x - r.x)
+ r.width -= s->clip_head->x - r.x;
+ else
+ r.width = 0;
+ r.x = s->clip_head->x;
+ }
+ if (s->clip_tail)
+ if (r.x + r.width > s->clip_tail->x + s->clip_tail->width)
+ {
+ if (s->clip_tail->x + s->clip_tail->width >= r.x)
+ r.width = s->clip_tail->x + s->clip_tail->width - r.x;
+ else
+ r.width = 0;
+ }
+
/* If S draws overlapping rows, it's sufficient to use the top and
bottom of the window for clipping because this glyph string
intentionally draws over other lines. */
***************
*** 18269,18274 ****
--- 18287,18293 ----
{
int dummy_x = 0;
struct glyph_string *h, *t;
+ struct glyph_string *clip_head = NULL, *clip_tail = NULL;
/* Compute overhangs for all glyph strings. */
if (rif->compute_glyph_string_overhangs)
***************
*** 18289,18294 ****
--- 18308,18314 ----
start = i;
compute_overhangs_and_x (t, head->x, 1);
prepend_glyph_string_lists (&head, &tail, h, t);
+ clip_head = head;
}
/* Prepend glyph strings for glyphs in front of the first glyph
***************
*** 18301,18306 ****
--- 18321,18327 ----
i = left_overwriting (head);
if (i >= 0)
{
+ clip_head = head;
BUILD_GLYPH_STRINGS (i, start, h, t,
DRAW_NORMAL_TEXT, dummy_x, last_x);
for (s = h; s; s = s->next)
***************
*** 18320,18325 ****
--- 18341,18347 ----
DRAW_NORMAL_TEXT, x, last_x);
compute_overhangs_and_x (h, tail->x + tail->width, 0);
append_glyph_string_lists (&head, &tail, h, t);
+ clip_tail = tail;
}
/* Append glyph strings for glyphs following the last glyph
***************
*** 18330,18335 ****
--- 18352,18358 ----
i = right_overwriting (tail);
if (i >= 0)
{
+ clip_tail = tail;
BUILD_GLYPH_STRINGS (end, i, h, t,
DRAW_NORMAL_TEXT, x, last_x);
for (s = h; s; s = s->next)
***************
*** 18337,18342 ****
--- 18360,18371 ----
compute_overhangs_and_x (h, tail->x + tail->width, 0);
append_glyph_string_lists (&head, &tail, h, t);
}
+ if (clip_head || clip_tail)
+ for (s = head; s; s = s->next)
+ {
+ s->clip_head = clip_head;
+ s->clip_tail = clip_tail;
+ }
}
/* Draw all strings. */
^ permalink raw reply [flat|nested] 17+ messages in thread
* Re: Patch for Mac OS X Text Drawing
2005-01-21 7:57 ` YAMAMOTO Mitsuharu
@ 2005-01-22 2:52 ` Richard Stallman
2005-01-22 3:47 ` YAMAMOTO Mitsuharu
[not found] ` <200501210353.j0L3rbj16707@church.math.s.chiba-u.ac.jp>
1 sibling, 1 reply; 17+ messages in thread
From: Richard Stallman @ 2005-01-22 2:52 UTC (permalink / raw)
Cc: piet, emacs-devel
It seems strange that a Mac-only bug would need system-independent changes.
Why is that?
^ permalink raw reply [flat|nested] 17+ messages in thread
* Re: Patch for Mac OS X Text Drawing
2005-01-22 2:52 ` Richard Stallman
@ 2005-01-22 3:47 ` YAMAMOTO Mitsuharu
2005-01-22 4:55 ` Kenichi Handa
0 siblings, 1 reply; 17+ messages in thread
From: YAMAMOTO Mitsuharu @ 2005-01-22 3:47 UTC (permalink / raw)
Cc: piet, emacs-devel
>>>>> On Fri, 21 Jan 2005 21:52:55 -0500, Richard Stallman <rms@gnu.org> said:
> It seems strange that a Mac-only bug would need system-independent
> changes. Why is that?
Because the current (system-independent) code assumes that drawing the
same character over the existing one does not change its appearance,
but that's not true on Mac OS X with text anti-aliasing.
Quote from http://developer.apple.com/qa/qa2001/qa1193.html:
Avoid double-drawing the same text because anti-aliased areas darken
with repeated over-drawing.
I'm not sure about other environments with anti-aliasing such as Xft
and ClearType. Does anyone know about how over-drawing is treated
there?
YAMAMOTO Mitsuharu
mituharu@math.s.chiba-u.ac.jp
^ permalink raw reply [flat|nested] 17+ messages in thread
* Re: Patch for Mac OS X Text Drawing
2005-01-22 3:47 ` YAMAMOTO Mitsuharu
@ 2005-01-22 4:55 ` Kenichi Handa
2005-01-22 5:49 ` YAMAMOTO Mitsuharu
0 siblings, 1 reply; 17+ messages in thread
From: Kenichi Handa @ 2005-01-22 4:55 UTC (permalink / raw)
Cc: piet, rms, emacs-devel
In article <20050122.124732.63490425.mituharu@math.s.chiba-u.ac.jp>, YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> writes:
> Because the current (system-independent) code assumes that drawing the
> same character over the existing one does not change its appearance,
> but that's not true on Mac OS X with text anti-aliasing.
> Quote from http://developer.apple.com/qa/qa2001/qa1193.html:
> Avoid double-drawing the same text because anti-aliased areas darken
> with repeated over-drawing.
> I'm not sure about other environments with anti-aliasing such as Xft
> and ClearType. Does anyone know about how over-drawing is treated
> there?
The tutorial of Xft says to clear or fill an area before
drawing a text there as below:
------------------------------------------------------------
5.3 Text Drawing
Xft doesn't support "image text" at all; rather the application must
explicitly fill the background rectangle before drawing the string. With AA
text, there's no other way to make it work.
XDrawString -> XftDrawString8
XDrawImageString -> XftDrawRect + XftDrawString8
Note that drawing the same string multiple times in the same place will
generate the wrong result with AA text. This can be especially hard to fix
in applications that avoid setting clipping when redrawing parts of
windows. An easy fix here is to simply clear the entire window before
redrawing it. This does cause extensive flashing on the screen, the
alternative is to use clipping and make sure that any areas within the clip
region get cleared to the background before text is drawn on top.
------------------------------------------------------------
---
Ken'ichi HANDA
handa@m17n.org
^ permalink raw reply [flat|nested] 17+ messages in thread
* Re: Patch for Mac OS X Text Drawing
2005-01-22 4:55 ` Kenichi Handa
@ 2005-01-22 5:49 ` YAMAMOTO Mitsuharu
0 siblings, 0 replies; 17+ messages in thread
From: YAMAMOTO Mitsuharu @ 2005-01-22 5:49 UTC (permalink / raw)
Cc: piet, rms, emacs-devel
>>>>> On Sat, 22 Jan 2005 13:55:46 +0900 (JST), Kenichi Handa <handa@m17n.org> said:
>> I'm not sure about other environments with anti-aliasing such as
>> Xft and ClearType. Does anyone know about how over-drawing is
>> treated there?
> The tutorial of Xft says to clear or fill an area before drawing a
> text there as below:
> 5.3 Text Drawing
> Note that drawing the same string multiple times in the same place
> will generate the wrong result with AA text.
Thanks for the info. The situation in Xft seems to be quite similar.
> the alternative is to use clipping and make sure that any areas
> within the clip region get cleared to the background before text is
> drawn on top.
The above sentence exactly explains what I intended by the patch.
YAMAMOTO Mitsuharu
mituharu@math.s.chiba-u.ac.jp
^ permalink raw reply [flat|nested] 17+ messages in thread
* Re: Patch for Mac OS X Text Drawing
[not found] ` <200501210353.j0L3rbj16707@church.math.s.chiba-u.ac.jp>
@ 2005-01-24 9:36 ` YAMAMOTO Mitsuharu
2005-01-24 10:08 ` Kim F. Storm
0 siblings, 1 reply; 17+ messages in thread
From: YAMAMOTO Mitsuharu @ 2005-01-24 9:36 UTC (permalink / raw)
>>>>> On Fri, 21 Jan 2005 16:57:51 +0900, YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> said:
> Could someone check if the following change makes sense?
It turned out that the posted patch was closely related to the
following problem (also on X11), which I've reported to
emacs-pretest-bug:
>>>>> On Fri, 21 Jan 2005 12:53:37 +0900 (JST), YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> said:
> I noticed that the cursor remained unerased with the following
> procedure:
> 1. % emacs -Q -fn -adobe-courier-bold-o-normal--12-120-75-75-m-70-iso8859-1 &
> 2. Type "RET C-p W C-b W W W W ...."
> This happens with any cursor type.
Here is a revised patch including a fix for the above bug.
YAMAMOTO Mituharu
mituharu@math.s.chiba-u.ac.jp
Index: src/dispextern.h
===================================================================
RCS file: /cvsroot/emacs/emacs/src/dispextern.h,v
retrieving revision 1.192
diff -c -r1.192 dispextern.h
*** src/dispextern.h 10 Jan 2005 13:30:46 -0000 1.192
--- src/dispextern.h 24 Jan 2005 08:42:45 -0000
***************
*** 1193,1198 ****
--- 1193,1203 ----
/* Slice */
struct glyph_slice slice;
+ /* Non-null means the horizontal clipping region starts from the
+ left edge of *clip_head, and ends with the right edge of
+ *clip_tail, not including their overhangs. */
+ struct glyph_string *clip_head, *clip_tail;
+
struct glyph_string *next, *prev;
};
Index: src/xdisp.c
===================================================================
RCS file: /cvsroot/emacs/emacs/src/xdisp.c,v
retrieving revision 1.969
diff -c -r1.969 xdisp.c
*** src/xdisp.c 23 Jan 2005 00:50:52 -0000 1.969
--- src/xdisp.c 24 Jan 2005 08:42:47 -0000
***************
*** 1786,1791 ****
--- 1786,1809 ----
r.height = s->row->visible_height;
}
+ if (s->clip_head)
+ if (r.x < s->clip_head->x)
+ {
+ if (r.width >= s->clip_head->x - r.x)
+ r.width -= s->clip_head->x - r.x;
+ else
+ r.width = 0;
+ r.x = s->clip_head->x;
+ }
+ if (s->clip_tail)
+ if (r.x + r.width > s->clip_tail->x + s->clip_tail->background_width)
+ {
+ if (s->clip_tail->x + s->clip_tail->background_width >= r.x)
+ r.width = s->clip_tail->x + s->clip_tail->background_width - r.x;
+ else
+ r.width = 0;
+ }
+
/* If S draws overlapping rows, it's sufficient to use the top and
bottom of the window for clipping because this glyph string
intentionally draws over other lines. */
***************
*** 18231,18236 ****
--- 18249,18255 ----
{
struct glyph_string *head, *tail;
struct glyph_string *s;
+ struct glyph_string *clip_head = NULL, *clip_tail = NULL;
int last_x, area_width;
int x_reached;
int i, j;
***************
*** 18299,18304 ****
--- 18318,18324 ----
start = i;
compute_overhangs_and_x (t, head->x, 1);
prepend_glyph_string_lists (&head, &tail, h, t);
+ clip_head = head;
}
/* Prepend glyph strings for glyphs in front of the first glyph
***************
*** 18311,18316 ****
--- 18331,18337 ----
i = left_overwriting (head);
if (i >= 0)
{
+ clip_head = head;
BUILD_GLYPH_STRINGS (i, start, h, t,
DRAW_NORMAL_TEXT, dummy_x, last_x);
for (s = h; s; s = s->next)
***************
*** 18330,18335 ****
--- 18351,18357 ----
DRAW_NORMAL_TEXT, x, last_x);
compute_overhangs_and_x (h, tail->x + tail->width, 0);
append_glyph_string_lists (&head, &tail, h, t);
+ clip_tail = tail;
}
/* Append glyph strings for glyphs following the last glyph
***************
*** 18340,18345 ****
--- 18362,18368 ----
i = right_overwriting (tail);
if (i >= 0)
{
+ clip_tail = tail;
BUILD_GLYPH_STRINGS (end, i, h, t,
DRAW_NORMAL_TEXT, x, last_x);
for (s = h; s; s = s->next)
***************
*** 18347,18352 ****
--- 18370,18381 ----
compute_overhangs_and_x (h, tail->x + tail->width, 0);
append_glyph_string_lists (&head, &tail, h, t);
}
+ if (clip_head || clip_tail)
+ for (s = head; s; s = s->next)
+ {
+ s->clip_head = clip_head;
+ s->clip_tail = clip_tail;
+ }
}
/* Draw all strings. */
***************
*** 18360,18367 ****
completely. */
&& !overlaps_p)
{
! int x0 = head ? head->x : x;
! int x1 = tail ? tail->x + tail->background_width : x;
int text_left = window_box_left (w, TEXT_AREA);
x0 -= text_left;
--- 18389,18397 ----
completely. */
&& !overlaps_p)
{
! int x0 = clip_head ? clip_head->x : (head ? head->x : x);
! int x1 = (clip_tail ? clip_tail->x + clip_tail->background_width
! : (tail ? tail->x + tail->background_width : x));
int text_left = window_box_left (w, TEXT_AREA);
x0 -= text_left;
^ permalink raw reply [flat|nested] 17+ messages in thread
* Re: Patch for Mac OS X Text Drawing
2005-01-24 9:36 ` YAMAMOTO Mitsuharu
@ 2005-01-24 10:08 ` Kim F. Storm
2005-01-24 11:15 ` YAMAMOTO Mitsuharu
0 siblings, 1 reply; 17+ messages in thread
From: Kim F. Storm @ 2005-01-24 10:08 UTC (permalink / raw)
Cc: emacs-devel
YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> writes:
>>>>>> On Fri, 21 Jan 2005 16:57:51 +0900, YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> said:
>
>> Could someone check if the following change makes sense?
>
> It turned out that the posted patch was closely related to the
> following problem (also on X11), which I've reported to
> emacs-pretest-bug:
>
>>>>>> On Fri, 21 Jan 2005 12:53:37 +0900 (JST), YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> said:
>
>> I noticed that the cursor remained unerased with the following
>> procedure:
>
>> 1. % emacs -Q -fn -adobe-courier-bold-o-normal--12-120-75-75-m-70-iso8859-1 &
>> 2. Type "RET C-p W C-b W W W W ...."
>
>> This happens with any cursor type.
>
> Here is a revised patch including a fix for the above bug.
Very good, thanks! Please install it.
--
Kim F. Storm <storm@cua.dk> http://www.cua.dk
^ permalink raw reply [flat|nested] 17+ messages in thread
* Re: Patch for Mac OS X Text Drawing
2005-01-24 10:08 ` Kim F. Storm
@ 2005-01-24 11:15 ` YAMAMOTO Mitsuharu
2005-01-24 18:00 ` Steven Tamm
0 siblings, 1 reply; 17+ messages in thread
From: YAMAMOTO Mitsuharu @ 2005-01-24 11:15 UTC (permalink / raw)
Cc: emacs-devel
[-- Attachment #1: Type: text/plain, Size: 1395 bytes --]
>>>>> On Mon, 24 Jan 2005 11:08:02 +0100, storm@cua.dk (Kim F. Storm) said:
>> Here is a revised patch including a fix for the above bug.
> Very good, thanks! Please install it.
Thanks for checking. I'd like to leave it to Steven because the whole
patch (attached below) includes some changes for Mac. Actually, I
cannot do it by myself at the moment.
YAMAMOTO Mitsuharu
mituharu@math.s.chiba-u.ac.jp
2005-01-24 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
* dispextern.h (struct glyph_string): New members clip_head and
clip_tail.
* xdisp.c (get_glyph_string_clip_rect): Restrict horizontal clip
region to the area between clip_head and clip_tail.
(draw_glyphs): Record the area that need to be actually redrawn to
the new variables clip_head and clip_tail when there are
overhangs. Set values of these variables to the corresponding
members in struct glyph_string. Refine x coordinates for
notice_overwritten_cursor using clip_head and clip_tail.
* macgui.h (STORE_XCHARSETSTRUCT): New macro.
* macterm.c (mac_compute_glyph_string_overhangs): Implement with
QDTextBounds.
(x_draw_glyph_string): Don't fill the background of the successor
of a glyph with a right overhang if the successor will draw a
cursor.
(XLoadQueryFont): Obtain font metrics using QDTextBounds.
(x_redisplay_interface): Add entry for
compute_glyph_string_overhangs.
[-- Attachment #2: diff-overhangs.gz --]
[-- Type: application/octet-stream, Size: 3143 bytes --]
[-- Attachment #3: Type: text/plain, Size: 142 bytes --]
_______________________________________________
Emacs-devel mailing list
Emacs-devel@gnu.org
http://lists.gnu.org/mailman/listinfo/emacs-devel
^ permalink raw reply [flat|nested] 17+ messages in thread
* Re: Patch for Mac OS X Text Drawing
2005-01-24 11:15 ` YAMAMOTO Mitsuharu
@ 2005-01-24 18:00 ` Steven Tamm
0 siblings, 0 replies; 17+ messages in thread
From: Steven Tamm @ 2005-01-24 18:00 UTC (permalink / raw)
Cc: Kim F. Storm, emacs-devel
I checked this in.
Although I think it may make sense to grant CVS access to Mr. Yamamoto,
as the patches are now going outside the domain of just Mac/Carbon and
into the whole realm of display rendering on all platforms.
-Steven
On Jan 24, 2005, at 3:15 AM, YAMAMOTO Mitsuharu wrote:
>>>>>> On Mon, 24 Jan 2005 11:08:02 +0100, storm@cua.dk (Kim F. Storm)
>>>>>> said:
>
>>> Here is a revised patch including a fix for the above bug.
>
>> Very good, thanks! Please install it.
>
> Thanks for checking. I'd like to leave it to Steven because the whole
> patch (attached below) includes some changes for Mac. Actually, I
> cannot do it by myself at the moment.
>
> YAMAMOTO Mitsuharu
> mituharu@math.s.chiba-u.ac.jp
>
> 2005-01-24 YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp>
>
> * dispextern.h (struct glyph_string): New members clip_head and
> clip_tail.
>
> * xdisp.c (get_glyph_string_clip_rect): Restrict horizontal clip
> region to the area between clip_head and clip_tail.
> (draw_glyphs): Record the area that need to be actually redrawn to
> the new variables clip_head and clip_tail when there are
> overhangs. Set values of these variables to the corresponding
> members in struct glyph_string. Refine x coordinates for
> notice_overwritten_cursor using clip_head and clip_tail.
>
> * macgui.h (STORE_XCHARSETSTRUCT): New macro.
>
> * macterm.c (mac_compute_glyph_string_overhangs): Implement with
> QDTextBounds.
> (x_draw_glyph_string): Don't fill the background of the successor
> of a glyph with a right overhang if the successor will draw a
> cursor.
> (XLoadQueryFont): Obtain font metrics using QDTextBounds.
> (x_redisplay_interface): Add entry for
> compute_glyph_string_overhangs.
>
> <diff-overhangs.gz>_______________________________________________
> Emacs-devel mailing list
> Emacs-devel@gnu.org
> http://lists.gnu.org/mailman/listinfo/emacs-devel
^ permalink raw reply [flat|nested] 17+ messages in thread
end of thread, other threads:[~2005-01-24 18:00 UTC | newest]
Thread overview: 17+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2005-01-14 20:39 Patch for Mac OS X Text Drawing Arthur G.P. Schuster
2005-01-16 0:39 ` Steven Tamm
2005-01-16 8:04 ` Arthur G.P. Schuster
2005-01-17 3:18 ` YAMAMOTO Mitsuharu
2005-01-17 5:31 ` Steven Tamm
2005-01-17 11:21 ` YAMAMOTO Mitsuharu
2005-01-18 15:40 ` Piet van Oostrum
2005-01-19 11:48 ` YAMAMOTO Mitsuharu
2005-01-21 7:57 ` YAMAMOTO Mitsuharu
2005-01-22 2:52 ` Richard Stallman
2005-01-22 3:47 ` YAMAMOTO Mitsuharu
2005-01-22 4:55 ` Kenichi Handa
2005-01-22 5:49 ` YAMAMOTO Mitsuharu
[not found] ` <200501210353.j0L3rbj16707@church.math.s.chiba-u.ac.jp>
2005-01-24 9:36 ` YAMAMOTO Mitsuharu
2005-01-24 10:08 ` Kim F. Storm
2005-01-24 11:15 ` YAMAMOTO Mitsuharu
2005-01-24 18:00 ` Steven Tamm
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/emacs.git
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.