Search code examples
macosprocessquartz-graphicswindow-handles

Mac OS X: Can one process render to another process's window?


Greetings!

I'm currently porting a web browser plugin from Win32 to MacOSX. One of the features of the plugin is that when the plugin is loaded, it spawns a separate process that serves as the "engine" of the plugin and executes drawing operations into the window of the plugin (specifically, by attaching an OpenGL context to the parent process's window and executing OpenGL rendering commands into that context). We do this because the plugin is typically loaded as a thread within the browser process, so crashes in the plugin would take down the whole browser. By partitioning the 'heavy lifting' into a separate process and keeping the plugin code very slim, we can protect users against such crashes.

I'd like to preserve this child-process-renderer architecture on MacOSX, but I've heard a nasty rumor (related to the Google Chrome web browser) that MacOSX doesn't allow a process to hand access to its windows to another process. My own search in this space has been inconclusive; if anyone has any knowledge of this problem and could either provide some advice on how to accomplish this goal or a more conclusive "can't be done," it would be extremely helpful.

Thank you for your help!


Solution

  • I was investigating a solution to this almost a year ago. I started a few threads on the apple mailing lists:

    http://www.mail-archive.com/[email protected]/msg08056.html

    http://www.mail-archive.com/[email protected]/msg01878.html

    http://lists.apple.com/archives/mac-opengl/2008/May/msg00099.html

    I had to revert to a solution which used CGWindowListCreateImage which took a screen grab of the opengl process window and convert it to a bitmap for display in the main process window. This is far from effeicient since pixel data is transfered from video ram to system ram.

    I also tried a floating window solution. The opengl process window floated above the main process window and respond to mouse movements from the main window. But I had issues with dragging lag and window z order.

    You would think NSWindowSharingReadWrite would do what you require, but doumentation/examples back then were practically non existent.

    But maybe things have changed in the last year. Keep me posted if you find anything new !

    Good luck

    JC