* Several suggestions for image support @ 2004-04-16 0:21 David Kastrup 2004-04-16 9:29 ` YAMAMOTO Mitsuharu ` (3 more replies) 0 siblings, 4 replies; 95+ messages in thread From: David Kastrup @ 2004-04-16 0:21 UTC (permalink / raw) PNG images support transparency. Emacs can't make use of it. You can only have Emacs declare a particular color as transparent. This is dissatisfactory. It should tell the PNG decoding routines Emacs' background color for the purpose of transparency. I would find it important if an image specifier could restrict the displayed portion of an image. The reason is that large images always appear as a single big character to Emacs. If I could split such an image into a bunch of smaller images, I could walk through it with the cursor. But it should only be necessary to instantiate the complete image itself once for this purpose. Of course, one should find a way that does not cause all of the subimages to be entered separately into the image cache. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 0:21 Several suggestions for image support David Kastrup @ 2004-04-16 9:29 ` YAMAMOTO Mitsuharu 2004-04-16 14:02 ` Kim F. Storm 2004-04-16 10:22 ` Kim F. Storm ` (2 subsequent siblings) 3 siblings, 1 reply; 95+ messages in thread From: YAMAMOTO Mitsuharu @ 2004-04-16 9:29 UTC (permalink / raw) >>>>> On 16 Apr 2004 02:21:11 +0200, David Kastrup <dak@gnu.org> said: > PNG images support transparency. Emacs can't make use of it. You > can only have Emacs declare a particular color as transparent. This > is dissatisfactory. It should tell the PNG decoding routines Emacs' > background color for the purpose of transparency. As for PNG transparency, there was one thing that I noticed (and I've been forgotten to tell about it) while I was porting image support to Carbon Emacs. In png_load (image.c): user_bg.red = color.red >> PNG_BG_COLOR_SHIFT; user_bg.green = color.green >> PNG_BG_COLOR_SHIFT; user_bg.blue = color.blue >> PNG_BG_COLOR_SHIFT; fn_png_set_background (png_ptr, &user_bg, PNG_BACKGROUND_GAMMA_SCREEN, 0, 1.0); I think the background color should be specified in 8-bit depth here (thus PNG_BG_COLOR_SHIFT should be 8 for all the platforms) because the 4th argument (aka need_expand) for fn_png_set_background is 0 and the image data has been normalized in 8-bit depth at this stage. You can observe the difference using http://www.w3.org/Graphics/PNG/alphatest.png. The same thing is also applied to the other place (in png_load) where fn_png_set_background is called with its 4th argument 0. YAMAMOTO Mitsuharu mituharu@math.s.chiba-u.ac.jp ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 9:29 ` YAMAMOTO Mitsuharu @ 2004-04-16 14:02 ` Kim F. Storm 2004-04-16 12:50 ` Jason Rumney 0 siblings, 1 reply; 95+ messages in thread From: Kim F. Storm @ 2004-04-16 14:02 UTC (permalink / raw) Cc: emacs-devel YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> writes: > >>>>> On 16 Apr 2004 02:21:11 +0200, David Kastrup <dak@gnu.org> said: > > > PNG images support transparency. Emacs can't make use of it. You > > can only have Emacs declare a particular color as transparent. This > > is dissatisfactory. It should tell the PNG decoding routines Emacs' > > background color for the purpose of transparency. > > As for PNG transparency, there was one thing that I noticed (and I've > been forgotten to tell about it) while I was porting image support to > Carbon Emacs. > > In png_load (image.c): > > user_bg.red = color.red >> PNG_BG_COLOR_SHIFT; > user_bg.green = color.green >> PNG_BG_COLOR_SHIFT; > user_bg.blue = color.blue >> PNG_BG_COLOR_SHIFT; > > fn_png_set_background (png_ptr, &user_bg, > PNG_BACKGROUND_GAMMA_SCREEN, 0, 1.0); > > I think the background color should be specified in 8-bit depth here > (thus PNG_BG_COLOR_SHIFT should be 8 for all the platforms) because > the 4th argument (aka need_expand) for fn_png_set_background is 0 and > the image data has been normalized in 8-bit depth at this stage. I can indeed see that 8-bit shift is the right setting on X. > You > can observe the difference using > http://www.w3.org/Graphics/PNG/alphatest.png. The same thing is also > applied to the other place (in png_load) where fn_png_set_background > is called with its 4th argument 0. You are right. Shifting 8 bits here as well on X fixes transparent bg. I will commit a fix for X shortly. However, on W32, it seems that it explicitly scales things to 16 bits in both cases. I cannot test this on W32, so I cannot say what's the right thing to do. Here is an easy way to test it -- after downloading the image you mentioned: (insert-image (create-image "alphatest.png")) this should result in a light blue image with nice rounded edges; a darker blue with rough edges indicates a problem. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 14:02 ` Kim F. Storm @ 2004-04-16 12:50 ` Jason Rumney 2004-04-16 16:59 ` Kim F. Storm 0 siblings, 1 reply; 95+ messages in thread From: Jason Rumney @ 2004-04-16 12:50 UTC (permalink / raw) Cc: YAMAMOTO Mitsuharu, emacs-devel Kim F. Storm wrote: > You are right. Shifting 8 bits here as well on X fixes transparent bg. > I will commit a fix for X shortly. > > However, on W32, it seems that it explicitly scales things to 16 bits > in both cases. I cannot test this on W32, so I cannot say what's > the right thing to do. The W32 port scales to 16 bits in places because the native Windows COLORREF is 8 bits, while Emacs XColor is 16 bits. So in this case, 8 bits is right, but alpha is currently coming out wrong. I suspect the use of COLOREF instead of XColor that you considered a bug when merging the image code (see comment around that location) was in fact not a bug. > Here is an easy way to test it -- after downloading the image you > mentioned: > > (insert-image (create-image "alphatest.png")) > > this should result in a light blue image with nice rounded > edges; a darker blue with rough edges indicates a problem. On Windows the image comes out with a black background and the image has rainbow colored stripes. Non-alpha PNGs look OK. ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 12:50 ` Jason Rumney @ 2004-04-16 16:59 ` Kim F. Storm 2004-04-16 15:18 ` Jason Rumney 0 siblings, 1 reply; 95+ messages in thread From: Kim F. Storm @ 2004-04-16 16:59 UTC (permalink / raw) Cc: YAMAMOTO Mitsuharu, emacs-devel Jason Rumney <jasonr@gnu.org> writes: > Kim F. Storm wrote: > > > You are right. Shifting 8 bits here as well on X fixes transparent bg. > > I will commit a fix for X shortly. > > However, on W32, it seems that it explicitly scales things to 16 > > bits > > in both cases. I cannot test this on W32, so I cannot say what's > > the right thing to do. > > The W32 port scales to 16 bits in places because the native Windows > COLORREF is 8 bits, while Emacs XColor is 16 bits. So in this case, 8 > bits is right, but alpha is currently coming out wrong. I suspect the > use of COLOREF instead of XColor that you considered a bug when > merging the image code (see comment around that location) was in fact > not a bug. But w32_defined_color has an XColor * as third arg, not COLORREF. And w32_defined_color seems to return "properly scaled" values, so it seems like it should be shifted >> 8 like the other ports. > > > Here is an easy way to test it -- after downloading the image you > > mentioned: > > (insert-image (create-image "alphatest.png")) > > this should result in a light blue image with nice rounded > > edges; a darker blue with rough edges indicates a problem. > > On Windows the image comes out with a black background and the image > has rainbow colored stripes. Non-alpha PNGs look OK. > That is more or less as I expected. Can you try to change in image.c around line 5454: frame_background.red = 256 * GetRValue (color); frame_background.green = 256 * GetGValue (color); frame_background.blue = 256 * GetBValue (color); to frame_background.red = GetRValue (color); frame_background.green = GetGValue (color); frame_background.blue = GetBValue (color); -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 16:59 ` Kim F. Storm @ 2004-04-16 15:18 ` Jason Rumney 0 siblings, 0 replies; 95+ messages in thread From: Jason Rumney @ 2004-04-16 15:18 UTC (permalink / raw) Cc: YAMAMOTO Mitsuharu, emacs-devel > Can you try to change in image.c around line 5454: > > frame_background.red = 256 * GetRValue (color); > frame_background.green = 256 * GetGValue (color); > frame_background.blue = 256 * GetBValue (color); > > to > > frame_background.red = GetRValue (color); > frame_background.green = GetGValue (color); > frame_background.blue = GetBValue (color); Yes, that (in combination with setting PNG_BG_COLOR_SHIFT to 8) fixed it. ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 0:21 Several suggestions for image support David Kastrup 2004-04-16 9:29 ` YAMAMOTO Mitsuharu @ 2004-04-16 10:22 ` Kim F. Storm 2004-04-16 9:09 ` Jason Rumney 2004-04-16 10:06 ` David Kastrup 2004-04-17 7:16 ` Richard Stallman 2004-04-21 1:08 ` Kim F. Storm 3 siblings, 2 replies; 95+ messages in thread From: Kim F. Storm @ 2004-04-16 10:22 UTC (permalink / raw) Cc: emacs-devel David Kastrup <dak@gnu.org> writes: > PNG images support transparency. Emacs can't make use of it. You can > only have Emacs declare a particular color as transparent. This is > dissatisfactory. It should tell the PNG decoding routines Emacs' > background color for the purpose of transparency. Using `:mask heuristic' should make the image background transparent. The tool-bar code uses this. I suppose you know that, so what's the problem with this approach? > > I would find it important if an image specifier could restrict the > displayed portion of an image. This might be useful for other reasons, e.g. image panning. Zoom (scaling) would be useful too. > > The reason is that large images always appear as a single big > character to Emacs. If I could split such an image into a bunch of > smaller images, I could walk through it with the cursor. But it > should only be necessary to instantiate the complete image itself once > for this purpose. Of course, one should find a way that does not > cause all of the subimages to be entered separately into the image > cache. Something like this is already on my to-do list. However, I have other ideas to make image scrolling work, and it is at the top of my to-do list. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 10:22 ` Kim F. Storm @ 2004-04-16 9:09 ` Jason Rumney 2004-04-16 10:06 ` David Kastrup 1 sibling, 0 replies; 95+ messages in thread From: Jason Rumney @ 2004-04-16 9:09 UTC (permalink / raw) Cc: David Kastrup, emacs-devel Kim F. Storm wrote: > David Kastrup <dak@gnu.org> writes: > >>PNG images support transparency. Emacs can't make use of it. You can >>only have Emacs declare a particular color as transparent. This is >>dissatisfactory. It should tell the PNG decoding routines Emacs' >>background color for the purpose of transparency. > > Using `:mask heuristic' should make the image background transparent. > The tool-bar code uses this. I don't think :mask heuristic has anything to do with PNG transparency. It is for heuristically determining the background color of a non-transparent image, in order to make it transparent. That said, PNG transparency used to just work back when I was porting image support to Windows. ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 10:22 ` Kim F. Storm 2004-04-16 9:09 ` Jason Rumney @ 2004-04-16 10:06 ` David Kastrup 2004-04-16 12:38 ` Kim F. Storm 2004-04-16 13:39 ` Stefan Monnier 1 sibling, 2 replies; 95+ messages in thread From: David Kastrup @ 2004-04-16 10:06 UTC (permalink / raw) Cc: emacs-devel storm@cua.dk (Kim F. Storm) writes: > David Kastrup <dak@gnu.org> writes: > > > PNG images support transparency. Emacs can't make use of it. You can > > only have Emacs declare a particular color as transparent. This is > > dissatisfactory. It should tell the PNG decoding routines Emacs' > > background color for the purpose of transparency. > > Using `:mask heuristic' should make the image background transparent. > The tool-bar code uses this. > > I suppose you know that, so what's the problem with this approach? That it does not work. It only works when the majority of corner pixels has the transparent color. Also it is impossible for an image to have, say, both white and transparent color. Since transparency is a feature of PNG files, is there any particular reason not to just use the information, preferring some heuristic hack to it that does not work in all circumstances? > > I would find it important if an image specifier could restrict the > > displayed portion of an image. > > This might be useful for other reasons, e.g. image panning. > Zoom (scaling) would be useful too. > > > The reason is that large images always appear as a single big > > character to Emacs. If I could split such an image into a bunch of > > smaller images, I could walk through it with the cursor. But it > > should only be necessary to instantiate the complete image itself once > > for this purpose. Of course, one should find a way that does not > > cause all of the subimages to be entered separately into the image > > cache. > > Something like this is already on my to-do list. > > However, I have other ideas to make image scrolling work, and it > is at the top of my to-do list. This is not mainly for making image scrolling work (it would be quite overkill for that). This is to split an image into addressable items. For example, preview-latex will turn a tabular into one large graphic. If I click on that graphic at a particular point, the whole graphic dissolves into text and the cursor is positioned at the start of the tabular. This is pretty useless if the table is large because you still have to find your point. If instead just the table cell opened and the cursor would be positioned there, one could use this for serious table editing. Since the whole table is available as one graphic, loading hundreds of separate images would be inconvenient. It is conceivable to split the image within TeX and load it as separate graphics. However, the involved complexity is far greater if I want to keep the alignment intact. It would also mean that I could walk the cursor through _rows_ of the preview-latex image instead of having to walk through it all at once. Image scrolling is a different problem: it does not involve actually changing the value of point. Of course, a different possibility would be to just display one image, but have a way of walking the cursor display across it. This would have the advantage that the table would have its optical integrity preserved (no line spacing between rows of the table), and the disadvantage that you could only open the whole table at once into text, not just a cell in between. It would probably be nice to have a way of tiling an image into areas with individual property lists (posn-point, keymap, mouse-highlighting...). But that's just phantasizing for the future. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 10:06 ` David Kastrup @ 2004-04-16 12:38 ` Kim F. Storm 2004-04-16 11:09 ` Jason Rumney 2004-04-16 13:39 ` Stefan Monnier 1 sibling, 1 reply; 95+ messages in thread From: Kim F. Storm @ 2004-04-16 12:38 UTC (permalink / raw) Cc: emacs-devel, Kim F. Storm David Kastrup <dak@gnu.org> writes: > That it does not work. It only works when the majority of corner > pixels has the transparent color. Also it is impossible for an image > to have, say, both white and transparent color. > > Since transparency is a feature of PNG files, is there any particular > reason not to just use the information, preferring some heuristic > hack to it that does not work in all circumstances? I understand now -- yes it is silly to try to guess something which is already there. Would somebody want to work on fixing this? > > > > I would find it important if an image specifier could restrict the > > > displayed portion of an image. > > > > This might be useful for other reasons, e.g. image panning. > > Zoom (scaling) would be useful too. > > > > It would also mean that I could walk the cursor through _rows_ of the > preview-latex image instead of having to walk through it all at > once. Image scrolling is a different problem: it does not involve > actually changing the value of point. That is correct. Another use of image splitting would be to allow positioning of multi-line text on the sides of an image; today you can only have one line of text on the side of an image, no matter how tall that image is. One issue I have been thinking about is how to automatically align those tiling image slices to the position of the first slice (even when that slice is not visible in the window). This would be a very handy way to support having multi-line proportional font text on the left of a tiled image. > It would probably be nice to have a way of tiling an image into areas > with individual property lists (posn-point, keymap, > mouse-highlighting...). But that's just phantasizing for the future. If done properly, that should definitely be part of it. Let me think some more about it; if it is trivial to do, I will add it before feature freeze; otherwise it will have to wait for 22.1. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 12:38 ` Kim F. Storm @ 2004-04-16 11:09 ` Jason Rumney 2004-04-16 11:34 ` David Kastrup 2004-04-16 17:08 ` Kim F. Storm 0 siblings, 2 replies; 95+ messages in thread From: Jason Rumney @ 2004-04-16 11:09 UTC (permalink / raw) Cc: David Kastrup, emacs-devel Kim F. Storm wrote: > I understand now -- yes it is silly to try to guess something which > is already there. > > Would somebody want to work on fixing this? What's to fix? There is already code there to create a mask from transparent parts of a PNG image with transparency. And for images with an alpha channel, if no :background is specified, the frame background color is used. In the alpha channel case, it might be better to do this at the time the image is displayed, in order to take faces into account, but that would probably mean a change in the way we cache and reuse images. ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 11:09 ` Jason Rumney @ 2004-04-16 11:34 ` David Kastrup 2004-04-16 12:29 ` Jason Rumney 2004-04-16 17:08 ` Kim F. Storm 1 sibling, 1 reply; 95+ messages in thread From: David Kastrup @ 2004-04-16 11:34 UTC (permalink / raw) Cc: emacs-devel, Kim F. Storm Jason Rumney <jasonr@gnu.org> writes: > Kim F. Storm wrote: > > > I understand now -- yes it is silly to try to guess something which > > is already there. > > Would somebody want to work on fixing this? > > What's to fix? There is already code there to create a mask from > transparent parts of a PNG image with transparency. Hmmm. Do you have any evidence of it working? I have stuff here involving several complicated things, and it would appear to me that the image stuff would be the most likely culprit. Anyway: if :heuristic-mask is true, but the majority of corner pixels is transparent, it would be nice if just transparency was used as the mask criterion. That way I get at least a heuristic mask if the image creating process does not support transparency, but get the transparence if it is available in the image. It is not always easy to know in advance. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 11:34 ` David Kastrup @ 2004-04-16 12:29 ` Jason Rumney 2004-04-16 12:56 ` David Kastrup 0 siblings, 1 reply; 95+ messages in thread From: Jason Rumney @ 2004-04-16 12:29 UTC (permalink / raw) Cc: emacs-devel, Kim F. Storm David Kastrup wrote: > Hmmm. Do you have any evidence of it working? When I wrote the image support for Windows, I tested a wide range of PNG test images. PNG support appears to be broken in the Windows port now though, as all images with transparency or alpha channels are appearing inverted. This may be something to do with the bug that YAMAMOTO Mitsuharu just pointed out. > Anyway: if :heuristic-mask is true, but the majority of corner pixels > is transparent, it would be nice if just transparency was used as the > mask criterion. > > That way I get at least a heuristic mask if the image > creating process does not support transparency, but get the > transparence if it is available in the image. It is not always easy > to know in advance. I see the problem. You don't want to have to know in advance whether the image has transparency or not. What about: if the image already has a mask (due to the fact it is a transparent image), any heuristic mask property should be ignored. Would that be better than relying on corner pixels being transparent? ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 12:29 ` Jason Rumney @ 2004-04-16 12:56 ` David Kastrup 0 siblings, 0 replies; 95+ messages in thread From: David Kastrup @ 2004-04-16 12:56 UTC (permalink / raw) Cc: emacs-devel, Kim F. Storm Jason Rumney <jasonr@gnu.org> writes: > David Kastrup wrote: > > > Anyway: if :heuristic-mask is true, but the majority of corner pixels > > is transparent, it would be nice if just transparency was used as the > > mask criterion. > > > > That way I get at least a heuristic mask if the image > > creating process does not support transparency, but get the > > transparence if it is available in the image. It is not always easy > > to know in advance. > > I see the problem. You don't want to have to know in advance whether > the image has transparency or not. Right. > What about: if the image already has a mask (due to the fact it is a > transparent image), any heuristic mask property should be > ignored. Would that be better than relying on corner pixels being > transparent? Yes. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 11:09 ` Jason Rumney 2004-04-16 11:34 ` David Kastrup @ 2004-04-16 17:08 ` Kim F. Storm 1 sibling, 0 replies; 95+ messages in thread From: Kim F. Storm @ 2004-04-16 17:08 UTC (permalink / raw) Cc: David Kastrup, emacs-devel, Kim F. Storm Jason Rumney <jasonr@gnu.org> writes: > Kim F. Storm wrote: > > > I understand now -- yes it is silly to try to guess something which > > is already there. > > Would somebody want to work on fixing this? > > What's to fix? There is already code there to create a mask from > transparent parts of a PNG image with transparency. Transparent backgrounds was broken on X -- and on W32. I already have a fix for X (to be committed shortly). It would be great to have W32 fixed as well. > > And for images with an alpha channel, if no :background is specified, > the frame background color is used. > > In the alpha channel case, it might be better to do this at the time > the image is displayed, in order to take faces into account, but that > would probably mean a change in the way we cache and reuse images. That's an idea... for 22.1 :-) -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 10:06 ` David Kastrup 2004-04-16 12:38 ` Kim F. Storm @ 2004-04-16 13:39 ` Stefan Monnier 2004-04-16 13:49 ` David Kastrup 1 sibling, 1 reply; 95+ messages in thread From: Stefan Monnier @ 2004-04-16 13:39 UTC (permalink / raw) Cc: emacs-devel, Kim F. Storm > If instead just the table cell opened and the cursor would be > positioned there, one could use this for serious table editing. > Since the whole table is available as one graphic, loading hundreds > of separate images would be inconvenient. It is conceivable to split > the image within TeX and load it as separate graphics. However, the > involved complexity is far greater if I want to keep the alignment > intact. Sounds great for preview-latex, except I'm wondering how you can make it work. I mean, how can you figure out what are the pixel positions of the various cells in your image? Stefan ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 13:39 ` Stefan Monnier @ 2004-04-16 13:49 ` David Kastrup 0 siblings, 0 replies; 95+ messages in thread From: David Kastrup @ 2004-04-16 13:49 UTC (permalink / raw) Cc: emacs-devel, Kim F. Storm Stefan Monnier <monnier@iro.umontreal.ca> writes: > > If instead just the table cell opened and the cursor would be > > positioned there, one could use this for serious table editing. > > Since the whole table is available as one graphic, loading > > hundreds of separate images would be inconvenient. It is > > conceivable to split the image within TeX and load it as separate > > graphics. However, the involved complexity is far greater if I > > want to keep the alignment intact. > > Sounds great for preview-latex, except I'm wondering how you can > make it work. I mean, how can you figure out what are the pixel > positions of the various cells in your image? preview-latex talks with GhostScript via a bidirectional pipe. The == PostScript operator will output things to stdout. The \special{ps: Some PostScript code} sequence will execute the given PostScript code at the page position corresponding to its source code position. An \errmessage will inform preview-latex of the buffer position. \everyhbox{...} will execute code at the start of every cell in a table. \everycr{...} will execute code at the end of each table line. The amount of dirty tricks involved here is moderate in comparison to what is already there. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 0:21 Several suggestions for image support David Kastrup 2004-04-16 9:29 ` YAMAMOTO Mitsuharu 2004-04-16 10:22 ` Kim F. Storm @ 2004-04-17 7:16 ` Richard Stallman 2004-04-17 13:02 ` Werner LEMBERG 2004-04-17 18:03 ` David Kastrup 2004-04-21 1:08 ` Kim F. Storm 3 siblings, 2 replies; 95+ messages in thread From: Richard Stallman @ 2004-04-17 7:16 UTC (permalink / raw) Cc: emacs-devel Emacs should have a way to scroll through an image, so that C-v each time can advance one window-height through the image. It would be inelegant to handle this by treating the tall image as several lines--but perhaps that might actually work more easily than some other methods. ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-17 7:16 ` Richard Stallman @ 2004-04-17 13:02 ` Werner LEMBERG 2004-04-17 19:24 ` David Kastrup 2004-04-17 18:03 ` David Kastrup 1 sibling, 1 reply; 95+ messages in thread From: Werner LEMBERG @ 2004-04-17 13:02 UTC (permalink / raw) Cc: dak, emacs-devel > Emacs should have a way to scroll through an image, so that C-v each > time can advance one window-height through the image. I strongly support this! Normally, I use a 24x12 bitmap font; together with preview-latex this gives quite big images which are really tedious to navigate within Emacs. Werner ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-17 13:02 ` Werner LEMBERG @ 2004-04-17 19:24 ` David Kastrup 0 siblings, 0 replies; 95+ messages in thread From: David Kastrup @ 2004-04-17 19:24 UTC (permalink / raw) Cc: rms, emacs-devel Werner LEMBERG <wl@gnu.org> writes: > > Emacs should have a way to scroll through an image, so that C-v each > > time can advance one window-height through the image. > > I strongly support this! Normally, I use a 24x12 bitmap font; > together with preview-latex this gives quite big images which are > really tedious to navigate within Emacs. Well, one solution would be to get preview-latex to shrink images automatically to a maximum size. However, it your preview indeed is quite taller than wide, this renders it unreadable. Also, having larger equation blocks shrink to fit some small widown height will make them not line up with other equations. By the way: there are also large performance problems with mouse-highlighting and cursor blinking on images: while they are most visible with larger-than-window images, it is also apparent that while the border line of the box cursor is blinking, the area of even small images is intermittently in background color, so it would appear that it is overdrawn in white and then replaced again. On a local display, this might be tolerable for small images. Over a low-bandwidth connection and/or with large images, this is a problem. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-17 7:16 ` Richard Stallman 2004-04-17 13:02 ` Werner LEMBERG @ 2004-04-17 18:03 ` David Kastrup 2004-04-18 21:30 ` Kim F. Storm 1 sibling, 1 reply; 95+ messages in thread From: David Kastrup @ 2004-04-17 18:03 UTC (permalink / raw) Cc: emacs-devel Richard Stallman <rms@gnu.org> writes: > Emacs should have a way to scroll through an image, > so that C-v each time can advance one window-height > through the image. > > It would be inelegant to handle this by treating the tall > image as several lines--but perhaps that might actually > work more easily than some other methods. I don't think that splitting the image into lines by Emacs itself is feasible: the cursor positions on the image would need to correspond to actual cursor positions in the buffer, or things get inconsistent (Emacs moves out of cursor positions in the image automatically). While it would be a real boost of usability for my main application (preview-latex) if I could walk the cursor across lines or other areas of an image, the correlation between buffer positions and corresponding location of the cursor display would need to get explicitly established by the application: it would imply "stopping points" when Emacs is trying to move the cursor out of visually inaccessible areas. And then Emacs would have to draw a cursor box or other indicator according to the location in there. Substructuring an image like that would be a very nice feature. But I don't see that it is possible to make the decision of where to split an image mechanically. Of course, scrolling through large images should be possible, anyway, and quite independent from that fanciful features. Emacs already has set-window-vscroll in its display engine in order to deal perfectly well with that. However, the only location where it is currently used is at the end of the buffer. Apart from C-v, scrollbars and mouse wheel currently assume a constant line height, which leads to confusing results where images or other tall lines are concerned. Functions that work in terms of fractions of the window height should try rounding the movement distance down to the next point-addressable line and if that causes the distance to be quite less than asked for, revert to using set-window-vscroll for moving to a partial line. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-17 18:03 ` David Kastrup @ 2004-04-18 21:30 ` Kim F. Storm 2004-04-19 1:51 ` Stefan Monnier 0 siblings, 1 reply; 95+ messages in thread From: Kim F. Storm @ 2004-04-18 21:30 UTC (permalink / raw) Cc: rms, emacs-devel David Kastrup <dak@gnu.org> writes: > Richard Stallman <rms@gnu.org> writes: > > > Emacs should have a way to scroll through an image, > > so that C-v each time can advance one window-height > > through the image. > > > > It would be inelegant to handle this by treating the tall > > image as several lines--but perhaps that might actually > > work more easily than some other methods. > > I don't think that splitting the image into lines by Emacs itself is > feasible: the cursor positions on the image would need to correspond > to actual cursor positions in the buffer, or things get inconsistent > (Emacs moves out of cursor positions in the image automatically). > While it would be a real boost of usability for my main application > (preview-latex) if I could walk the cursor across lines or other areas > of an image, the correlation between buffer positions and > corresponding location of the cursor display would need to get > explicitly established by the application: it would imply "stopping > points" when Emacs is trying to move the cursor out of visually > inaccessible areas. And then Emacs would have to draw a cursor box or > other indicator according to the location in there. Substructuring an > image like that would be a very nice feature. But I don't see that > it is possible to make the decision of where to split an image > mechanically. I have written some code (not too complex) which can split an image into individual row, and each of those rows into individual "slices" on each row, e.g. +--------+--------------+--------------+ | | | | | | | | POSSIBLE +--------+-----+-----------------------+ SLICING | | | | | | | | | | | | +--------------+-----------------------+ The major limitation of this is that all "slices" in one row is (and must be) of equal height - the height of the row. This is because emacs display engine is still row based, meaning that all "glyphs" on a row are padded with empty space in top and bottom to make all glyphs on the row of the same height (this is not entirely true, but you get the picture.) In principle, my implementation can take any slice of an image and combine it with any other slice of the same image, but the display engine does not allow those slices to be placed arbitrarily in the window, i.e. overlap rows like this: +----------------+---------------------+ | | | | | | | +---------------------+ IMPOSSIBLE | | | SLICING | | | +----------------| | | | | | | | +----------------+---------------------+ David, what are the requirements for preview-latex ? > > Of course, scrolling through large images should be possible, anyway, > and quite independent from that fanciful features. Emacs already has > set-window-vscroll in its display engine in order to deal perfectly > well with that. Yes, and it could probably be done entirely in lisp !? -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-18 21:30 ` Kim F. Storm @ 2004-04-19 1:51 ` Stefan Monnier 2004-04-19 7:57 ` David Kastrup ` (2 more replies) 0 siblings, 3 replies; 95+ messages in thread From: Stefan Monnier @ 2004-04-19 1:51 UTC (permalink / raw) Cc: David Kastrup, rms, emacs-devel >> Of course, scrolling through large images should be possible, anyway, >> and quite independent from that fanciful features. Emacs already has >> set-window-vscroll in its display engine in order to deal perfectly >> well with that. > Yes, and it could probably be done entirely in lisp !? I already suggested to use two new primitives (that have incidentally been requested for other purpose): point-to-pixel and pixel-to-point which turn a (displayed) buffer position into a display position and vice versa. All the rest should then be reasonably easy to do in Elisp. Stefan ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-19 1:51 ` Stefan Monnier @ 2004-04-19 7:57 ` David Kastrup 2004-04-19 10:34 ` Kim F. Storm 2004-04-19 15:56 ` Kim F. Storm 2004-04-21 0:53 ` Kim F. Storm 2 siblings, 1 reply; 95+ messages in thread From: David Kastrup @ 2004-04-19 7:57 UTC (permalink / raw) Cc: emacs-devel, rms, Kim F. Storm Stefan Monnier <monnier@iro.umontreal.ca> writes: > >> Of course, scrolling through large images should be possible, anyway, > >> and quite independent from that fanciful features. Emacs already has > >> set-window-vscroll in its display engine in order to deal perfectly > >> well with that. > > Yes, and it could probably be done entirely in lisp !? > > I already suggested to use two new primitives (that have incidentally > been requested for other purpose): > > point-to-pixel > and > pixel-to-point > > which turn a (displayed) buffer position into a display position and vice > versa. All the rest should then be reasonably easy to do in Elisp. I don't see how. Absolutely not. Emacs moves point out of images. Without stopping points, point will not remain inside of the image anywhere. And I certainly can't draw a cursor box over a selected area of an image. Or have mouse highlighting over a selected area. I am still thinking about Kim's proposal (horizontal slices with vertical subslices) with regard to use under preview-latex. It would certainly cater for pretty much every important application I currently have in mind. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-19 7:57 ` David Kastrup @ 2004-04-19 10:34 ` Kim F. Storm 2004-04-19 14:29 ` Stefan Monnier 0 siblings, 1 reply; 95+ messages in thread From: Kim F. Storm @ 2004-04-19 10:34 UTC (permalink / raw) Cc: emacs-devel, Stefan Monnier, rms David Kastrup <dak@gnu.org> writes: > Stefan Monnier <monnier@iro.umontreal.ca> writes: > > > >> Of course, scrolling through large images should be possible, anyway, > > >> and quite independent from that fanciful features. Emacs already has > > >> set-window-vscroll in its display engine in order to deal perfectly > > >> well with that. > > > Yes, and it could probably be done entirely in lisp !? > > > > I already suggested to use two new primitives (that have incidentally > > been requested for other purpose): > > > > point-to-pixel > > and > > pixel-to-point > > > > which turn a (displayed) buffer position into a display position and vice > > versa. All the rest should then be reasonably easy to do in Elisp. > > I don't see how. Absolutely not. Emacs moves point out of images. > Without stopping points, point will not remain inside of the image > anywhere. At least it could deal sensible with vscrolling through a partially visible image without moving point out of the image until there is some other visible line to move it to. Stefan, isn't it be necessary to have some indication of whether vscrolling will have any effect, i.e. whether the cursor line is currently fully visible, or if there are N pixels invisible at the top and M pixels invisible at the bottom? E.g. a current-row-visibility function which returns nil if fully visible and a cons (N . M) otherwise. > And I certainly can't draw a cursor box over a selected > area of an image. Or have mouse highlighting over a selected area. My image slice changes allows you to do exactly that, as each slice of the image is inserted as a separate display property. Re. image maps, I decided that for an image slice, the code still references the image map of the full image, but restricted to the current slice. So if you want each image slice to have specific properties, you must create an image map corresponding to the actual slicing of the image. Of course, you may also put properties on each slice, as each slice corresponds to a separate buffer position. I will try to complete my changes during this week. > > I am still thinking about Kim's proposal (horizontal slices with > vertical subslices) with regard to use under preview-latex. It would > certainly cater for pretty much every important application I > currently have in mind. Doing "free positioning (and rotation/orientation/scaling)" of images and text is on my to-do list for 22.x. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-19 10:34 ` Kim F. Storm @ 2004-04-19 14:29 ` Stefan Monnier 2004-04-19 15:17 ` David Kastrup 0 siblings, 1 reply; 95+ messages in thread From: Stefan Monnier @ 2004-04-19 14:29 UTC (permalink / raw) Cc: David Kastrup, rms, emacs-devel >> > I already suggested to use two new primitives (that have incidentally >> > been requested for other purpose): >> > >> > point-to-pixel >> > and >> > pixel-to-point >> > >> > which turn a (displayed) buffer position into a display position and vice >> > versa. All the rest should then be reasonably easy to do in Elisp. >> >> I don't see how. Absolutely not. Emacs moves point out of images. >> Without stopping points, point will not remain inside of the image >> anywhere. OK, maybe we'd need window-start-to-pixel as well, or somesuch. Note that "buffer position" would not be just an integer but an info very much (or probably even exactly) like the one provided in mouse-lick events. I expect that the same C code can be used for it. Stefan ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-19 14:29 ` Stefan Monnier @ 2004-04-19 15:17 ` David Kastrup 2004-04-19 15:37 ` Stefan Monnier 0 siblings, 1 reply; 95+ messages in thread From: David Kastrup @ 2004-04-19 15:17 UTC (permalink / raw) Cc: emacs-devel, rms, Kim F. Storm Stefan Monnier <monnier@iro.umontreal.ca> writes: > >> > I already suggested to use two new primitives (that have incidentally > >> > been requested for other purpose): > >> > > >> > point-to-pixel > >> > and > >> > pixel-to-point > >> > > >> > which turn a (displayed) buffer position into a display position and vice > >> > versa. All the rest should then be reasonably easy to do in Elisp. > >> > >> I don't see how. Absolutely not. Emacs moves point out of images. > >> Without stopping points, point will not remain inside of the image > >> anywhere. > > OK, maybe we'd need window-start-to-pixel as well, or somesuch. Which will not make Emacs' cursor stop in image parts AFAICS, nor will it enable a cursor display covering only part of the image. Conversion routines alone will not make Emacs place its cursor on "sensible" parts of the image. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-19 15:17 ` David Kastrup @ 2004-04-19 15:37 ` Stefan Monnier 0 siblings, 0 replies; 95+ messages in thread From: Stefan Monnier @ 2004-04-19 15:37 UTC (permalink / raw) Cc: emacs-devel, rms, Kim F. Storm > Which will not make Emacs' cursor stop in image parts AFAICS, nor > will it enable a cursor display covering only part of the image. There's a misunderstanding: I'm only concerned with scrolling of images at this point. Stefan ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-19 1:51 ` Stefan Monnier 2004-04-19 7:57 ` David Kastrup @ 2004-04-19 15:56 ` Kim F. Storm 2004-04-19 14:15 ` David Kastrup 2004-04-21 0:53 ` Kim F. Storm 2 siblings, 1 reply; 95+ messages in thread From: Kim F. Storm @ 2004-04-19 15:56 UTC (permalink / raw) Cc: David Kastrup, rms, emacs-devel Stefan Monnier <monnier@iro.umontreal.ca> writes: > >> Of course, scrolling through large images should be possible, anyway, > >> and quite independent from that fanciful features. Emacs already has > >> set-window-vscroll in its display engine in order to deal perfectly > >> well with that. > > Yes, and it could probably be done entirely in lisp !? > > I already suggested to use two new primitives (that have incidentally > been requested for other purpose): > > point-to-pixel > and > pixel-to-point > > which turn a (displayed) buffer position into a display position and vice > versa. All the rest should then be reasonably easy to do in Elisp. Actually, these are easy to implement, so I'll do that. They will return a lispy position like the one returned by event-start for a mouse click at the given point/position. In this context, the names posn-at-point and posn-at-x-y are better, as they directly relate to the corresponding posn- macros. As a side bonus, pos-visible-in-window-p will be changed to return a list [when partially arg is non-nil]: (x y top bottom) which specifies the x and y position of POS, and the number of pixels not visible at the top and bottom of the corresponding window line. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-19 15:56 ` Kim F. Storm @ 2004-04-19 14:15 ` David Kastrup 2004-04-19 21:59 ` Kim F. Storm 0 siblings, 1 reply; 95+ messages in thread From: David Kastrup @ 2004-04-19 14:15 UTC (permalink / raw) Cc: emacs-devel, Stefan Monnier, rms storm@cua.dk (Kim F. Storm) writes: > Stefan Monnier <monnier@iro.umontreal.ca> writes: > > > I already suggested to use two new primitives (that have incidentally > > been requested for other purpose): > > > > point-to-pixel > > and > > pixel-to-point > > > > which turn a (displayed) buffer position into a display position > > and vice versa. All the rest should then be reasonably easy to do > > in Elisp. > > Actually, these are easy to implement, so I'll do that. > > They will return a lispy position like the one returned by > event-start for a mouse click at the given point/position. > > In this context, the names posn-at-point and posn-at-x-y are better, > as they directly relate to the corresponding posn- macros. > > As a side bonus, pos-visible-in-window-p will be changed to return a > list [when partially arg is non-nil]: > > (x y top bottom) > > which specifies the x and y position of POS, and the number of pixels > not visible at the top and bottom of the corresponding window line. Is this really necessary? I think that it should be sufficient if we just returned x and y; if one wants to see which of the pixels are actually off-screen, then checking x and y for negative coordinates or coordinates that (if we add the object's x and y extent) pass beyond the screen dimension. I think that the situation where one would check for partial visibility is rare enough that complicating the data format is not warranted. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-19 14:15 ` David Kastrup @ 2004-04-19 21:59 ` Kim F. Storm 0 siblings, 0 replies; 95+ messages in thread From: Kim F. Storm @ 2004-04-19 21:59 UTC (permalink / raw) Cc: emacs-devel, Stefan Monnier, rms David Kastrup <dak@gnu.org> writes: > storm@cua.dk (Kim F. Storm) writes: > > > As a side bonus, pos-visible-in-window-p will be changed to return a > > list [when partially arg is non-nil]: > > > > (x y top bottom) > > > > which specifies the x and y position of POS, and the number of pixels > > not visible at the top and bottom of the corresponding window line. > > Is this really necessary? Not really -- but it eases image scrolling using window-vscroll. > I think that it should be sufficient if we > just returned x and y; Actually, the change I made returns (x y partial) where x and y are pixel coordinates and partial means that the line is only partially visible (so vscroll _may_ apply). -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-19 1:51 ` Stefan Monnier 2004-04-19 7:57 ` David Kastrup 2004-04-19 15:56 ` Kim F. Storm @ 2004-04-21 0:53 ` Kim F. Storm 2 siblings, 0 replies; 95+ messages in thread From: Kim F. Storm @ 2004-04-21 0:53 UTC (permalink / raw) Cc: David Kastrup, rms, emacs-devel Stefan Monnier <monnier@iro.umontreal.ca> writes: > >> Of course, scrolling through large images should be possible, anyway, > >> and quite independent from that fanciful features. Emacs already has > >> set-window-vscroll in its display engine in order to deal perfectly > >> well with that. > > Yes, and it could probably be done entirely in lisp !? > > I already suggested to use two new primitives (that have incidentally > been requested for other purpose): > > point-to-pixel > and > pixel-to-point > > which turn a (displayed) buffer position into a display position and vice > versa. All the rest should then be reasonably easy to do in Elisp. I just installed changes to implement posn-at-point and posn-at-x-y. I also fixed a recent bug that practically disabled vscrolling. However, there is still one important limitation to when vscroll actually works: - If image at top row of screen is fully visible and cursor is in top row, vscroll is reset. This is because making the cursor row fully visible takes precedence over vscroll. My new fix ensures that if the top line contains an image which is taller than the window height, vscroll is allowed even when the cursor is in that line. So if someone would like to enhance line-move and scrolling to deal with "tall" images, please do it. I have also added an enhancement to pos-visible-in-window-p to return pixel coordinates and partial visibility status of the row at the given position if PARTIALLY arg is non-nil. E.g. if (nth 2 (pos-visible-in-window-p (window-start))) is non-nil, the first line is only partially visible, so vscrolling may be considered. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-16 0:21 Several suggestions for image support David Kastrup ` (2 preceding siblings ...) 2004-04-17 7:16 ` Richard Stallman @ 2004-04-21 1:08 ` Kim F. Storm 2004-04-20 23:31 ` David Kastrup [not found] ` <E1BGiB8-00087H-Tz@fencepost.gnu.org> 3 siblings, 2 replies; 95+ messages in thread From: Kim F. Storm @ 2004-04-21 1:08 UTC (permalink / raw) Cc: emacs-devel David Kastrup <dak@gnu.org> writes: > PNG images support transparency. Emacs can't make use of it. You can > only have Emacs declare a particular color as transparent. This is > dissatisfactory. It should tell the PNG decoding routines Emacs' > background color for the purpose of transparency. > > I would find it important if an image specifier could restrict the > displayed portion of an image. I have just implemented image slicing via a new slice property: display ((slice X Y WIDTH HEIGHT) (image ...)) I have installed changes for W32 and MAC ports also, but as usual I have no way to test if they actually do something sensible. > > The reason is that large images always appear as a single big > character to Emacs. If I could split such an image into a bunch of > smaller images, I could walk through it with the cursor. But it > should only be necessary to instantiate the complete image itself once > for this purpose. Of course, one should find a way that does not > cause all of the subimages to be entered separately into the image > cache. Try this with http://www.w3.org/Graphics/PNG/alphatest.png : (setq im (create-image "alphatest.png" nil nil)) (insert "\n") (insert-sliced-image im nil nil 5 4) (insert "\n") Note on XPM images: There are severe problems with sliced XPM images, at least on X. The clip mask for each slice is taken from top/leftmost part of the image, rather than the actual slice of the image. I have tried a zillion things to setup the clip mask (and rewrite other parts of the code) to make this work, but to no avail. So I hereby ask for help from more skilled X people. How do you setup the clip mask of an image with an image mask so that XCopyArea will use the corresponding part of the image mask when copying a slice from the image ? Here is some code to illustrate the bug: (setq im2 (create-image "etc/gnus.png" nil nil)) (insert "\n") (insert-sliced-image im2 nil nil 5 4) (insert "\n") -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-21 1:08 ` Kim F. Storm @ 2004-04-20 23:31 ` David Kastrup 2004-04-21 3:04 ` Piet van Oostrum 2004-04-21 10:10 ` Kim F. Storm [not found] ` <E1BGiB8-00087H-Tz@fencepost.gnu.org> 1 sibling, 2 replies; 95+ messages in thread From: David Kastrup @ 2004-04-20 23:31 UTC (permalink / raw) Cc: emacs-devel storm@cua.dk (Kim F. Storm) writes: > David Kastrup <dak@gnu.org> writes: > > > PNG images support transparency. Emacs can't make use of it. You can > > only have Emacs declare a particular color as transparent. This is > > dissatisfactory. It should tell the PNG decoding routines Emacs' > > background color for the purpose of transparency. > > > > I would find it important if an image specifier could restrict the > > displayed portion of an image. > > I have just implemented image slicing via a new slice property: > > display ((slice X Y WIDTH HEIGHT) (image ...)) Does that imply that slicing is not only applicable to images? Anyway, I have been wondering about how to make slicing an image property while being able to reuse the image for several slices. Making this a separate property of course solves that concern. The effect would presumably be that only the selected slice of the image gets displayed, right? And if the current line height exceeds that of slices in consecutive rows, then there would be white space between them, right? Does anybody know offhand whether one can _reduce_ the linespacing to "tight" for a given interval? It probably will not be "crucial" though. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-20 23:31 ` David Kastrup @ 2004-04-21 3:04 ` Piet van Oostrum 2004-04-22 0:43 ` Kim F. Storm 2004-04-21 10:10 ` Kim F. Storm 1 sibling, 1 reply; 95+ messages in thread From: Piet van Oostrum @ 2004-04-21 3:04 UTC (permalink / raw) With the last change to image support I can't compile Carbon emacs on MacOSX: (configured with --enable-carbon-app --without-x) gcc -I/sw/include -L/sw/lib -c -fpascal-strings -fno-common -DMAC_OSX -I../mac/src -Demacs -DHAVE_CONFIG_H -I. -I/Users/piet/Projects/cvs/emacs/src -fpascal-strings -fno-common -DMAC_OSX -I../mac/src -Dtemacs -g -O2 dispnew.c In file included from dispnew.c:64: macterm.h:579: error: conflicting types for `image_ascent' dispextern.h:2682: error: previous declaration of `image_ascent' make[1]: *** [dispnew.o] Error 1 make: *** [src] Error 2 -- Piet van Oostrum <piet@cs.uu.nl> URL: http://www.cs.uu.nl/~piet [PGP] Private email: P.van.Oostrum@hccnet.nl ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-21 3:04 ` Piet van Oostrum @ 2004-04-22 0:43 ` Kim F. Storm 2004-04-22 1:18 ` YAMAMOTO Mitsuharu 0 siblings, 1 reply; 95+ messages in thread From: Kim F. Storm @ 2004-04-22 0:43 UTC (permalink / raw) Cc: emacs-devel Piet van Oostrum <piet@cs.uu.nl> writes: > With the last change to image support I can't compile Carbon emacs on > MacOSX: (configured with --enable-carbon-app --without-x) > > gcc -I/sw/include -L/sw/lib -c -fpascal-strings -fno-common -DMAC_OSX -I../mac/src -Demacs -DHAVE_CONFIG_H -I. -I/Users/piet/Projects/cvs/emacs/src -fpascal-strings -fno-common -DMAC_OSX -I../mac/src -Dtemacs -g -O2 dispnew.c > In file included from dispnew.c:64: > macterm.h:579: error: conflicting types for `image_ascent' > dispextern.h:2682: error: previous declaration of `image_ascent' > make[1]: *** [dispnew.o] Error 1 > make: *** [src] Error 2 I'm sorry, but I cannot find a prototype for image_ascent in macterm.h. Is your macterm.h up-to-date (rev 1.13)? -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-22 0:43 ` Kim F. Storm @ 2004-04-22 1:18 ` YAMAMOTO Mitsuharu 2004-04-22 22:03 ` Piet van Oostrum 0 siblings, 1 reply; 95+ messages in thread From: YAMAMOTO Mitsuharu @ 2004-04-22 1:18 UTC (permalink / raw) Cc: Piet van Oostrum, emacs-devel >>>>> On 22 Apr 2004 02:43:46 +0200, storm@cua.dk (Kim F. Storm) said: > Piet van Oostrum <piet@cs.uu.nl> writes: >> With the last change to image support I can't compile Carbon emacs >> on MacOSX: (configured with --enable-carbon-app --without-x) > I'm sorry, but I cannot find a prototype for image_ascent in > macterm.h. Is your macterm.h up-to-date (rev 1.13)? I guess the patch in the following post is applied. http://mail.gnu.org/archive/html/emacs-devel/2004-04/msg00002.html In that case, please delete the line containing image_ascent in macterm.h. As far as I tested, image slicing works perfectly for the Mac port including sliced XPM images (with the XPM support patch). YAMAMOTO Mitsuharu mituharu@math.s.chiba-u.ac.jp ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-22 1:18 ` YAMAMOTO Mitsuharu @ 2004-04-22 22:03 ` Piet van Oostrum 2004-04-23 4:02 ` YAMAMOTO Mitsuharu 0 siblings, 1 reply; 95+ messages in thread From: Piet van Oostrum @ 2004-04-22 22:03 UTC (permalink / raw) >>>>> YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> (YM) wrote: >>>>> On 22 Apr 2004 02:43:46 +0200, storm@cua.dk (Kim F. Storm) said: >> Piet van Oostrum <piet@cs.uu.nl> writes: >>> With the last change to image support I can't compile Carbon emacs >>> on MacOSX: (configured with --enable-carbon-app --without-x) >> I'm sorry, but I cannot find a prototype for image_ascent in >> macterm.h. Is your macterm.h up-to-date (rev 1.13)? YM> I guess the patch in the following post is applied. YM> http://mail.gnu.org/archive/html/emacs-devel/2004-04/msg00002.html Yes, I did. Is this patch still valid/relevant? YM> In that case, please delete the line containing image_ascent in YM> macterm.h. OK, I'll try that. YM> As far as I tested, image slicing works perfectly for the Mac port YM> including sliced XPM images (with the XPM support patch). Thanks. -- Piet van Oostrum <piet@cs.uu.nl> URL: http://www.cs.uu.nl/~piet [PGP] Private email: P.van.Oostrum@hccnet.nl ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-22 22:03 ` Piet van Oostrum @ 2004-04-23 4:02 ` YAMAMOTO Mitsuharu 2004-04-24 14:48 ` Piet van Oostrum 0 siblings, 1 reply; 95+ messages in thread From: YAMAMOTO Mitsuharu @ 2004-04-23 4:02 UTC (permalink / raw) Cc: emacs-devel >>>>> On 23 Apr 2004 00:03:36 +0200, Piet van Oostrum <piet@cs.uu.nl> said: >>>>> YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> (YM) wrote: YM> I guess the patch in the following post is applied. YM> http://mail.gnu.org/archive/html/emacs-devel/2004-04/msg00002.html > Yes, I did. Is this patch still valid/relevant? It's valid (if the line containing image_ascent in macterm.h is removed and the declarations for Vx_resorce_{name,class} are enclosed with #ifdef HAVE_WINDOW_SYSTEM in lisp.h), but not relevant to the crash, I suppose. Could you please try the patch I posted in the following message and see similar crash still occurs? http://mail.gnu.org/archive/html/emacs-devel/2004-04/msg00783.html YAMAMOTO Mitsuharu mituharu@math.s.chiba-u.ac.jp ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-23 4:02 ` YAMAMOTO Mitsuharu @ 2004-04-24 14:48 ` Piet van Oostrum 0 siblings, 0 replies; 95+ messages in thread From: Piet van Oostrum @ 2004-04-24 14:48 UTC (permalink / raw) >>>>> YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> (YM) wrote: >>>>> On 23 Apr 2004 00:03:36 +0200, Piet van Oostrum <piet@cs.uu.nl> said: >>>>> YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> (YM) wrote: YM> I guess the patch in the following post is applied. YM> http://mail.gnu.org/archive/html/emacs-devel/2004-04/msg00002.html >> Yes, I did. Is this patch still valid/relevant? YM> It's valid (if the line containing image_ascent in macterm.h is YM> removed and the declarations for Vx_resorce_{name,class} are enclosed YM> with #ifdef HAVE_WINDOW_SYSTEM in lisp.h), but not relevant to the YM> crash, I suppose. YM> Could you please try the patch I posted in the following message and YM> see similar crash still occurs? YM> http://mail.gnu.org/archive/html/emacs-devel/2004-04/msg00783.html The version that I am currently running is the checkout of D2004.04.19.22.00.00 with amongst others the above patch applied. I have emacs now running since Wed Apr 21 22:36:27 without a crash, while it used to crash several times a day. So this seems promising. -- Piet van Oostrum <piet@cs.uu.nl> URL: http://www.cs.uu.nl/~piet [PGP] Private email: P.van.Oostrum@hccnet.nl ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-20 23:31 ` David Kastrup 2004-04-21 3:04 ` Piet van Oostrum @ 2004-04-21 10:10 ` Kim F. Storm 2004-04-21 8:51 ` David Kastrup 2004-04-22 17:40 ` Richard Stallman 1 sibling, 2 replies; 95+ messages in thread From: Kim F. Storm @ 2004-04-21 10:10 UTC (permalink / raw) Cc: emacs-devel David Kastrup <dak@gnu.org> writes: > storm@cua.dk (Kim F. Storm) writes: > > > David Kastrup <dak@gnu.org> writes: > > > > > PNG images support transparency. Emacs can't make use of it. You can > > > only have Emacs declare a particular color as transparent. This is > > > dissatisfactory. It should tell the PNG decoding routines Emacs' > > > background color for the purpose of transparency. > > > > > > I would find it important if an image specifier could restrict the > > > displayed portion of an image. > > > > I have just implemented image slicing via a new slice property: > > > > display ((slice X Y WIDTH HEIGHT) (image ...)) > > Does that imply that slicing is not only applicable to images? Currently it only applies to images. It can be extended to other objects as well, but I don't plan to do that myself. > Anyway, I have been wondering about how to make slicing an image > property while being able to reuse the image for several slices. > Making this a separate property of course solves that concern. > > The effect would presumably be that only the selected slice of the > image gets displayed, right? Exactly. > And if the current line height exceeds > that of slices in consecutive rows, then there would be white space > between them, right? Unfortunately, yes. However, I have fixed the treatment of newline characters so that non-empty lines are no longer made a minimum height equal to the frame default line height. So you can use very small slices with good results. > Does anybody know offhand whether one can > _reduce_ the linespacing to "tight" for a given interval? We can probably build on the existing "overlapping rows" code, thus allowing a slice to be physically higher than its logical height. But it is a bit complicated, so I postponed that to later -- and to see if something better could be found. > > It probably will not be "crucial" though. Good. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-21 10:10 ` Kim F. Storm @ 2004-04-21 8:51 ` David Kastrup 2004-04-21 12:51 ` Kim F. Storm 2004-04-22 17:40 ` Richard Stallman 1 sibling, 1 reply; 95+ messages in thread From: David Kastrup @ 2004-04-21 8:51 UTC (permalink / raw) Cc: emacs-devel storm@cua.dk (Kim F. Storm) writes: > David Kastrup <dak@gnu.org> writes: > > > storm@cua.dk (Kim F. Storm) writes: > > > > > David Kastrup <dak@gnu.org> writes: > > > > > > > PNG images support transparency. Emacs can't make use of it. You can > > > > only have Emacs declare a particular color as transparent. This is > > > > dissatisfactory. It should tell the PNG decoding routines Emacs' > > > > background color for the purpose of transparency. > > > > > > > > I would find it important if an image specifier could restrict the > > > > displayed portion of an image. > > > > > > I have just implemented image slicing via a new slice property: > > > > > > display ((slice X Y WIDTH HEIGHT) (image ...)) > > > > Does that imply that slicing is not only applicable to images? > > Currently it only applies to images. It can be extended to other > objects as well, but I don't plan to do that myself. Ok, here is the next problem I see: assume that I have the input in preview-latex: \begin{smallmatrix} 1&2\\ 3&4 \end{smallmatrix} This will produce a single image split into 4 slices that I want to have arranged 12 34 This stuff we will split into 4 overlays covering \begin{smallmatrix} 1& 2\\ 3& 4 \end{smallmatrix} Now here come the somewhat ugly things: in order to have this composition arranged properly, the first overlay will also have to contain a before-string of "\n", and the second and fourth overlay will contain an after-string of "\n". Cursor up/down will not produce any sensible results. Ok, I mean with preview-latex the solution is not too bad: require the source to be formatted appropriately, or the image does not get sliced, period. Namely, have a newline after every row and only a constant non-printing fillprefix before each row (as a requirement for slicing). And better use align-current to align all & signs (optionally, will make cursor movement nicer). If we place those requirements on source formatting, we won't be needing any before-string and after-string, and things get slightly more sane. So I think we might get along without more heavyweight support here for now. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-21 8:51 ` David Kastrup @ 2004-04-21 12:51 ` Kim F. Storm 0 siblings, 0 replies; 95+ messages in thread From: Kim F. Storm @ 2004-04-21 12:51 UTC (permalink / raw) Cc: emacs-devel David Kastrup <dak@gnu.org> writes: > Ok, here is the next problem I see: assume that I have the input in > preview-latex: > > > \begin{smallmatrix} 1&2\\ 3&4 \end{smallmatrix} > > This will produce a single image split into 4 slices that I want to > have arranged > > 12 > 34 > > This stuff we will split into 4 overlays covering > \begin{smallmatrix} 1& > 2\\ > 3& > 4 \end{smallmatrix} > > Now here come the somewhat ugly things: in order to have this > composition arranged properly, the first overlay will also have to > contain a before-string of "\n", and the second and fourth overlay > will contain an after-string of "\n". Cursor up/down will not produce > any sensible results. Sounds like a problem with cursor motion in the presense of newlines in before and after string properties -- maybe something for our "line-move" experts to look into. > > Ok, I mean with preview-latex the solution is not too bad: require the > source to be formatted appropriately, or the image does not get > sliced, period. Namely, have a newline after every row and only a > constant non-printing fillprefix before each row (as a requirement for > slicing). As in: .. (newline) \begin{smallmatrix} 1&2\\ (newline) 3&4 \end{smallmatrix} (newline) I.e. if input is like this, image can be sliced; otherwise, image is not sliced. Sounds like a sensible approach to me -- if the latex-mode (or whatever) can help you write in the proper format and warn (different coloring like in makefile-mode) if there are things which breaks that format. > And better use align-current to align all & signs > (optionally, will make cursor movement nicer). If we place those > requirements on source formatting, we won't be needing any > before-string and after-string, and things get slightly more sane. > > So I think we might get along without more heavyweight support here > for now. Good. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-21 10:10 ` Kim F. Storm 2004-04-21 8:51 ` David Kastrup @ 2004-04-22 17:40 ` Richard Stallman 2004-04-22 18:17 ` David Kastrup 2004-04-22 23:53 ` Kim F. Storm 1 sibling, 2 replies; 95+ messages in thread From: Richard Stallman @ 2004-04-22 17:40 UTC (permalink / raw) Cc: dak, emacs-devel However, I have fixed the treatment of newline characters so that non-empty lines are no longer made a minimum height equal to the frame default line height. That could have bad effects in many cases. I don't think it is ok, unless it is limited to special conditions. ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-22 17:40 ` Richard Stallman @ 2004-04-22 18:17 ` David Kastrup 2004-04-24 14:26 ` Richard Stallman 2004-04-22 23:53 ` Kim F. Storm 1 sibling, 1 reply; 95+ messages in thread From: David Kastrup @ 2004-04-22 18:17 UTC (permalink / raw) Cc: emacs-devel, Kim F. Storm Richard Stallman <rms@gnu.org> writes: > However, I have fixed the treatment of newline characters > so that non-empty lines are no longer made a minimum > height equal to the frame default line height. > > That could have bad effects in many cases. > > I don't think it is ok, unless it is limited to special conditions. Then let us limit it to special conditions. Line spacing is usually used for two conflicting purposes: a) keep material from separate lines apart b) provide a regular grid on which lines are placed. I have no idea what the current semantics actually are, but I'd propose the following: Two adjacent lines have their baselines separated by the value of line spacing corresponding to the face that is valid for the newline character between them unless overriden by a special "line-spacing" property or similar. Unless this would cause overlap of the descenders of the upper line and the ascenders of the lower line in which case the line distance will be increased until no overlap occurs. This means that for the application I have in mind, I will have to particularly mark the newline characters as "line spacing 0". Since it would probably be a nuisance to require installation of a special face here, it would be nice if we had a special text property that could be used for the purpose of fixing the minimal line spacing. Does this sound like a reasonable scheme? -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-22 18:17 ` David Kastrup @ 2004-04-24 14:26 ` Richard Stallman 0 siblings, 0 replies; 95+ messages in thread From: Richard Stallman @ 2004-04-24 14:26 UTC (permalink / raw) Cc: emacs-devel, storm Two adjacent lines have their baselines separated by the value of line spacing corresponding to the face that is valid for the newline character between them unless overriden by a special "line-spacing" property or similar. That is one good way to make it problem-free, I think. ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-22 17:40 ` Richard Stallman 2004-04-22 18:17 ` David Kastrup @ 2004-04-22 23:53 ` Kim F. Storm 2004-04-22 23:02 ` David Kastrup ` (2 more replies) 1 sibling, 3 replies; 95+ messages in thread From: Kim F. Storm @ 2004-04-22 23:53 UTC (permalink / raw) Cc: dak, emacs-devel Richard Stallman <rms@gnu.org> writes: > However, I have fixed the treatment of newline characters > so that non-empty lines are no longer made a minimum > height equal to the frame default line height. > > That could have bad effects in many cases. I honestly don't understand why this is a problem. Quite contrary, I always found it very odd (i.e. buggy) that emacs forces all lines to be at least as high as the default frame line height. That means that you cannot have any "fine print". With my change, if you have just ONE character in the frame default font in the line, it will be shown exactly as before. Also, if the line is empty, ie. only contains the newline, it is also shown as before. The only time you will see my change in effect is if you have a line where ALL glyphs are lower than the default frame line height; in that case, the line is only as high as the tallest character on that line. > I don't think > it is ok, unless it is limited to special conditions. Of course, I can change this, but my feeling is that the new behaviour is more in line with what people would expect, so we should provide a way to force a specific height. If you really have an application where you want to force the old behaviour (I doubt there are currently any such uses), there are ways to force the line to be shown with the default line height (e.g. use a 'display space property with a zero width and a height of 1 -- ok, that is currently not supported, but it could easily be added). -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-22 23:53 ` Kim F. Storm @ 2004-04-22 23:02 ` David Kastrup 2004-04-23 12:36 ` Kim F. Storm 2004-04-23 15:02 ` Stefan Monnier 2004-04-23 0:33 ` Kenichi Handa 2004-04-25 18:09 ` Richard Stallman 2 siblings, 2 replies; 95+ messages in thread From: David Kastrup @ 2004-04-22 23:02 UTC (permalink / raw) Cc: rms, emacs-devel storm@cua.dk (Kim F. Storm) writes: > Richard Stallman <rms@gnu.org> writes: > > > However, I have fixed the treatment of newline characters > > so that non-empty lines are no longer made a minimum > > height equal to the frame default line height. > > > > That could have bad effects in many cases. > > I honestly don't understand why this is a problem. For instance, preview-latex uses images as a substitute for characters. If I have a line that looks like $x$ I still want to have it keep the full line distance to the previous line in order to avoid inconsistent spacing. This is existing usage of images. In contrast, sliced images have no existing usage. For this reason alone, it would be more useful to put the burden of removing the interline space on applications wanting seamless joining of images rather than on applications that want the normal spacing to be kept: we already _have_ applications that assume they need to do nothing special in order to keep the normal line spacing. > Quite contrary, I always found it very odd (i.e. buggy) that emacs > forces all lines to be at least as high as the default frame line > height. That means that you cannot have any "fine print". That's why I proposed to take the line spacing corresponding to the face valid on the new-line character (we'd need something like a null-face with zero metrics) or have something like a line-distance property we could tack onto it. Instead of the line spacing for the newline, one could also take the largest line spacing prevalent in the line _including_ the newline (as I explained above, there are existing applications of image-only lines which need to have a non-zero line spacing). That way we would still be able to do properly spaced fine-print. > Of course, I can change this, but my feeling is that the new > behaviour is more in line with what people would expect, Existing preview-latex code expects to be spaced like text by default. Your change would make some future special-case code slightly easier, at the cost of complicating existing uses. I think we can do this with less negative impact on existing usage, at just a small cost for future uses: just make it easy to specify explicitly when you want zero line spacing. > If you really have an application where you want to force the old > behaviour (I doubt there are currently any such uses), preview-latex uses glyphs as a replacement for characters. And it allows a line to consist just of images. So there are such uses right now. > there are ways to force the line to be shown with the default line > height (e.g. use a 'display space property with a zero width and a > height of 1 -- ok, that is currently not supported, but it could > easily be added). I think it would be less contrived to force the line spacing to zero by putting a suitable property on the newline. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-22 23:02 ` David Kastrup @ 2004-04-23 12:36 ` Kim F. Storm 2004-04-23 15:02 ` Stefan Monnier 1 sibling, 0 replies; 95+ messages in thread From: Kim F. Storm @ 2004-04-23 12:36 UTC (permalink / raw) Cc: rms, emacs-devel David Kastrup <dak@gnu.org> writes: > storm@cua.dk (Kim F. Storm) writes: > > > Richard Stallman <rms@gnu.org> writes: > > > > > However, I have fixed the treatment of newline characters > > > so that non-empty lines are no longer made a minimum > > > height equal to the frame default line height. > > > > > > That could have bad effects in many cases. > > > > I honestly don't understand why this is a problem. > > For instance, preview-latex uses images as a substitute for > characters. If I have a line that looks like > $x$ > I still want to have it keep the full line distance to the previous > line in order to avoid inconsistent spacing. > Ok, I will undo my change and find another way to reduce default line height. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-22 23:02 ` David Kastrup 2004-04-23 12:36 ` Kim F. Storm @ 2004-04-23 15:02 ` Stefan Monnier 2004-04-23 15:05 ` David Kastrup 1 sibling, 1 reply; 95+ messages in thread From: Stefan Monnier @ 2004-04-23 15:02 UTC (permalink / raw) Cc: emacs-devel, rms, Kim F. Storm >> > However, I have fixed the treatment of newline characters >> > so that non-empty lines are no longer made a minimum >> > height equal to the frame default line height. >> > >> > That could have bad effects in many cases. >> >> I honestly don't understand why this is a problem. > For instance, preview-latex uses images as a substitute for > characters. If I have a line that looks like > $x$ > I still want to have it keep the full line distance to the previous > line in order to avoid inconsistent spacing. I don't see the relevance. More specifically, I understand Kim's change to only affect the computation of line height, not line spacing. By its description Kim's change sounds right (although I guess Handa's point about C-k increasing the line height is valid: so we should refine the change, but not take it out). But maybe I'm misunderstanding. Stefan ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-23 15:02 ` Stefan Monnier @ 2004-04-23 15:05 ` David Kastrup 0 siblings, 0 replies; 95+ messages in thread From: David Kastrup @ 2004-04-23 15:05 UTC (permalink / raw) Cc: emacs-devel, rms, Kim F. Storm Stefan Monnier <monnier@iro.umontreal.ca> writes: > >> > However, I have fixed the treatment of newline characters > >> > so that non-empty lines are no longer made a minimum > >> > height equal to the frame default line height. > >> > > >> > That could have bad effects in many cases. > >> > >> I honestly don't understand why this is a problem. > > > For instance, preview-latex uses images as a substitute for > > characters. If I have a line that looks like > > $x$ > > I still want to have it keep the full line distance to the previous > > line in order to avoid inconsistent spacing. > > I don't see the relevance. More specifically, I understand Kim's > change to only affect the computation of line height, not line > spacing. I tried to write what parameters I mean in a separate post. It appears we are all talking about different concepts. Since I don't know what you call in particular "line height" and "line spacing", I can't make a meaningful comment or explanation. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-22 23:53 ` Kim F. Storm 2004-04-22 23:02 ` David Kastrup @ 2004-04-23 0:33 ` Kenichi Handa 2004-04-23 0:51 ` David Kastrup 2004-04-25 1:56 ` Kim F. Storm 2004-04-25 18:09 ` Richard Stallman 2 siblings, 2 replies; 95+ messages in thread From: Kenichi Handa @ 2004-04-23 0:33 UTC (permalink / raw) Cc: dak, rms, emacs-devel [-- Attachment #1: Type: text/plain, Size: 1464 bytes --] In article <m3isfrk1ry.fsf@kfs-l.imdomain.dk>, storm@cua.dk (Kim F. Storm) writes: > With my change, if you have just ONE character in the frame default > font in the line, it will be shown exactly as before. Also, if the > line is empty, ie. only contains the newline, it is also shown as > before. > The only time you will see my change in effect is if you have a line > where ALL glyphs are lower than the default frame line height; in that > case, the line is only as high as the tallest character on that line. With the latest code, when I do this: (make-face 'small) (set-face-attribute 'small nil :height 0.5) (insert (propertize "abc" 'face 'small) "\n") the line height gets shorter even if the tailing newline doesn't have the face `small'. This result in that when I type C-k at the beggining of that line, the line gets taller, which is counter intuitive. I think the height of the space glyph for the tailing newline should be the default frame line height in the above case, and the line height must be desided by all glyphs including the tailing space. Then, to have a short line, we should do: (insert (propertize "abc\n" 'face 'small)) In this case, C-k as above doesn't change the line height because we still have a newline of `small' face. By the way, it seems that the current code doesn't draw a hollow cursor correctly. The bottom line of the rectangle is not drawn (see the attached image). --- Ken'ichi HANDA handa@m17n.org [-- Attachment #2: temp.png --] [-- Type: image/png, Size: 838 bytes --] [-- Attachment #3: Type: text/plain, Size: 141 bytes --] _______________________________________________ Emacs-devel mailing list Emacs-devel@gnu.org http://mail.gnu.org/mailman/listinfo/emacs-devel ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-23 0:33 ` Kenichi Handa @ 2004-04-23 0:51 ` David Kastrup 2004-04-23 12:58 ` Kenichi Handa 2004-04-24 14:27 ` Richard Stallman 2004-04-25 1:56 ` Kim F. Storm 1 sibling, 2 replies; 95+ messages in thread From: David Kastrup @ 2004-04-23 0:51 UTC (permalink / raw) Cc: emacs-devel, rms, storm Kenichi Handa <handa@m17n.org> writes: > I think the height of the space glyph for the tailing > newline should be the default frame line height in the above > case, and the line height must be desided by all glyphs > including the tailing space. You are confusing line spacing and line height, I think. Line spacing is the distance by which the _baselines_ of different lines are to be set apart unless this could cause overlap. So I think that the space between two baselines should be max(line space of newline, max(all glyph depths of upper line,0) +max(all glyph heights of lower line,0)) where depth is the extent of a glyph below the baseline, and the height is the extent above. We could discuss whether it makes sense to use a maximum value of more than the just the line spacing of the newline character (maybe of the whole lower line?), but if we do, then the parameter "line spacing" should be the same for a complete face (including newline and spaces), whereas height and depth are specific to each glyph. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-23 0:51 ` David Kastrup @ 2004-04-23 12:58 ` Kenichi Handa 2004-04-23 14:53 ` David Kastrup 2004-04-24 14:27 ` Richard Stallman 1 sibling, 1 reply; 95+ messages in thread From: Kenichi Handa @ 2004-04-23 12:58 UTC (permalink / raw) Cc: storm, rms, emacs-devel In article <x5oepj4iul.fsf@lola.goethe.zz>, David Kastrup <dak@gnu.org> writes: > Kenichi Handa <handa@m17n.org> writes: >> I think the height of the space glyph for the tailing >> newline should be the default frame line height in the above >> case, and the line height must be desided by all glyphs >> including the tailing space. > You are confusing line spacing and line height, I think. Line > spacing is the distance by which the _baselines_ of different lines > are to be set apart unless this could cause overlap. I don't think I'm confusing. In my paragraph above, I really meant line height. But I should have written more clearly that "line height must be the maxinum logical font height (ascent + descent) of faces of all characters (including the tailing newline)". Here I think we should not consider the physical ascent/descent of each glyph which may be taller or shorter than the the logical ascent/descent of a font. > So I think that the space between two baselines should be > max(line space of newline, max(all glyph depths of upper line,0) > +max(all glyph heights of lower line,0)) > where depth is the extent of a glyph below the baseline, and the > height is the extent above. I don't understand what you mean by "line space of newline", but anyway, I think it's not worth discussing about line spacing (of your definition). > We could discuss whether it makes sense to use a maximum value of > more than the just the line spacing of the newline character (maybe > of the whole lower line?), but if we do, then the parameter "line > spacing" should be the same for a complete face (including newline > and spaces), whereas height and depth are specific to each glyph. Sorry, I don't understand the above paragraph. What is "the parameter line spacing"? Do you mean the frame parameter `line-spacing' or a buffer local variable `line-spacing'? Then they are both a spacing between lines, not the baseline distance. Please see what happens by (setq line-spacing 1). --- Ken'ichi HANDA handa@m17n.org ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-23 12:58 ` Kenichi Handa @ 2004-04-23 14:53 ` David Kastrup 0 siblings, 0 replies; 95+ messages in thread From: David Kastrup @ 2004-04-23 14:53 UTC (permalink / raw) Cc: storm, rms, emacs-devel Kenichi Handa <handa@m17n.org> writes: > In article <x5oepj4iul.fsf@lola.goethe.zz>, David Kastrup > <dak@gnu.org> writes: > > > Kenichi Handa <handa@m17n.org> writes: > >> I think the height of the space glyph for the tailing > >> newline should be the default frame line height in the above > >> case, and the line height must be desided by all glyphs > >> including the tailing space. > > > You are confusing line spacing and line height, I think. Line > > spacing is the distance by which the _baselines_ of different > > lines are to be set apart unless this could cause overlap. > > I don't think I'm confusing. In my paragraph above, I really meant > line height. But I should have written more clearly that "line > height must be the maxinum logical font height (ascent + descent) of > faces of all characters (including the tailing newline)". Ok, what I mean by "line spacing" is not what the variables in Emacs call by that name, but the prescribed distance between baselines for a font. Actually, I wrote that definition down two paragraphs above. > Here I think we should not consider the physical ascent/descent of > each glyph which may be taller or shorter than the the logical > ascent/descent of a font. I don't know how X11 defines the line spacings. In typesetting, however, each font comes with an associated baseline distance. It may be what you call the sum of logical ascent/descent, I don't know. It is the distance that the baselines should be apart for the font to look good. This is usually quite more than the sum of the maximum ascent and descent available in the font, since good discrimination of the lines requires a streak of empty space between the lines. So let us assume that these logical ascent/descent of fonts are what constitute the "line spacing" as I called it. Then the recipe would be to use max(logical descent of newline character at end of above line + logical ascent of newline character at end of below line, max(all physical decents of characters in above line,0)+max(all physical ascents of characters in below line,0)) Images will not have a logical ascent/descent differing from their physical one. The idea is to keep the grid spacing prescribed by the font of the line endings, unless this could cause overlap (can happen if we have a few larger characters, or images in between). Only when overlap may occur, is the basic distance between lines prescribed by the font of the newlines increased, and only by that amount which makes it possible to rule out overlap. In that way, the basic grid only gets disrupted where it is unavoidable or where we have font size changes lasting across line endings. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-23 0:51 ` David Kastrup 2004-04-23 12:58 ` Kenichi Handa @ 2004-04-24 14:27 ` Richard Stallman 2004-04-24 15:16 ` David Kastrup 1 sibling, 1 reply; 95+ messages in thread From: Richard Stallman @ 2004-04-24 14:27 UTC (permalink / raw) Cc: storm, emacs-devel, handa So I think that the space between two baselines should be max(line space of newline, max(all glyph depths of upper line,0) +max(all glyph heights of lower line,0)) where depth is the extent of a glyph below the baseline, and the height is the extent above. You may be right, but it occurs to me that we should see if text formatters have any guidance to offer us on how to decide this. ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-24 14:27 ` Richard Stallman @ 2004-04-24 15:16 ` David Kastrup 0 siblings, 0 replies; 95+ messages in thread From: David Kastrup @ 2004-04-24 15:16 UTC (permalink / raw) Cc: storm, emacs-devel, handa Richard Stallman <rms@gnu.org> writes: > So I think that > the space between two baselines should be > > max(line space of newline, max(all glyph depths of upper line,0) > +max(all glyph heights of lower line,0)) > where depth is the extent of a glyph below the baseline, and the > height is the extent above. > > You may be right, but it occurs to me that we should see if text > formatters have any guidance to offer us on how to decide this. TeX is pretty quirky in this regard. It has some design decisions resulting from efficiency and memory considerations, and some that are due to dealing best with pagination. Since an editor window is usually not intended to display paginated material but rather to provide a view on part of a long scroll, we don't need to bother with stuff like "flexible glue" that is used for fitting things better to a page. Basically, lines are governed by the three values \baselineskip, \lineskiplimit and \lineskip. TeX tries to arrange lines such that their baselines are \baselineskip apart. If the descenders of the upper line come closer than \lineskiplimit to the ascenders of the lower line, however, TeX instead separates those parts of the lines by using \lineskip between them. The plain TeX values are 12pt for \baselineskip, 0pt for \lineskiplimit, and 1pt for \lineskip. There is a discontinuity involved in those standard settings: the separation jumps from 0pt to 1pt once overlap can't be avoided anymore with the standard settings. In calculating ascent and descent of a line, TeX uses only the maximum of any actually involved characters and does not distinguish where on the line these occur. For an editor, this is certainly appropriate, as we use rectangular areas of differing background color for highlighting things. When typesetting running text, TeX uses the values of the line spacing variables that are current at the end of the paragraph. This causes a whole paragraph to be typeset with consistent (though sometimes surprising) baseline distances. This consistency is what I am mostly worried about: if we have a few words of small print in a paragraph, and auto-fill-mode happens to break between them, the newline will belong to a face with a smaller baseline distance. So I am not sure whether we should making changes of the baseline distance as easy as changing a face for a few words in running text. I don't have a much better idea, though. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-23 0:33 ` Kenichi Handa 2004-04-23 0:51 ` David Kastrup @ 2004-04-25 1:56 ` Kim F. Storm 2004-04-25 2:06 ` David Kastrup 2004-04-29 2:20 ` Kenichi Handa 1 sibling, 2 replies; 95+ messages in thread From: Kim F. Storm @ 2004-04-25 1:56 UTC (permalink / raw) Cc: dak, rms, emacs-devel I have now reworked my line height changes. Now, the height of a newline equals the current face height, unless an explicit line-spacing property is present on the newline character. If the value of the line-spacing property is t, you get the effect of my previous change, i.e. the newline character does not add to the height of the row by itself, but the newline glyph is re-positioned inside the available row height to make it fully visible (when the cursor is above it). If the value is an integer, it overrides the value of the frame line-spacing parameter and the (buffer local) value of the line-spacing variable. If the value is a float, the number of extra pixels is calculated as the current row height * value. I think this covers all the objections raised. Try this: (make-face 'small) (set-face-attribute 'small nil :height 0.5) (insert (propertize "abc\ndef\nghi" 'face 'small) (propertize "\n" 'line-spacing t) (propertize "jkl" 'face 'small) "\n") Kenichi Handa <handa@m17n.org> writes: > By the way, it seems that the current code doesn't draw a > hollow cursor correctly. The bottom line of the rectangle > is not drawn (see the attached image). That's an old bug which probably never got noticed because lines were never less that the default face height. I fixed that too. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-25 1:56 ` Kim F. Storm @ 2004-04-25 2:06 ` David Kastrup 2004-04-26 9:38 ` Kim F. Storm 2004-04-29 2:20 ` Kenichi Handa 1 sibling, 1 reply; 95+ messages in thread From: David Kastrup @ 2004-04-25 2:06 UTC (permalink / raw) Cc: emacs-devel, rms, Kenichi Handa storm@cua.dk (Kim F. Storm) writes: > I have now reworked my line height changes. > > Now, the height of a newline equals the current face height, unless an > explicit line-spacing property is present on the newline character. > > If the value of the line-spacing property is t, you get the effect of > my previous change, i.e. the newline character does not add to the > height of the row by itself, but the newline glyph is re-positioned > inside the available row height to make it fully visible (when the > cursor is above it). > > If the value is an integer, it overrides the value of the frame > line-spacing parameter and the (buffer local) value of the line-spacing > variable. So presumably setting the value to 0 will make the newline have the height of a normal space in the line? One thing that one should try is to have no surprising changes if the newline is turned into a space while keeping its properties: re-filling a paragraph will do that. I'll have to think this through and maybe play with a few things. Thanks, -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-25 2:06 ` David Kastrup @ 2004-04-26 9:38 ` Kim F. Storm 2004-04-27 0:34 ` Kim F. Storm 0 siblings, 1 reply; 95+ messages in thread From: Kim F. Storm @ 2004-04-26 9:38 UTC (permalink / raw) Cc: emacs-devel, rms, Kenichi Handa David Kastrup <dak@gnu.org> writes: > storm@cua.dk (Kim F. Storm) writes: > > > I have now reworked my line height changes. > > > > Now, the height of a newline equals the current face height, unless an > > explicit line-spacing property is present on the newline character. > > > > If the value of the line-spacing property is t, you get the effect of > > my previous change, i.e. the newline character does not add to the > > height of the row by itself, but the newline glyph is re-positioned > > inside the available row height to make it fully visible (when the > > cursor is above it). > > > > If the value is an integer, it overrides the value of the frame > > line-spacing parameter and the (buffer local) value of the line-spacing > > variable. > > So presumably setting the value to 0 will make the newline have the > height of a normal space in the line? With the current code, it will have the height of a space in the current face, not the default face. Maybe the functionality should be that newlines are by default always in the default face height, and the line-spacing property should not change that. Instead, it would be better to have a separate line-height property which can have values: nil -> use default face height (as minimum height) t -> use height of current face 0 -> use actual line height N (integer > 0) -> use N pixels (as minimum height) F (float > 0.0) -> use F * default face height I think that would be a much cleaner interface. > > One thing that one should try is to have no surprising changes if the > newline is turned into a space while keeping its properties: > re-filling a paragraph will do that. You can just put the line-spacing (or line-height) property on the whole paragraph and make it sticky. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-26 9:38 ` Kim F. Storm @ 2004-04-27 0:34 ` Kim F. Storm 2004-04-26 22:50 ` David Kastrup 2004-04-29 2:06 ` Kenichi Handa 0 siblings, 2 replies; 95+ messages in thread From: Kim F. Storm @ 2004-04-27 0:34 UTC (permalink / raw) Cc: Kenichi Handa, rms, emacs-devel I have just installed changes to revert to the 21.3 functionality for newline height calculation, that is, use the current face font height (by default). Then I added a new line-height property on the newline with the following values: nil -> use height of current face (the default) t -> use default face height (as minimum height) 0 -> use (don't increase) actual line height N (integer > 0) -> use N pixels (as minimum height) F (float > 0.0) -> use F * current face font height The line-spacing property now just specifies additional line-spacing like the line-spacing variable and frame parameter. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-27 0:34 ` Kim F. Storm @ 2004-04-26 22:50 ` David Kastrup 2004-04-27 1:30 ` Miles Bader 2004-04-29 2:06 ` Kenichi Handa 1 sibling, 1 reply; 95+ messages in thread From: David Kastrup @ 2004-04-26 22:50 UTC (permalink / raw) Cc: Kenichi Handa, rms, emacs-devel storm@cua.dk (Kim F. Storm) writes: > I have just installed changes to revert to the 21.3 functionality for > newline height calculation, that is, use the current face font height > (by default). Is that really the 21.3 default? I am asking because I was of the impression that the line arrangement usually was fixed to the ascent/descent values of the default face, rather than the current face: namely that merely switching to a smaller font would not decrease the distance of lines unless you changed the frame's _default_ face. Or do we have different values for "height of newline" and "total height of line"? If so, how are they related? > Then I added a new line-height property on the newline with the > following values: > > nil -> use height of current face (the default) > t -> use default face height (as minimum height) > 0 -> use (don't increase) actual line height > N (integer > 0) -> use N pixels (as minimum height) > F (float > 0.0) -> use F * current face font height Is 0 a special case of N (use 0 pixels as minimum height)? If so, would it be the same as 0.0, too? >From your pointing out the different cases, it would appear that they differ. I am trying to get a feel of things. > The line-spacing property now just specifies additional line-spacing > like the line-spacing variable and frame parameter. All in all, this behavior sounds much more consistent and free from unexpected sideeffects than the previous implementation. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-26 22:50 ` David Kastrup @ 2004-04-27 1:30 ` Miles Bader 2004-04-27 9:30 ` Kim F. Storm 0 siblings, 1 reply; 95+ messages in thread From: Miles Bader @ 2004-04-27 1:30 UTC (permalink / raw) Cc: Kenichi Handa, emacs-devel, rms, Kim F. Storm David Kastrup <dak@gnu.org> writes: > > nil -> use height of current face (the default) > > t -> use default face height (as minimum height) > > 0 -> use (don't increase) actual line height > > N (integer > 0) -> use N pixels (as minimum height) > > F (float > 0.0) -> use F * current face font height > > Is 0 a special case of N (use 0 pixels as minimum height)? Sounds like it. Maybe the description would be more clear if phrased that way, e.g. -- N (integer) -> use N pixels (as minimum height); note that 0 will give you exactly the actual line height > > F (float > 0.0) -> use F * current face font height > > If so, would it be the same as 0.0, too? I assume that the F case is really a minimum too (really that that the display engine can't _not_ do that), so that sounds like it's true for the same reasons as the N case. -Miles -- `The suburb is an obsolete and contradictory form of human settlement' ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-27 1:30 ` Miles Bader @ 2004-04-27 9:30 ` Kim F. Storm 2004-04-27 13:22 ` David Kastrup 0 siblings, 1 reply; 95+ messages in thread From: Kim F. Storm @ 2004-04-27 9:30 UTC (permalink / raw) Cc: David Kastrup, emacs-devel, rms, Kenichi Handa Miles Bader <miles@lsi.nec.co.jp> writes: > David Kastrup <dak@gnu.org> writes: > > > nil -> use height of current face (the default) > > > t -> use default face height (as minimum height) > > > 0 -> use (don't increase) actual line height > > > N (integer > 0) -> use N pixels (as minimum height) > > > F (float > 0.0) -> use F * current face font height > > > > Is 0 a special case of N (use 0 pixels as minimum height)? > > Sounds like it. Not exactly -- the 0 value is a little special in the sense that it _also_ tries to reposition the ascent/descent of the space glyph so that when the cursor is on that glyph, as much as possible of the cursor is visible. This is different from a value > 0, as that just gives a minimum height -- and if the space glyph is taller than that, clipping occurs. Maybe it should also try to reposition the cursor in this case; if so, 0 would indeed be just a special case of N > 0 and F > 0.0 > > Maybe the description would be more clear if phrased that way, e.g. -- > > N (integer) -> use N pixels (as minimum height); note that > 0 will give you exactly the actual line height > > > > F (float > 0.0) -> use F * current face font height > > > > If so, would it be the same as 0.0, too? > > I assume that the F case is really a minimum too (really that that the > display engine can't _not_ do that), so that sounds like it's true for > the same reasons as the N case. Well, it's not really true for the reasons just explained. Another issue is whether F should be relative the current face font or the frame default font? I chose current font, as it enables you to use default font when necessary, while the opposite isn't true. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-27 9:30 ` Kim F. Storm @ 2004-04-27 13:22 ` David Kastrup 2004-04-27 14:00 ` David Kastrup 0 siblings, 1 reply; 95+ messages in thread From: David Kastrup @ 2004-04-27 13:22 UTC (permalink / raw) Cc: emacs-devel, rms, Kenichi Handa, Miles Bader storm@cua.dk (Kim F. Storm) writes: > Miles Bader <miles@lsi.nec.co.jp> writes: > > > David Kastrup <dak@gnu.org> writes: > > > > nil -> use height of current face (the default) > > > > t -> use default face height (as minimum height) > > > > 0 -> use (don't increase) actual line height > > > > N (integer > 0) -> use N pixels (as minimum height) > > > > F (float > 0.0) -> use F * current face font height > > > > > > Is 0 a special case of N (use 0 pixels as minimum height)? > > > > Sounds like it. > > Not exactly -- the 0 value is a little special in the sense that it > _also_ tries to reposition the ascent/descent of the space glyph > so that when the cursor is on that glyph, as much as possible of the > cursor is visible. > > This is different from a value > 0, as that just gives a minimum > height -- and if the space glyph is taller than that, clipping occurs. > Maybe it should also try to reposition the cursor in this case; if so, > 0 would indeed be just a special case of N > 0 and F > 0.0 Ok, here is my take on it: the height of the newline glyph is more or less relevant when we visibly mark a region or change the background locally in any other manner or have the cursor box on it: then the skyline of the top is given by the glyph height, right? It would appear to me that for this purpose it would be most consistent if we used the same rules for spaces as for newline. The rule I would propose is the following: always use the height of the _current_ font at the point of the space or newline, unless that would exceed the actually available height (which normally will never fall behind the ascent of the default font, unless we use text properties on the newline character). 0 will be a special case, spaces will usually have the height of the font that they are corresponding to, and the presence of one overtall character or image will not cause all other spaces to look overtall. > Another issue is whether F should be relative the current face font > or the frame default font? I chose current font, as it enables you > to use default font when necessary, while the opposite isn't true. Well, we already established that having a paragraph of small print with line distance reduced to the natural size of the small print would be nice. Tacking an 1.0 value on the text will achieve that. But in that case, having some smaller print within the small print will again cause inconsistencies. And it is somewhat contraintuitive if a relative size of 1.0 causes a change. So I think that the default of the relative size should refer to the default face of the frame. If you want to allow a different base face for specifying relative sizes, you could allow specifications like (1.0 . small-face) That would allow to set a paragraph in small print by placing the respective line distance property on it. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-27 13:22 ` David Kastrup @ 2004-04-27 14:00 ` David Kastrup 2004-04-28 10:12 ` Richard Stallman 0 siblings, 1 reply; 95+ messages in thread From: David Kastrup @ 2004-04-27 14:00 UTC (permalink / raw) Cc: Miles Bader, Kenichi Handa, rms, emacs-devel David Kastrup <dak@gnu.org> writes: > storm@cua.dk (Kim F. Storm) writes: > > > Miles Bader <miles@lsi.nec.co.jp> writes: > > > > > David Kastrup <dak@gnu.org> writes: > > > > > nil -> use height of current face (the default) > > > > > t -> use default face height (as minimum height) > > > > > 0 -> use (don't increase) actual line height > > > > > N (integer > 0) -> use N pixels (as minimum height) > > > > > F (float > 0.0) -> use F * current face font height > > > > > > > > Is 0 a special case of N (use 0 pixels as minimum height)? > > > > > > Sounds like it. > > > > Not exactly -- the 0 value is a little special in the sense that it > > _also_ tries to reposition the ascent/descent of the space glyph > > so that when the cursor is on that glyph, as much as possible of the > > cursor is visible. > > Ok, here is my take on it: the height of the newline glyph is more or > less relevant when we visibly mark a region or change the background > locally in any other manner or have the cursor box on it: then the > skyline of the top is given by the glyph height, right? It would > appear to me that for this purpose it would be most consistent if we > used the same rules for spaces as for newline. The rule I would > propose is the following: always use the height of the _current_ font > at the point of the space or newline, unless that would exceed the > actually available height (which normally will never fall behind the > ascent of the default font, unless we use text properties on the > newline character). > > 0 will be a special case, I mean, will _not_ be a special case. Sorry. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-27 14:00 ` David Kastrup @ 2004-04-28 10:12 ` Richard Stallman 2004-04-28 10:58 ` David Kastrup 0 siblings, 1 reply; 95+ messages in thread From: Richard Stallman @ 2004-04-28 10:12 UTC (permalink / raw) Cc: miles, emacs-devel, handa, storm The rule I would > propose is the following: always use the height of the _current_ font > at the point of the space or newline, unless that would exceed the > actually available height (which normally will never fall behind the > ascent of the default font, unless we use text properties on the > newline character). Treating spaces and newlines alike could be a good idea since filling converts between them. What is the "actually available height"? I am not sure what that phrase means. However, the use of the current font for either spaces or newlines seems to be a mistake, because of the case I mentioned earlier (more than one line of small text in a paragraph of larger text). ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-28 10:12 ` Richard Stallman @ 2004-04-28 10:58 ` David Kastrup 2004-04-29 0:29 ` Kim F. Storm 2004-04-29 13:31 ` Richard Stallman 0 siblings, 2 replies; 95+ messages in thread From: David Kastrup @ 2004-04-28 10:58 UTC (permalink / raw) Cc: miles, emacs-devel, handa, storm Richard Stallman <rms@gnu.org> writes: > > The rule I would propose is the following: always use the > > height of the _current_ font at the point of the space or > > newline, unless that would exceed the actually available > > height (which normally will never fall behind the ascent of > > the default font, unless we use text properties on the newline > > character). > > Treating spaces and newlines alike could be a good idea since > filling converts between them. > > What is the "actually available height"? I am not sure what that > phrase means. However, the use of the current font for either > spaces or newlines seems to be a mistake, because of the case I > mentioned earlier (more than one line of small text in a paragraph > of larger text). I was talking here about the visual appearance of the cursor and probably the top line of highlighting boxes: for those I think it appropriate to use the current font height (there is no sense in having taller or smaller boxes than the characters around them). The line distance is determined differently: it is constant for a frame unless that would cause overlapping rows with the actual glyph dimensions, or unless we change it with special properties on the newline characters. Those special properties can also be put on space and other characters but have no effect there. At least that's how I understood the last proposals. It means that if one wants to have a paragraph with smaller line distance, one can explicitly cover it with an appropriate property. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-28 10:58 ` David Kastrup @ 2004-04-29 0:29 ` Kim F. Storm 2004-04-28 22:52 ` David Kastrup 2004-04-29 13:31 ` Richard Stallman 1 sibling, 1 reply; 95+ messages in thread From: Kim F. Storm @ 2004-04-29 0:29 UTC (permalink / raw) Cc: rms, emacs-devel David Kastrup <dak@gnu.org> writes: > The line distance is determined differently: it is constant for a > frame unless that would cause overlapping rows with the actual glyph > dimensions, or unless we change it with special properties on the > newline characters. Those special properties can also be put on space > and other characters but have no effect there. > > At least that's how I understood the last proposals. It means that if > one wants to have a paragraph with smaller line distance, one can > explicitly cover it with an appropriate property. With my latest changes, emacs has two properties on newlines: * line-height which gives the minimum line height; default minimum line height is given by the height of the face of the newline character. The actual line height is determined by the text on the line; if some glyphs are taller than the minimum line height, the actual line height is increased. * line-spacing which adds additional pixels between this line and the next line. Default is the value of the line-spacing variable (usually 0). So there is still no "fixed line-distance" concept in emacs, as lines can always be taller than the ordinary line-distance. BTW, the line-height and line-spacing properties are currently only supported as text-properties; should this be extended to check for overlays too? -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-29 0:29 ` Kim F. Storm @ 2004-04-28 22:52 ` David Kastrup 0 siblings, 0 replies; 95+ messages in thread From: David Kastrup @ 2004-04-28 22:52 UTC (permalink / raw) Cc: rms, emacs-devel no-spam@cua.dk (Kim F. Storm) writes: > David Kastrup <dak@gnu.org> writes: > > > The line distance is determined differently: it is constant for a > > frame unless that would cause overlapping rows with the actual glyph > > dimensions, or unless we change it with special properties on the > > newline characters. Those special properties can also be put on space > > and other characters but have no effect there. > > > > At least that's how I understood the last proposals. It means that if > > one wants to have a paragraph with smaller line distance, one can > > explicitly cover it with an appropriate property. > > With my latest changes, emacs has two properties on newlines: > > * line-height which gives the minimum line height; > default minimum line height is given by the height of the face > of the newline character. > > The actual line height is determined by the text on the line; > if some glyphs are taller than the minimum line height, the > actual line height is increased. That's what I meant with "unless that would cause overlapping rows". > * line-spacing which adds additional pixels between this line and the > next line. Default is the value of the line-spacing variable > (usually 0). > > So there is still no "fixed line-distance" concept in emacs, as > lines can always be taller than the ordinary line-distance. > > BTW, the line-height and line-spacing properties are currently only > supported as text-properties; should this be extended to check for > overlays too? Yes. I'll need this eventually in preview-latex for sliced images, and preview-latex works exclusively with overlays (it never touches the text itself). -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-28 10:58 ` David Kastrup 2004-04-29 0:29 ` Kim F. Storm @ 2004-04-29 13:31 ` Richard Stallman 1 sibling, 0 replies; 95+ messages in thread From: Richard Stallman @ 2004-04-29 13:31 UTC (permalink / raw) Cc: miles, emacs-devel, handa, storm The line distance is determined differently: it is constant for a frame unless that would cause overlapping rows with the actual glyph dimensions, or unless we change it with special properties on the newline characters. Those special properties can also be put on space and other characters but have no effect there. That sounds good. Filling could propagate these properties. ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-27 0:34 ` Kim F. Storm 2004-04-26 22:50 ` David Kastrup @ 2004-04-29 2:06 ` Kenichi Handa 2004-04-29 10:00 ` Kim F. Storm 1 sibling, 1 reply; 95+ messages in thread From: Kenichi Handa @ 2004-04-29 2:06 UTC (permalink / raw) Cc: dak, rms, emacs-devel In article <m3u0z6ntqo.fsf@kfs-l.imdomain.dk>, storm@cua.dk (Kim F. Storm) writes: > I have just installed changes to revert to the 21.3 functionality for > newline height calculation, that is, use the current face font height > (by default). > Then I added a new line-height property on the newline with the > following values: > nil -> use height of current face (the default) > t -> use default face height (as minimum height) > 0 -> use (don't increase) actual line height > N (integer > 0) -> use N pixels (as minimum height) > F (float > 0.0) -> use F * current face font height If there's no line-height property, a height of a space glyph (for SPC, TAB, NL) is decided by the height of a SPACE glyph of a font. But, it seems that we can make their height exactly what requested by a face. Then I think we don't have to introduce line-height property. Each line-height property value can be simulated as follows. nil -- do nothing t -- add `default' face 0 -- make a face of height 0 and add it N -- make a face by :height N (but specifies it by 1/10 pt) and add it. F -- make a face by :height F and add it --- Ken'ichi HANDA handa@m17n.org ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-29 2:06 ` Kenichi Handa @ 2004-04-29 10:00 ` Kim F. Storm 2004-04-30 1:54 ` Kenichi Handa 0 siblings, 1 reply; 95+ messages in thread From: Kim F. Storm @ 2004-04-29 10:00 UTC (permalink / raw) Cc: dak, rms, emacs-devel Kenichi Handa <handa@m17n.org> writes: > In article <m3u0z6ntqo.fsf@kfs-l.imdomain.dk>, storm@cua.dk (Kim F. Storm) writes: > > I have just installed changes to revert to the 21.3 functionality for > > newline height calculation, that is, use the current face font height > > (by default). > > > Then I added a new line-height property on the newline with the > > following values: > > > nil -> use height of current face (the default) > > t -> use default face height (as minimum height) > > 0 -> use (don't increase) actual line height > > N (integer > 0) -> use N pixels (as minimum height) > > F (float > 0.0) -> use F * current face font height > > If there's no line-height property, a height of a space > glyph (for SPC, TAB, NL) is decided by the height of a SPACE > glyph of a font. But, it seems that we can make their > height exactly what requested by a face. Then I think we > don't have to introduce line-height property. Each > line-height property value can be simulated as follows. > > nil -- do nothing > t -- add `default' face > 0 -- make a face of height 0 and add it > N -- make a face by :height N (but specifies it by 1/10 pt) and add it. > F -- make a face by :height F and add it This is possible, yes, but the main advantage of the line-height property is that you can put it on an entire region -- independent of the faces in that region -- and make the line spacing work independint of filling, untabitying etc. which may add/delete newlines (which will automatically inherit the line-height property). -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-29 10:00 ` Kim F. Storm @ 2004-04-30 1:54 ` Kenichi Handa 0 siblings, 0 replies; 95+ messages in thread From: Kenichi Handa @ 2004-04-30 1:54 UTC (permalink / raw) Cc: dak, rms, emacs-devel In article <m38ygf2je5.fsf@kfs-l.imdomain.dk>, storm@cua.dk (Kim F. Storm) writes: > This is possible, yes, but the main advantage of the line-height > property is that you can put it on an entire region -- independent of > the faces in that region -- and make the line spacing work independint > of filling, untabitying etc. which may add/delete newlines (which will > automatically inherit the line-height property). I see the point. --- Ken'ichi HANDA handa@m17n.org ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-25 1:56 ` Kim F. Storm 2004-04-25 2:06 ` David Kastrup @ 2004-04-29 2:20 ` Kenichi Handa 1 sibling, 0 replies; 95+ messages in thread From: Kenichi Handa @ 2004-04-29 2:20 UTC (permalink / raw) Cc: dak, rms, emacs-devel In article <m33c6sakh4.fsf@kfs-l.imdomain.dk>, storm@cua.dk (Kim F. Storm) writes: >> By the way, it seems that the current code doesn't draw a >> hollow cursor correctly. The bottom line of the rectangle >> is not drawn (see the attached image). > That's an old bug which probably never got noticed because lines were > never less that the default face height. > I fixed that too. Thank you, I confimed it's fixed. --- Ken'ichi HANDA handa@m17n.org ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-22 23:53 ` Kim F. Storm 2004-04-22 23:02 ` David Kastrup 2004-04-23 0:33 ` Kenichi Handa @ 2004-04-25 18:09 ` Richard Stallman 2004-04-29 0:17 ` Kim F. Storm 2 siblings, 1 reply; 95+ messages in thread From: Richard Stallman @ 2004-04-25 18:09 UTC (permalink / raw) Cc: dak, emacs-devel Quite contrary, I always found it very odd (i.e. buggy) that emacs forces all lines to be at least as high as the default frame line height. That means that you cannot have any "fine print". Paragraphs of "fine print" should have smaller line spacing. However, when text in a smaller font appears in the middle of a paragraph that is mainly ordinary size, even if one whole line is in the smaller font, that line's spacing should not be reduced. So the right way to handle this is not really based on the size of the text in the line. Another idea is to make it depend on the height of the newlines. That would mean putting the newlines into the ordinary font even though the text around them is in a smaller font. That would work provided the fill commands know how to keep the newlines in the ordinary font. ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-25 18:09 ` Richard Stallman @ 2004-04-29 0:17 ` Kim F. Storm 2004-04-28 23:02 ` David Kastrup 2004-04-30 9:02 ` Richard Stallman 0 siblings, 2 replies; 95+ messages in thread From: Kim F. Storm @ 2004-04-29 0:17 UTC (permalink / raw) Cc: dak, emacs-devel Richard Stallman <rms@gnu.org> writes: > Quite contrary, I always found it very odd (i.e. buggy) that emacs > forces all lines to be at least as high as the default frame line > height. That means that you cannot have any "fine print". > > Paragraphs of "fine print" should have smaller line spacing. However, > when text in a smaller font appears in the middle of a paragraph that > is mainly ordinary size, even if one whole line is in the smaller > font, that line's spacing should not be reduced. But 21.2 did that, so I have tried to be compatible. > > So the right way to handle this is not really based on the size > of the text in the line. > > Another idea is to make it depend on the height of the newlines. That is what it does already -- the height of the newline is derived from the face font of the newline, not the text in the line. But if the text in the line is taller than the ordinary line height, the text height "wins". > That > would mean putting the newlines into the ordinary font even though the > text around them is in a smaller font. That would work provided the > fill commands know how to keep the newlines in the ordinary font. > We could accomplish this by setting the line-height property to the pixel height of a specific face *) The effect of this would be that newlines would have the height of that face, rather than the current font. Code could then set the line-height from that face's height on a whole paragraph to make it immune to filling changing the spaces & newlines in the paragraph. Of course, this requires that code explicitly specifies the face to use for line spacing, but since any existing code will assume the 21.2 behaviour, this approach is backwards compatible. *) I don't see any way to actually obtain the pixel height of a face from lisp. What about adding a face-char-height function (corresponding to frame-char-height). Args would be FACE &optional FRAME. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-29 0:17 ` Kim F. Storm @ 2004-04-28 23:02 ` David Kastrup 2004-04-29 9:51 ` Kim F. Storm 2004-04-30 1:07 ` Kim F. Storm 2004-04-30 9:02 ` Richard Stallman 1 sibling, 2 replies; 95+ messages in thread From: David Kastrup @ 2004-04-28 23:02 UTC (permalink / raw) Cc: rms, emacs-devel no-spam@cua.dk (Kim F. Storm) writes: > We could accomplish this by setting the line-height property to the > pixel height of a specific face *) The effect of this would be that > newlines would have the height of that face, rather than the current > font. Is there a particular reason to have the unit of the line-height be in pixels? We specify face dimensions in units of tenths of a point elsewhere. Not that I am convinced that is the best way, though. Anyway, it would be nice if one could specify this relative to a particular face. Something like '(line-height . (1.0 . small-face)) '(line-height . (1.2 . nil)) ;; means the current face '(line-height . (1.2 . default)) ;; same as the following '(line-height . 1.2) ;; relative to default Something like that. If somebody has a better idea to specify "current face", that would be nice. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-28 23:02 ` David Kastrup @ 2004-04-29 9:51 ` Kim F. Storm 2004-04-29 8:08 ` David Kastrup 2004-04-30 1:07 ` Kim F. Storm 1 sibling, 1 reply; 95+ messages in thread From: Kim F. Storm @ 2004-04-29 9:51 UTC (permalink / raw) Cc: rms, emacs-devel David Kastrup <dak@gnu.org> writes: > > We could accomplish this by setting the line-height property to the > > pixel height of a specific face *) The effect of this would be that > > newlines would have the height of that face, rather than the current > > font. > > Is there a particular reason to have the unit of the line-height be in > pixels? We specify face dimensions in units of tenths of a point > elsewhere. Not that I am convinced that is the best way, though. The main reason is that the display engine counts in pixels -- so that's the value that is "needed" there; of course, we could convert points to pixels (somehow, I'm not a `face expert'). > > Anyway, it would be nice if one could specify this relative to a > particular face. Something like But except for the "dynamic vs. static" properties here, that's the same effect you get with my simpler proposal: > > '(line-height . (1.0 . small-face)) `(line-height . ,(face-char-height 'small-face)) > > '(line-height . (1.2 . nil)) ;; means the current face '(line-height . 1.2) > '(line-height . (1.2 . default)) ;; same as the following > '(line-height . 1.2) ;; relative to default `(line-height . ,(round (* 1.2 (face-char-height 'default)))) > > Something like that. If somebody has a better idea to specify > "current face", that would be nice. Of course it can be done as you propose (I planned to do that myself), but it makes the redisplay engine more complex -- and I doubt the added flexibility/complexity is really needed. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-29 9:51 ` Kim F. Storm @ 2004-04-29 8:08 ` David Kastrup 2004-04-29 11:24 ` Kim F. Storm 0 siblings, 1 reply; 95+ messages in thread From: David Kastrup @ 2004-04-29 8:08 UTC (permalink / raw) Cc: rms, emacs-devel storm@cua.dk (Kim F. Storm) writes: > David Kastrup <dak@gnu.org> writes: > > > Anyway, it would be nice if one could specify this relative to a > > particular face. Something like > > But except for the "dynamic vs. static" properties here, that's > the same effect you get with my simpler proposal: > > > > > '(line-height . (1.0 . small-face)) > > `(line-height . ,(face-char-height 'small-face)) The problem is that I have to know the actual display that will get used in order to convert this into pixels. If I have the same buffer on two different displays (like M-x talk-connect RET does), then the same faces might have completely different pixel dimensions. It also means that I can't set up the buffer independent of the display that it is going to be shown on. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-29 8:08 ` David Kastrup @ 2004-04-29 11:24 ` Kim F. Storm 0 siblings, 0 replies; 95+ messages in thread From: Kim F. Storm @ 2004-04-29 11:24 UTC (permalink / raw) Cc: rms, emacs-devel David Kastrup <dak@gnu.org> writes: > The problem is that I have to know the actual display that will get > used in order to convert this into pixels. If I have the same buffer > on two different displays (like M-x talk-connect RET does), then the > same faces might have completely different pixel dimensions. > > It also means that I can't set up the buffer independent of the > display that it is going to be shown on. That's a good point -- I'll see what I can do. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-28 23:02 ` David Kastrup 2004-04-29 9:51 ` Kim F. Storm @ 2004-04-30 1:07 ` Kim F. Storm 2004-04-30 11:31 ` David Kastrup 2004-05-01 9:44 ` Several suggestions for image support Richard Stallman 1 sibling, 2 replies; 95+ messages in thread From: Kim F. Storm @ 2004-04-30 1:07 UTC (permalink / raw) Cc: rms, emacs-devel David Kastrup <dak@gnu.org> writes: > Anyway, it would be nice if one could specify this relative to a > particular face. Something like > I implemented this proposal, with a few changes: '(line-height . (1.0 . small-face)) '(line-height . (1.2 . t)) ;; means the current face '(line-height . (1.2 . nil)) ;; same as the following '(line-height . 1.2) ;; relative to default The same values can be specified for the line-spacing property. In addition, the line-spacing property value may be negative, in which case the abs value is used as a total line height (so extra pixels are optionally inserted after the line to make its height the specified value, e.g. the following are equivalent when the default face is used: 0.5 -1.5 But if the default line height is, say 12 pixels, and the current line is 10 pixels, then the line-spacing value of 0.5 adds 6 pixels to the height (resulting in a height of 16 pixels), while -1.5 adds 8 pixels giving a total height of 18 pixels = 1.5 x 12. Can we close this issue now ? -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-30 1:07 ` Kim F. Storm @ 2004-04-30 11:31 ` David Kastrup 2004-04-30 14:21 ` Kim F. Storm 2004-05-01 9:44 ` Several suggestions for image support Richard Stallman 1 sibling, 1 reply; 95+ messages in thread From: David Kastrup @ 2004-04-30 11:31 UTC (permalink / raw) Cc: rms, emacs-devel storm@cua.dk (Kim F. Storm) writes: [line spacing properties] > Can we close this issue now ? Sounds good. Of course, documentation and bug fixing will have to follow, but that will occur mostly after the feature freeze. From what I can see without actually using it, this looks good. It accomplishes a lot more than what I originally asked for, but in a generally useful and upwards-compatible and sensible way, as far as I can see. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-30 11:31 ` David Kastrup @ 2004-04-30 14:21 ` Kim F. Storm 2004-04-30 13:30 ` David Kastrup 2004-04-30 13:49 ` preview-latex in Emacs (was: Several suggestions for image support) Stefan Monnier 0 siblings, 2 replies; 95+ messages in thread From: Kim F. Storm @ 2004-04-30 14:21 UTC (permalink / raw) Cc: emacs-devel David Kastrup <dak@gnu.org> writes: > storm@cua.dk (Kim F. Storm) writes: > > [line spacing properties] > > > Can we close this issue now ? > > Sounds good. Of course, documentation and bug fixing will have to > follow, but that will occur mostly after the feature freeze. Sure. > From > what I can see without actually using it, this looks good. It > accomplishes a lot more than what I originally asked for, but in a > generally useful and upwards-compatible and sensible way, as far as I > can see. Now we just need to have preview-latex included with CVS emacs. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-30 14:21 ` Kim F. Storm @ 2004-04-30 13:30 ` David Kastrup 2004-04-30 13:49 ` preview-latex in Emacs (was: Several suggestions for image support) Stefan Monnier 1 sibling, 0 replies; 95+ messages in thread From: David Kastrup @ 2004-04-30 13:30 UTC (permalink / raw) Cc: emacs-devel storm@cua.dk (Kim F. Storm) writes: > David Kastrup <dak@gnu.org> writes: > > > what I can see without actually using it, this looks good. It > > accomplishes a lot more than what I originally asked for, but in a > > generally useful and upwards-compatible and sensible way, as far > > as I can see. > > Now we just need to have preview-latex included with CVS emacs. Not feasible at the moment: while preview-latex has a pretty limited scope of developers that would all agree to signing over the necessary stuff, its process system and a few other things pretty much are tied into AUCTeX. So unless somebody volunteers to come up with replacements for all of the locations where preview-latex relies on AUCTeX, placing preview-latex within Emacs would be useless. AUCTeX can't be placed into CVS Emacs right now because the copyright, though licenced under the GPL, is pretty much diluted over the course of 12 years or so. The principal copyright holders have partly agreed to sign papers, partly already done so, but a lot of hunting will be needed to round up every contributor, and the work is still being done. The aim is to have it acceptable into Emacs at some point of time. It is not going to happen before the next releasable Emacs state is reached AFAICS. Making preview-latex independent from AUCTeX might also be used to boost the rendering facilities of Emacs, and maybe to add graphical modes into calc and stuff. But all of this is not something for which any of the current preview-latex developers happens to have any resources available. The long-term plans are to fold preview-latex into AUCTeX some time next year to make it more generally available. Since there is nobody having time into making preview-latex an independent component from AUCTeX, this seems to be the best approach at the current point of time. So in short: getting preview-latex assigned to be placed into Emacs would not be much of a problem, but it has a dependency on AUCTeX, and assignments for that will take longer and are not guaranteed to arrive. If things come to worst, some rewriting might even be needed. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* preview-latex in Emacs (was: Several suggestions for image support) 2004-04-30 14:21 ` Kim F. Storm 2004-04-30 13:30 ` David Kastrup @ 2004-04-30 13:49 ` Stefan Monnier 1 sibling, 0 replies; 95+ messages in thread From: Stefan Monnier @ 2004-04-30 13:49 UTC (permalink / raw) Cc: David Kastrup, emacs-devel > Now we just need to have preview-latex included with CVS emacs. Since it does not work with Emacs's tex-mode.el but only with AUCTeX, it would only make sense if we either also include AUCTeX, or hack preview-latex to the point where it works with tex-mode.el, or hack tex-mode.el to the point where it works with preview-latex. Stefan ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-30 1:07 ` Kim F. Storm 2004-04-30 11:31 ` David Kastrup @ 2004-05-01 9:44 ` Richard Stallman 2004-05-01 19:56 ` Kim F. Storm 1 sibling, 1 reply; 95+ messages in thread From: Richard Stallman @ 2004-05-01 9:44 UTC (permalink / raw) Cc: dak, emacs-devel In addition, the line-spacing property value may be negative, in which case the abs value is used as a total line height (so extra pixels are optionally inserted after the line to make its height the specified value, e.g. the following are equivalent when the default face is used: Wouldn't it be cleaner to distinguish this particular kind of specification by something other than sign of the number? ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-05-01 9:44 ` Several suggestions for image support Richard Stallman @ 2004-05-01 19:56 ` Kim F. Storm 2004-05-02 19:52 ` Richard Stallman 0 siblings, 1 reply; 95+ messages in thread From: Kim F. Storm @ 2004-05-01 19:56 UTC (permalink / raw) Cc: dak, emacs-devel Richard Stallman <rms@gnu.org> writes: > In addition, the line-spacing property value may be negative, in which > case the abs value is used as a total line height (so extra pixels are > optionally inserted after the line to make its height the specified > value, e.g. the following are equivalent when the default face is used: > > Wouldn't it be cleaner to distinguish this particular kind of > specification by something other than sign of the number? Yes. Current formats are: 1.3 or (1.3 . face) => extra line spacing -1.3 or (-1.3 . face) => total line spacing What about (height . 1.3) or (height . (1.3 . face)) => total line spacing or (equal . 1.3) or (equal . (1.3 . face)) => total line spacing or ((1.3)) or ((1.3 . face)) Any other suggestions? -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-05-01 19:56 ` Kim F. Storm @ 2004-05-02 19:52 ` Richard Stallman 2004-05-03 9:19 ` David Kastrup 0 siblings, 1 reply; 95+ messages in thread From: Richard Stallman @ 2004-05-02 19:52 UTC (permalink / raw) Cc: dak, emacs-devel What about (height . 1.3) or (height . (1.3 . face)) => total line spacing or (equal . 1.3) or (equal . (1.3 . face)) => total line spacing I think `total' would be clearer than `height' or `equal'. or ((1.3)) or ((1.3 . face)) That is less clear than using a symbol. ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-05-02 19:52 ` Richard Stallman @ 2004-05-03 9:19 ` David Kastrup 0 siblings, 0 replies; 95+ messages in thread From: David Kastrup @ 2004-05-03 9:19 UTC (permalink / raw) Cc: emacs-devel, Kim F. Storm Richard Stallman <rms@gnu.org> writes: > What about > > (height . 1.3) or (height . (1.3 . face)) => total line spacing > or > (equal . 1.3) or (equal . (1.3 . face)) => total line spacing > > I think `total' would be clearer than `height' or `equal'. TeX uses the terminology width, height (ascent above baseline), depth (descent below line) and totalheight (height+depth). -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-29 0:17 ` Kim F. Storm 2004-04-28 23:02 ` David Kastrup @ 2004-04-30 9:02 ` Richard Stallman 2004-04-30 11:27 ` David Kastrup 1 sibling, 1 reply; 95+ messages in thread From: Richard Stallman @ 2004-04-30 9:02 UTC (permalink / raw) Cc: dak, emacs-devel But if the text in the line is taller than the ordinary line height, the text height "wins". That's right when the text is taller. Text that is shorter is another case. > That > would mean putting the newlines into the ordinary font even though the > text around them is in a smaller font. That would work provided the > fill commands know how to keep the newlines in the ordinary font. > We could accomplish this by setting the line-height property to the pixel height of a specific face *) The effect of this would be that newlines would have the height of that face, rather than the current font. That seems like an approach that could work. BTW, the line-height and line-spacing properties are currently only supported as text-properties; should this be extended to check for overlays too? I don't see a use for them as overlays. ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-30 9:02 ` Richard Stallman @ 2004-04-30 11:27 ` David Kastrup 2004-04-30 14:19 ` Kim F. Storm 0 siblings, 1 reply; 95+ messages in thread From: David Kastrup @ 2004-04-30 11:27 UTC (permalink / raw) Cc: emacs-devel, Kim F. Storm Richard Stallman <rms@gnu.org> writes: > BTW, the line-height and line-spacing properties are currently only > supported as text-properties; should this be extended to check for > overlays too? > > I don't see a use for them as overlays. I do. I'll be using them in preview-latex for the spliced image stuff, and everything preview-latex does is done by overlays: copy&paste does not transfer the images, so it should not transfer the line compression. I could perhaps get by by using text-properties on a newline tacked into the after-string of overlays. Of course this would mean exercising the display engine pretty heavily, pushing my luck. But better now than after a release. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-30 11:27 ` David Kastrup @ 2004-04-30 14:19 ` Kim F. Storm 0 siblings, 0 replies; 95+ messages in thread From: Kim F. Storm @ 2004-04-30 14:19 UTC (permalink / raw) Cc: rms, emacs-devel David Kastrup <dak@gnu.org> writes: > I could perhaps get by by using text-properties on a newline tacked > into the after-string of overlays. Of course this would mean > exercising the display engine pretty heavily, pushing my luck. But > better now than after a release. > It should work with overlays now... -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
[parent not found: <E1BGiB8-00087H-Tz@fencepost.gnu.org>]
[parent not found: <x5brljkgk5.fsf@lola.goethe.zz>]
* Re: Several suggestions for image support [not found] ` <x5brljkgk5.fsf@lola.goethe.zz> @ 2004-04-22 23:32 ` Kim F. Storm 2004-04-22 21:50 ` David Kastrup 0 siblings, 1 reply; 95+ messages in thread From: Kim F. Storm @ 2004-04-22 23:32 UTC (permalink / raw) Cc: rms, emacs-devel David Kastrup <dak@gnu.org> writes: > Richard Stallman <rms@gnu.org> writes: > > > I wonder if slicing images is really the right approach to take. It > > will make possible scrolling through an image, though the interline > > spacing will appear between the slices, which would be ugly. > > Unless we provide a way to suppress the interline spacing in that > case. I specifically reworked the interline spacing code to avoid adding extra spacing in this case. This is generally useful to properly display "pre-sliced" images which are very common on web pages. > > > anyway, requiring programs that display images to slice them is > > rather kludgy. > > Yes, most certainly. Scrolling through images should be possible > without slicing. I agree that it would be a really bad kludge if the > only way to scroll through images would be to require a program to > slice them. I never intended slicing to be used for image scrolling -- it _can_ be used for that, but it was implemented for other purposes. In any case, slicing of images is a general way to display one or more individual sections of a bigger image -- aka "cropping". E.g. with image slicing you can implement the good old 1 2 3 4 5 6 7 8 8 9 A B C D E X puzzle in emacs (I'm not going to do that :-) > > > Is there some other reason to prefer to handle images by slicing > > them? > > I would not recommend them as a general mechanism. However, in the > particular application for which I have asked for this feature, every > slice is associated with a different piece of source code that is > covered by it. Splitting the image is not as much a tool for > managing the display of the image than it is for managing control of > the source code. > > When the source code gets uncovered, it would be convenient to have > the cursor at the location corresponding to where the mouse pointed. > Slicing the image makes this possible. If I use the mouse to mark a > region on the images, this will copy and paste just the text > corresponding to that pieces of the images which have been marked. If > I edit a table cell, only the image of the cell I am editing at the > moment will be replaced by the actual text. In short: I need the > slicing for an application where it is the natural way of dealing > with the image. > > Whereas the proposal to demand applications to artificially slice > their images or Emacs will scroll badly would be an unnatural way of > dealing with it. > > I agree with you that slicing is not a solution to the bad scrolling > of Emacs with regard to images. I just implemented some functions requested by Stefan to assist implementing image scrolling in lisp. -- Kim F. Storm <storm@cua.dk> http://www.cua.dk ^ permalink raw reply [flat|nested] 95+ messages in thread
* Re: Several suggestions for image support 2004-04-22 23:32 ` Kim F. Storm @ 2004-04-22 21:50 ` David Kastrup 0 siblings, 0 replies; 95+ messages in thread From: David Kastrup @ 2004-04-22 21:50 UTC (permalink / raw) Cc: rms, emacs-devel storm@cua.dk (Kim F. Storm) writes: > David Kastrup <dak@gnu.org> writes: > > > Richard Stallman <rms@gnu.org> writes: > > > > > I wonder if slicing images is really the right approach to take. > > > It will make possible scrolling through an image, though the > > > interline spacing will appear between the slices, which would be > > > ugly. > > > > Unless we provide a way to suppress the interline spacing in that > > case. > > I specifically reworked the interline spacing code to avoid adding > extra spacing in this case. > > This is generally useful to properly display "pre-sliced" images > which are very common on web pages. There is no question that we need a way to suppress interline spacing in order to apply sliced images to full utility. But it might be a mistake to do this automatically. For example, preview-latex can replace simple inline math with images. If we now happen to have two rows that consists solely of such inline math images, the interline spacing will vanish and the rows will get too tight. Since the removal of interline spacing is mostly desirable in connection with sliced images, and since there is no code in existence yet that produces sliced images, we are still free to define the semantics. I think it would be a tolerable requirement if one mounted a sliced image from pieces to cover the newline with a text property removing the line spacing, as described in a separate post. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 95+ messages in thread
end of thread, other threads:[~2004-05-03 9:19 UTC | newest] Thread overview: 95+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2004-04-16 0:21 Several suggestions for image support David Kastrup 2004-04-16 9:29 ` YAMAMOTO Mitsuharu 2004-04-16 14:02 ` Kim F. Storm 2004-04-16 12:50 ` Jason Rumney 2004-04-16 16:59 ` Kim F. Storm 2004-04-16 15:18 ` Jason Rumney 2004-04-16 10:22 ` Kim F. Storm 2004-04-16 9:09 ` Jason Rumney 2004-04-16 10:06 ` David Kastrup 2004-04-16 12:38 ` Kim F. Storm 2004-04-16 11:09 ` Jason Rumney 2004-04-16 11:34 ` David Kastrup 2004-04-16 12:29 ` Jason Rumney 2004-04-16 12:56 ` David Kastrup 2004-04-16 17:08 ` Kim F. Storm 2004-04-16 13:39 ` Stefan Monnier 2004-04-16 13:49 ` David Kastrup 2004-04-17 7:16 ` Richard Stallman 2004-04-17 13:02 ` Werner LEMBERG 2004-04-17 19:24 ` David Kastrup 2004-04-17 18:03 ` David Kastrup 2004-04-18 21:30 ` Kim F. Storm 2004-04-19 1:51 ` Stefan Monnier 2004-04-19 7:57 ` David Kastrup 2004-04-19 10:34 ` Kim F. Storm 2004-04-19 14:29 ` Stefan Monnier 2004-04-19 15:17 ` David Kastrup 2004-04-19 15:37 ` Stefan Monnier 2004-04-19 15:56 ` Kim F. Storm 2004-04-19 14:15 ` David Kastrup 2004-04-19 21:59 ` Kim F. Storm 2004-04-21 0:53 ` Kim F. Storm 2004-04-21 1:08 ` Kim F. Storm 2004-04-20 23:31 ` David Kastrup 2004-04-21 3:04 ` Piet van Oostrum 2004-04-22 0:43 ` Kim F. Storm 2004-04-22 1:18 ` YAMAMOTO Mitsuharu 2004-04-22 22:03 ` Piet van Oostrum 2004-04-23 4:02 ` YAMAMOTO Mitsuharu 2004-04-24 14:48 ` Piet van Oostrum 2004-04-21 10:10 ` Kim F. Storm 2004-04-21 8:51 ` David Kastrup 2004-04-21 12:51 ` Kim F. Storm 2004-04-22 17:40 ` Richard Stallman 2004-04-22 18:17 ` David Kastrup 2004-04-24 14:26 ` Richard Stallman 2004-04-22 23:53 ` Kim F. Storm 2004-04-22 23:02 ` David Kastrup 2004-04-23 12:36 ` Kim F. Storm 2004-04-23 15:02 ` Stefan Monnier 2004-04-23 15:05 ` David Kastrup 2004-04-23 0:33 ` Kenichi Handa 2004-04-23 0:51 ` David Kastrup 2004-04-23 12:58 ` Kenichi Handa 2004-04-23 14:53 ` David Kastrup 2004-04-24 14:27 ` Richard Stallman 2004-04-24 15:16 ` David Kastrup 2004-04-25 1:56 ` Kim F. Storm 2004-04-25 2:06 ` David Kastrup 2004-04-26 9:38 ` Kim F. Storm 2004-04-27 0:34 ` Kim F. Storm 2004-04-26 22:50 ` David Kastrup 2004-04-27 1:30 ` Miles Bader 2004-04-27 9:30 ` Kim F. Storm 2004-04-27 13:22 ` David Kastrup 2004-04-27 14:00 ` David Kastrup 2004-04-28 10:12 ` Richard Stallman 2004-04-28 10:58 ` David Kastrup 2004-04-29 0:29 ` Kim F. Storm 2004-04-28 22:52 ` David Kastrup 2004-04-29 13:31 ` Richard Stallman 2004-04-29 2:06 ` Kenichi Handa 2004-04-29 10:00 ` Kim F. Storm 2004-04-30 1:54 ` Kenichi Handa 2004-04-29 2:20 ` Kenichi Handa 2004-04-25 18:09 ` Richard Stallman 2004-04-29 0:17 ` Kim F. Storm 2004-04-28 23:02 ` David Kastrup 2004-04-29 9:51 ` Kim F. Storm 2004-04-29 8:08 ` David Kastrup 2004-04-29 11:24 ` Kim F. Storm 2004-04-30 1:07 ` Kim F. Storm 2004-04-30 11:31 ` David Kastrup 2004-04-30 14:21 ` Kim F. Storm 2004-04-30 13:30 ` David Kastrup 2004-04-30 13:49 ` preview-latex in Emacs (was: Several suggestions for image support) Stefan Monnier 2004-05-01 9:44 ` Several suggestions for image support Richard Stallman 2004-05-01 19:56 ` Kim F. Storm 2004-05-02 19:52 ` Richard Stallman 2004-05-03 9:19 ` David Kastrup 2004-04-30 9:02 ` Richard Stallman 2004-04-30 11:27 ` David Kastrup 2004-04-30 14:19 ` Kim F. Storm [not found] ` <E1BGiB8-00087H-Tz@fencepost.gnu.org> [not found] ` <x5brljkgk5.fsf@lola.goethe.zz> 2004-04-22 23:32 ` Kim F. Storm 2004-04-22 21:50 ` David Kastrup
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.