Re: How to prevent windows to be raised at the top of the stack when clicked?

2013-02-21 Thread Olivier Guillion - Myriad
Hi, Lucas,

Vous avez écrit (you wrote:)

  It's not completely satisfactory,
  because for instance, when tool palettes are clicked they will raise
  above the currently open dialog box.
 
 Not exactly. Depending on the WM settings, a click may well not raise the
 window. The fact is: *you* cannot prevent some windows to be raised above some
 others if the user wants to, but the user may also decide that a click do not
 raise the window.

You are right. I would have said when tool palettes are clicked they *might* 
raise above the currently open dialog box, depending on the WM, its version, 
and a bunch of user's settings. 

In other words, even if I find a way to make it work as I expect, probably 
other WMs or some user settings could ruin my efforts. Uncertainty is the enemy 
of consistency...

  By comparison, this feature 
  is quite straightforward under Windows or MacOS.
 
 Probably right. Those OSes are well known for their I know what you need 
 better
 than you behaviour ;)

Well, in this case it's exactly the other way round. :)

Here, the WM is doing things automatically. It decides that any clicked window 
has to be raised on top (or not), because it thinks that it knows better than 
me (the programmer) how to manage the application window stacking...

Regards,
Olivier
Olivier Guillion
Myriad
26 rue Michel de Montaigne
31200 Toulouse 
FRANCE
  WebSite---
http://www.myriad-online.com
Download here the latest version of our shareware programs, view the online 
tutorials or get info about Myriad and its activities.
-

___
gtk-app-devel-list mailing list
gtk-app-devel-list@gnome.org
https://mail.gnome.org/mailman/listinfo/gtk-app-devel-list

Re: How to prevent windows to be raised at the top of the stack when clicked?

2013-02-19 Thread Olivier Guillion - Myriad
Thank you very much, Sam,

It does make sense indeed.
I almost abandoned the idea of managing completely the stacking order at 
application-level, and tried to find a way to distribute my windows into 
several non-intersecting stacking groups.
By using the gdk_window_set_type_hint() function, I could identify 4 groups, 
from top to bottom of the z-order stack:

- Above any other window (including the windows from the application that 
currently has the focus) : GDK_WINDOW_TYPE_HINT_DOCK

- Below that, GDK_WINDOW_TYPE_HINT_UTILITY or GDK_WINDOW_TYPE_HINT_TOOLBAR or 
GDK_WINDOW_TYPE_HINT_MENU or GDK_WINDOW_TYPE_HINT_DIALOG

- Below that, GDK_WINDOW_TYPE_HINT_NORMAL or GDK_WINDOW_TYPE_HINT_DROPDOWN_MENU 
or GDK_WINDOW_TYPE_HINT_SPLASHSCREEN or GDK_WINDOW_TYPE_HINT_POPUP_MENU or 
GDK_WINDOW_TYPE_HINT_TOOLTIP or GDK_WINDOW_TYPE_HINT_NOTIFICATION or 
GDK_WINDOW_TYPE_HINT_COMBO or GDK_WINDOW_TYPE_HINT_DND

- And at the very bottom, below any other window, even the windows from other 
applications that don't have the focus : GDK_WINDOW_TYPE_HINT_DESKTOP

I presume that, internally, the WM manages these type hints by setting the 
values that are described in the link you provided: 
http://standards.freedesktop.org/wm-spec/wm-spec-latest.html#STACKINGORDER

It's not completely satisfactory, because for instance, when tool palettes are 
clicked they will raise above the currently open dialog box. This drawback 
doesn't seem to be avoidable (e.g. I also noticed it in The Gimp), but it seems 
to be the best result I could expect from this OS. By comparison, this feature 
is quite straightforward under Windows or MacOS.

Thanks !
Olivier


Sam Spilsbury smspil...@gmail.com wrote:

 Hi,
 
 On Thu, Feb 14, 2013 at 12:17 AM, Olivier Guillion - Myriad
 oliv...@myriad-online.com wrote:
  Hi,
 
  I'm struggling with this problem for several days now, and can't find any
  solution.
 
  I'm writing an application for Ubuntu using GTK in C language.
  This application manages various windows (floating palettes, documents,
  toolbars, etc), with a complex stacking (Z-order) strategy.
  I would want to manage the stacking myself, by calling gtk_window_restack
  appropriately.
 
 Warning, here be dragons. Applications don't have full control over
 their stacking order or stacking policy, except if they are override
 redirect and the window manager does not touch them at all.
 
 
  It works well, except for one thing : when a window is clicked, it seems to 
  be
  automatically sent to front (top of the stack) by the system before my 
  program
  receives any signal. For instance, if I put a breakpoint in the
  focus_in_event or button_press_event signal callback, the window has
  already been sent to top before the breakpoint is reached.
 
  Is there a way to prevent a clicked window from being automatically sent to
  top of the stack ? Any help would be greatly appreciated.
 
 
 There isn't really.
 
 You can set _NET_WM_STATE_BELOW to make the window manager put it on
 the same layer as all of the below windows [1]. The window manager
 will still freely raise any window within this layer. Then you can use
 WM_TRANSIENT_FOR in order to force ordering amongst your windows. That
 ordering won't be exclusive though - it is entirely possible that
 other windows can go in-between.
 
 The reason why the window is automatically raised is because the
 window manager has a passive grab on the parent window if its not on
 the top of the stack. This grab activates and prevents your
 application from receiving the first mouse click until the window
 manager has done what its wants to do, namely, place the window at the
 top of the stack. This is part of the reason why people want client
 side decorations.
 
 I'd suggest reconsidering the design of your application. There are
 very good reasons why window managers needs to manage the stacking
 order, allowing applications to override that behaviour generally
 results in trouble.
 
 [1] http://standards.freedesktop.org/wm-spec/wm-spec-latest.html#STACKINGORDER
 
  Thank you,
  Olivier
  ___
  gtk-app-devel-list mailing list
  gtk-app-devel-list@gnome.org
  https://mail.gnome.org/mailman/listinfo/gtk-app-devel-list
 
 
 
 -- 
 Sam Spilsbury
 
 


