From: Drew Adams <drew.adams@oracle.com>
To: Eli Zaretskii <eliz@gnu.org>
Cc: 18637@debbugs.gnu.org
Subject: bug#18637: 24.4.50; doc of frame parameter DISPLAY vs actual value on MS Windows
Date: Mon, 6 Oct 2014 09:31:00 -0700 (PDT) [thread overview]
Message-ID: <b5ac6ce3-5c0d-4517-a44f-6925cfccdcfd@default> (raw)
In-Reply-To: <<83ppe5mfed.fsf@gnu.org>>
> > Is there no support for multiple monitors on MS Windows?
>
> There is, but by and large, Emacs will see them as a single large
> desktop. See here:
> http://msdn.microsoft.com/en-us/library/dd145071%28v=vs.85%29.aspx
> (We don't support the "independent monitors" mode mentioned there.)
>
> In any case, "multiple monitors" and "multiple displays" are 2
> different issues. Each display can have multiple monitors.
OK. Where can one find doc about using multiple monitors with Emacs?
> > I was not able to find out how to obtain info about which monitor
> > is being used to show a particular frame
>
> The functions you mentioned provide that info, or maybe I don't
> understand what info are you looking for.q
Which function tells you what monitor is showing a given frame (on
MS Windows)?
I should maybe point out that the OP reporting this problem is not on
MS Windows, AFAIK. My question about Windows was for me, to see if I
could understand the problem even though I am on Windows (and even
though I do not have multiple monitors).
> > how to specify which monitor to use to display a particular frame.
>
> You can't.
>
> > The symptom reported was that by modifying a frame's parameters
> > to restore its previous values of `top', `left', `width' and
> > `height', the frame got moved to another monitor, for some
> > reason.
>
> Probably because the pixel coordinates mapped to that other monitor,
> the URL above explains that, among other things.
I appreciate your replies and your trying to help, but I don't quite
understand you here. The URL you cite introduces a long chapter.
My Lisp code in question simply does this:
1. If not "maximized" then "maximize", after recording the original
frame location and size, by setting frame parameters `restore-left',...
`restore-height' to the original values of parameters `left',...`height'.
2. If "maximized" then use `modify-frame-parameters' to restore
parameters `left',...`height' to the values saved in parameters
`restore-left',...`restore-height'.
I put "maximized" in quotes here because the code maximizes not wrt
the screen but the screen possibly minus the space used by a standalone
minibuffer frame. But that should be an irrelevant detail.
No doubt the problematic code is somewhere in my function
`maximize-frame', which calculates the position and size for maximizing.
It uses either function `mac-display-available-pixel-bounds', if
available, or functions `x-display-pixel-width' and
`x-display-pixel-height'.
I'm guessing that that is the problem (?) - I do not pass the frame as
an argument to `x-display-pixel-*'. But the doc for those functions
says (since Emacs 20, and still now) that if arg DISPLAY is omitted
then the display of the selected frame is used. So I would think
that it would not be necessary to pass the selected frame as arg.
You say that a monitor is not a display - OK. But I do not see
anything that speaks to which monitor gets used. I am only using
the available display space, as returned by `x-display-pixel-*'.
Dunno what else the problem could be here - i.e., why the newly
repositioned and resized frame would show up on the other monitor.
All the other functions I call here pass the frame explicitly.
In sum, all the code does is either (b) "maximize", by repositioning
and resizing to fit (essentially) what `x-display-pixel-width' and
`x-display-pixel-height' say is the available space or (b) reposition
and resize back to previous `left' etc. settings. Why the frame ends
up being moved to another monitor is a mystery to me.
This is the full function definition:
(defun frcmds-available-screen-pixel-bounds ()
"Returns a value of the same form as option `available-screen-pixel-bounds'.
This represents the currently available screen area."
(or available-screen-pixel-bounds ; Use the option, if available.
(if (fboundp 'mac-display-available-pixel-bounds) ; Mac-OS.
(mac-display-available-pixel-bounds)
(list 0
0
(x-display-pixel-width)
(x-display-pixel-height)))))
You say "Probably because the pixel coordinates mapped to that other
monitor", and that the URL explains this. Could you elaborate, or point
me to the section of that chapter that you have in mind? Do you think
there is something I am not doing that I should be doing, to try to keep
the calculation of the display size to the current monitor?
I understand that on MS Windows the surface of the available monitors
is summed to give the display size. But (a) I don't think the OP is on
Windows and (b) I don't see how that would be a problem anyway. It seems
to be (I'm guessing) that the `left' setting is somehow giving a
coordinate that corresponds to, or is being interpreted as, a coordinate
on the other monitor.
Yes, this is verbose, and no, I don't expect that you have the answer to
my coding problem. If you do have some light to shine on this, however,
then that is appreciated.
next parent reply other threads:[~2014-10-06 16:31 UTC|newest]
Thread overview: 20+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <<b3d0f532-3b29-43d3-a41d-6687886307dc@default>
[not found] ` <<83ppe5mfed.fsf@gnu.org>
2014-10-06 16:31 ` Drew Adams [this message]
2014-10-06 16:54 ` bug#18637: 24.4.50; doc of frame parameter DISPLAY vs actual value on MS Windows Eli Zaretskii
[not found] <<c75b3094-d24b-4949-9c1e-b513c0b5bed7@default>
[not found] ` <<ce89167f-4906-496e-9ace-4d51e1741311@default>
[not found] ` <<83tx3flxn2.fsf@gnu.org>
2014-10-07 18:12 ` Drew Adams
2014-10-07 18:26 ` Eli Zaretskii
[not found] ` <<41484edb-9aaa-4f56-bf46-4ab70b609aac@default>
[not found] ` <<8361fvlos0.fsf@gnu.org>
2014-10-07 18:31 ` Drew Adams
[not found] <<b5ac6ce3-5c0d-4517-a44f-6925cfccdcfd@default>
[not found] ` <<837g0dm95c.fsf@gnu.org>
2014-10-06 17:25 ` Drew Adams
2014-10-05 19:23 ` Drew Adams
2014-10-05 19:30 ` Eli Zaretskii
2014-10-05 19:44 ` Eli Zaretskii
2014-10-06 18:08 ` Andy Moreton
2014-10-06 18:23 ` Drew Adams
2014-10-07 18:35 ` Andy Moreton
2014-10-07 20:25 ` Drew Adams
2014-10-06 19:29 ` Eli Zaretskii
2014-10-06 20:52 ` Drew Adams
2014-10-07 15:14 ` Eli Zaretskii
[not found] <<12fc196e-cc82-4f22-8d2f-cede95542ea7@default>
[not found] ` <<83vbnymi0h.fsf@gnu.org>
[not found] ` <<83tx3imhdg.fsf@gnu.org>
2014-10-06 2:55 ` Drew Adams
2014-10-06 14:39 ` Eli Zaretskii
2014-10-06 16:34 ` Stefan Monnier
2014-10-06 2:55 ` Drew Adams
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
List information: https://www.gnu.org/software/emacs/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=b5ac6ce3-5c0d-4517-a44f-6925cfccdcfd@default \
--to=drew.adams@oracle.com \
--cc=18637@debbugs.gnu.org \
--cc=eliz@gnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).