___
gtk-app-devel-list mailing list
gtk-app-devel-list@gnome.org
https://mail.gnome.org/mailman/listinfo/gtk-app-devel-list


Re: How to prevent windows to be raised at the top of the stack when clicked?

2013-02-18 Thread Olivier Guillion - Myriad
Hi,

I made some more tests about the solutions that seem to be useable. It appears 
that they are not.

Reminder: the problem is to let the application manage window stacking (z-
order), instead of letting the Window manager do most of the job by itself.

- The gtk_windows_set_transient_for() function works but :

. It's not possible to change anything in the window stacking order 
without 
rebuilding the whole list from scratch

. When the list reaches 16 windows and more, this operation takes 
exponentially more and more time. With 20 windows, it takes several seconds. 
With 25, the whole system hangs.

- The gtk_window_restack() function works but :

. When a window is clicked, it seems that the WM automatically send it 
to the 
frontmost position in the stack, without letting the application avoid that.

. I couldn't find any way to prevent that behaviour from the WM by 
altering 
the .XDefault/.XResources file


Could it be possible to bypass GTK and to access the X structures and events 
directly? If yes, is it a way to prevent it to bring automatically the clicked 
window to front ?

Regards,
Olivier
___
gtk-app-devel-list mailing list
gtk-app-devel-list@gnome.org
https://mail.gnome.org/mailman/listinfo/gtk-app-devel-list


Re: How to prevent windows to be raised at the top of the stack when clicked?

2013-02-15 Thread Olivier Guillion - Myriad
Michael Cronenworth m...@cchtml.com wrote:

  Is there a way to prevent a clicked window from being automatically sent to
  top of the stack ? Any help would be greatly appreciated.
 
 You can use gtk_window_set_transient_for() to force stack ordering.

Thanks, Michael,

I already tried it, and it didn't work as expected.

To manage the stacking order properly, each window has to be set transient for 
the window below it in the stack. But changing the order in this transient 
list doesn't work as expected : sometimes windows remain at their previous Z-
order after the call. It seems that  gtk_window_set_transient_for()  is merely 
designed to manage dialog boxes that open over a document window, and not to 
apply changes to existing windows stack ordering.

I'm still trying to go further with this function though. So far, the only 
solution I could find with this function is, when something changes in the 
stack order, to delete the transient info of each and every window, then 
rebuild it entirely.

It seems to work, but it's not straightforward. I'll tell here the results of 
my experiments.

Regards,
Olivier

Olivier Guillion
Myriad
26 rue Michel de Montaigne
31200 Toulouse 
FRANCE
  WebSite---
http://www.myriad-online.com
Download here the latest version of our shareware programs, view the online 
tutorials or get info about Myriad and its activities.
-

___
gtk-app-devel-list mailing list
gtk-app-devel-list@gnome.org
https://mail.gnome.org/mailman/listinfo/gtk-app-devel-list


Re: How to prevent windows to be raised at the top of the stack when clicked?

2013-02-15 Thread Olivier Guillion - Myriad
Thank you, Kurt !

I'm a complete newbie in Linux programming, and I didn't realize that the 
window manager could be configured on an application-basis.
It worth definitely a look.

Thanks again,


Kurt M. Bruhnke wrote :

 Have you tried looking at the settings for your window manager? I know 
 with mwm (yes, I still use it) you can change the button bindings so that, for
 instance, a mouse button down in a window can call f.nop instead of the usual
 f.raise. Depending on how standardized your window manager wants your
 applications to behave, you might be able to fix your problem by reconfiguring
 your window manager. You may even be able to do this on a window class or 
 window
 name basis which would be done in .Xdefaults.
 


Olivier Guillion
Myriad
26 rue Michel de Montaigne
31200 Toulouse 
FRANCE
  WebSite---
http://www.myriad-online.com
Download here the latest version of our shareware programs, view the online 
tutorials or get info about Myriad and its activities.
-

___
gtk-app-devel-list mailing list
gtk-app-devel-list@gnome.org
https://mail.gnome.org/mailman/listinfo/gtk-app-devel-list


How to prevent windows to be raised at the top of the stack when clicked?

2013-02-13 Thread Olivier Guillion - Myriad
Hi,

I'm struggling with this problem for several days now, and can't find any 
solution.

I'm writing an application for Ubuntu using GTK in C language.
This application manages various windows (floating palettes, documents, 
toolbars, etc), with a complex stacking (Z-order) strategy.
I would want to manage the stacking myself, by calling gtk_window_restack 
appropriately.

It works well, except for one thing : when a window is clicked, it seems to be 
automatically sent to front (top of the stack) by the system before my program 
receives any signal.
For instance, if I put a breakpoint in the focus_in_event or 
button_press_event signal callback, the window has already been sent to top 
before the breakpoint is reached.

Is there a way to prevent a clicked window from being automatically sent to top 
of the stack ? 
Any help would be greatly appreciated.

Thank you,
Olivier
___
gtk-app-devel-list mailing list
gtk-app-devel-list@gnome.org
https://mail.gnome.org/mailman/listinfo/gtk-app-devel-list