jdk/src/java.desktop/share/specs/AWT_Native_Interface.html
changeset 45017 7bd7767129ed
equal deleted inserted replaced
45016:77bb38ba0789 45017:7bd7767129ed
       
     1 <!--
       
     2  Copyright (c) 2005, 2017, Oracle and/or its affiliates. All rights reserved.
       
     3  DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
       
     4 
       
     5  This code is free software; you can redistribute it and/or modify it
       
     6  under the terms of the GNU General Public License version 2 only, as
       
     7  published by the Free Software Foundation.
       
     8 
       
     9  This code is distributed in the hope that it will be useful, but WITHOUT
       
    10  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
       
    11  FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
       
    12  version 2 for more details (a copy is included in the LICENSE file that
       
    13  accompanied this code).
       
    14 
       
    15  You should have received a copy of the GNU General Public License version
       
    16  2 along with this work; if not, write to the Free Software Foundation,
       
    17  Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
       
    18 
       
    19  Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
       
    20  or visit www.oracle.com if you need additional information or have any
       
    21  questions.
       
    22 -->
       
    23 <?xml version="1.0" encoding="utf-8"?>
       
    24 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
       
    25     "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
       
    26 <html lang="en-US" xmlns="http://www.w3.org/1999/xhtml" xml:lang=
       
    27 "en-US">
       
    28 <head>
       
    29 <title>Java AWT Native Interface Specification and Guide</title>
       
    30 </head>
       
    31 <body>
       
    32 <h2>The Java AWT Native Interface Specification and Guide</h2>
       
    33 <h3>Introduction</h3>
       
    34 <p>The Java AWT Native Interface (JAWT) comprises a small set of native
       
    35 (eg C language-based) APIs that provide a standard supported way
       
    36 for interaction between Java API windows and surfaces, and
       
    37 platform native API windows and surfaces.
       
    38 Non-Java libraries may then render to a Java owned window.
       
    39 <p>
       
    40 Note: in this document the terms "Java AWT Native Interface",
       
    41 "AWT Native Interface" and "JAWT" are interchangeable and
       
    42 refer to this same specification.
       
    43 <p>
       
    44 The fundamental obstacle to native rendering without JAWT is that
       
    45 is that the rendering code cannot identify where to draw.
       
    46 The native code needs access to information about a Java
       
    47 drawing surface (such as a handle to the underlying native ID of a
       
    48 <tt>Canvas</tt>), but cannot get it.</p>
       
    49 Without that information (ie without JAWT) an application could
       
    50 use native rendering only by creating its own top-level window
       
    51 not shared at all with Java. This is unacceptable for most uses.
       
    52 Except for usage via JAWT, this is considered to be entirely
       
    53 internal to the Java platform implementation: private, unsupported
       
    54 and undocumented.
       
    55 <p>
       
    56 JAWT should be supported in all headful implementations
       
    57 where technically possible although this is not enforced by the JCK.
       
    58 There is a platform-specific and a platform
       
    59 independent portion to the API, to account for the differing
       
    60 data structures and requirements of each platform.
       
    61 This document specifies the platform independent portions and
       
    62 also documents the platform dependent portions for the Oracle JDK
       
    63 supported desktop operating environments.
       
    64 For AWT the term platform is less tied to the underlying operating
       
    65 system than it is to the desktop windowing environment.
       
    66 <p>
       
    67 Reasons for using the AWT Native Interface include
       
    68 <ul>
       
    69 <li>Use of a 3rd party native library not available in Java
       
    70 <li>A temporary porting aid before converting legacy code to Java
       
    71 <li>Rendering performance available only to native hardware accelerated APIs
       
    72 <li>Interoperation with another toolkit
       
    73 </ul>
       
    74 <p>
       
    75 Drawbacks include
       
    76 <ul>
       
    77 <li>A more complex application implementation, eg for painting
       
    78 <li>Potential for application instability if the native library does
       
    79 not interoperate properly with AWT.
       
    80 <li>Increased application delivery complexity - per platform binaries
       
    81 </ul>
       
    82 The header file <a href="#jawt.h"> "jawt.h"</a>
       
    83 in the Appendix fully specifies the APIs provided by JAWT.
       
    84 <p>
       
    85 An example illustrating how easy it is to use the AWT Native Interface
       
    86 is presented and discussed later in this document.</p>
       
    87 
       
    88 <p><b>JAWT usage depends on JNI</b></p>
       
    89 <p>The definition of Java Standard Edition includes JNI, the Java
       
    90 Native Interface. Many Java developers will never need to use it,
       
    91 but the interface is the only standard supported way for a Java
       
    92 language program to interact directly with
       
    93 application code that has been compiled to the native machine
       
    94 instructions for the host processor architecture.
       
    95 JNI is used where ever there is a need for mixed languages.
       
    96 These are by no means limited to cases like AWT. For example, you
       
    97 could use JNI to integrate with native code that communicates with
       
    98 a peripheral device, such as a scanner, connected to a system via a
       
    99 USB port.</p>
       
   100 <p>So JNI is general enough to be used to access almost any
       
   101 sort of native library.
       
   102 The rest of this document assumes a familiarity with how
       
   103 to use JNI.
       
   104 
       
   105 <p><b>How to use JAWT </b></p>
       
   106 <p>In this section we describe the most common usage of the AWT
       
   107 Native Interface &mdash; overriding the <tt>paint</tt> method to
       
   108 direct drawing operations to a native rendering library which then
       
   109 queries the Java VM to determine the information it needs in order
       
   110 to render. Note, however, that any native code may use the AWT
       
   111 Native Interface to learn about a target drawing surface, not just
       
   112 code in a <tt>paint</tt> method.</p>
       
   113 <p>The first step in hooking up a native rendering library to a
       
   114 Java <tt>Canvas</tt> is to define a new class that extends
       
   115 <tt>Canvas</tt> and overrides the <tt>paint</tt> method. The Java
       
   116 system routes all drawing operations for a <tt>Canvas</tt> object
       
   117 through the <tt>paint</tt> method, as it does for all other GUI
       
   118 objects. Canvas is a good candidate for the rendering surface as
       
   119 it does not have any content as a Button would.</p>
       
   120 <p>The new <tt>paint</tt> method, to be implemented in the native
       
   121 rendering library, must be declared as <tt>public native void</tt>
       
   122 , and the native library itself is loaded at runtime by including a
       
   123 call to <tt>System.loadLibrary( &quot;myRenderingLib&quot;)</tt>in
       
   124 the <tt>static</tt> block of the class. The <tt>myRenderingLib</tt>
       
   125 name is used for the native shared library; for Linux or the Solaris
       
   126 operating environment, the actual name for the library file on disk
       
   127 is <tt>libmyRenderingLib.so</tt> .</p>
       
   128 <p>Here is a simple example of such a class:</p>
       
   129 <pre>
       
   130 import java.awt.*;
       
   131 import java.awt.event.*;
       
   132 
       
   133 public class MyCanvas extends Canvas {
       
   134     static {
       
   135         System.loadLibrary("myRenderingLib");
       
   136     }
       
   137     public native void paint(Graphics g);
       
   138 
       
   139     public static void main(String[] args) {
       
   140         Frame f = new Frame();
       
   141         f.setBounds(0, 0, 500, 110);
       
   142         f.add(new MyCanvas());
       
   143         f.addWindowListener( new WindowAdapter() {
       
   144             public void windowClosing(WindowEvent ev) {
       
   145                 System.exit(0);
       
   146             }
       
   147         } );
       
   148         f.show();
       
   149     }
       
   150 }
       
   151 <br />
       
   152 </pre>
       
   153 <p>Note that this class has a <tt>main</tt> method that can be used
       
   154 to run this code as an application for testing purposes.</p>
       
   155 <p>The next step is to run the <tt>javah</tt> tool on the
       
   156 <tt>MyCanvas</tt> class file above to generate a C/C++ header file
       
   157 that describes the interface to the native <tt>paint</tt> method
       
   158 that Java expects to be used. <tt>javah</tt> is a standard tool
       
   159 included with the JDK. NB: <tt>javac -h outputdir</tt> may also be used.</p>
       
   160 
       
   161 <p>The final step &#173; and the most interesting one &#173; is to
       
   162 write the native rendering method, with an interface that conforms
       
   163 to the header file that <tt>javah</tt> generated, and build it as a
       
   164 standard shared library (called <tt>myRenderingLib</tt> in the
       
   165 above example) by linking it, against the appropriate JDK provided
       
   166 $JDK_HOME/lib/$JAWT_LIB library for the target platform.
       
   167 Where JAWT_LIB has the base name "jawt" and follows platform
       
   168 shared object naming rules. i.e.:
       
   169 <ul>
       
   170 <li>Windows: jawt.dll
       
   171 <li>MacOS: libjawt.dylib
       
   172 <li>Linux: libjawt.so
       
   173 <li>Solaris: libjawt.so
       
   174 </ul>
       
   175 
       
   176 This code will call back to the Java virtual machine to
       
   177 get the drawing surface information it needs to access the
       
   178 <tt>MyCanvas</tt> peer. Once this information is available, the
       
   179 code can draw directly to <tt>MyCanvas</tt> using standard drawing
       
   180 routines supplied by the underlying operating system.</p>
       
   181 <p>Here is sample source code for a native <tt>paint</tt> method
       
   182 designed for use in a X11-based drawing environment (Linux
       
   183 or Solaris) and a Java VM where the AWT Native Interface is present:</p>
       
   184 <pre>
       
   185 #include "MyCanvas.h"
       
   186 #include "jawt_md.h"
       
   187 
       
   188 /*
       
   189  * Class:     MyCanvas
       
   190  * Method:    paint
       
   191  * Signature: (Ljava/awt/Graphics;)V
       
   192  */
       
   193 JNIEXPORT void JNICALL Java_MyCanvas_paint
       
   194 (JNIEnv* env, jobject canvas, jobject graphics)
       
   195 {
       
   196     JAWT awt;
       
   197     JAWT_DrawingSurface* ds;
       
   198     JAWT_DrawingSurfaceInfo* dsi;
       
   199     JAWT_X11DrawingSurfaceInfo* dsi_x11;
       
   200     jboolean result;
       
   201     jint lock;
       
   202     GC gc;
       
   203 
       
   204     short       i;
       
   205     char        *testString = "^^^ rendered from native code ^^^";
       
   206 
       
   207     /* Get the AWT */
       
   208     awt.version = JAWT_VERSION_9;
       
   209     if (JAWT_GetAWT(env, &amp;awt) == JNI_FALSE) {
       
   210         printf("AWT Not found\n");
       
   211         return;
       
   212     }
       
   213 
       
   214     /* Get the drawing surface */
       
   215     ds = awt.GetDrawingSurface(env, canvas);
       
   216     if (ds == NULL) {
       
   217         printf("NULL drawing surface\n");
       
   218         return;
       
   219     }
       
   220 
       
   221     /* Lock the drawing surface */
       
   222     lock = ds-&gt;Lock(ds);
       
   223     if((lock &amp; JAWT_LOCK_ERROR) != 0) {
       
   224         printf("Error locking surface\n");
       
   225         awt.FreeDrawingSurface(ds);
       
   226         return;
       
   227     }
       
   228 
       
   229     /* Get the drawing surface info */
       
   230     dsi = ds-&gt;GetDrawingSurfaceInfo(ds);
       
   231     if (dsi == NULL) {
       
   232         printf("Error getting surface info\n");
       
   233         ds-&gt;Unlock(ds);
       
   234         awt.FreeDrawingSurface(ds);
       
   235         return;
       
   236     }
       
   237 
       
   238     /* Get the platform-specific drawing info */
       
   239     dsi_x11 = (JAWT_X11DrawingSurfaceInfo*)dsi-&gt;platformInfo;
       
   240 
       
   241 
       
   242     /* Now paint */
       
   243     gc = XCreateGC(dsi_x11-&gt;display, dsi_x11-&gt;drawable, 0, 0);
       
   244     XSetBackground(dsi_x11-&gt;display, gc, 0);
       
   245     for (i=0; i&lt;36;i++)
       
   246     {
       
   247         XSetForeground(dsi_x11-&gt;display, gc, 10*i);
       
   248         XFillRectangle(dsi_x11-&gt;display, dsi_x11-&gt;drawable, gc,
       
   249                         10*i, 5, 90, 90);
       
   250     }
       
   251     XSetForeground(dsi_x11-&gt;display, gc, 155);
       
   252     XDrawImageString(dsi_x11-&gt;display, dsi_x11-&gt;drawable, gc,
       
   253                         100, 110, testString, strlen(testString));
       
   254     XFreeGC(dsi_x11-&gt;display, gc);
       
   255 
       
   256 
       
   257     /* Free the drawing surface info */
       
   258     ds-&gt;FreeDrawingSurfaceInfo(dsi);
       
   259 
       
   260     /* Unlock the drawing surface */
       
   261     ds-&gt;Unlock(ds);
       
   262 
       
   263     /* Free the drawing surface */
       
   264     awt.FreeDrawingSurface(ds);
       
   265 }
       
   266 </pre>
       
   267 <p>The key data structure here is <tt>JAWT</tt> , which is defined
       
   268 in <tt>jawt.h</tt> (included by <tt>jawt_md.h)</tt> ; it provides
       
   269 access to all the information the native code needs to get the job
       
   270 done. The first part of the native method is boilerplate: it
       
   271 populates the <tt>JAWT</tt> structure, gets a
       
   272 <tt>JAWT_DrawingSurface</tt> structure, locks the surface (only one
       
   273 drawing engine at a time, please!), then gets a
       
   274 <tt>JAWT_DrawingSurfaceInfo</tt> structure that contains a pointer
       
   275 (in the <tt>platformInfo</tt> field) to the necessary
       
   276 platform-specific drawing information. It also includes the
       
   277 bounding rectangle of the drawing surface and the current clipping
       
   278 region.</p>
       
   279 <p>The structure of the information pointed to by
       
   280 <tt>platformInfo</tt> is defined in a machine-dependent header file
       
   281 called <tt>jawt_md.h</tt>. For X11 drawing, it includes
       
   282 information about the X11 display and X11 drawable associated with
       
   283 <tt>MyCanvas</tt>. After the drawing operations are completed,
       
   284 there is more boilerplate code as <tt>JAWT_DrawingSurfaceInfo</tt>
       
   285 is freed and <tt>JAWT_DrawingSurface</tt> is unlocked and
       
   286 freed.</p>
       
   287 <p>The corresponding code for the GDI API on the Microsoft Windows platform would
       
   288 be structured similarly, but would include the version of
       
   289 <tt>jawt_md.h</tt> for Microsoft Windows and the structure located
       
   290 in the <tt>platformInfo</tt> field of drawing surface info would be
       
   291 cast as a <tt>JAWT_Win32DrawingSurfaceInfo*</tt> . And, of course,
       
   292 the actual drawing operations would need to be changed to those
       
   293 appropriate for the Microsoft Windows platform.
       
   294 The same also for MacOS.
       
   295 </p>
       
   296 <p><b>Summary</b></p>
       
   297 <p>The ability to draw directly into a Java <tt>Canvas</tt> from a
       
   298 native code library is extremely useful for developers planning to
       
   299 migrate a legacy software system to Java, especially one that
       
   300 includes a high-performance rendering engine. It makes it much
       
   301 easier to migrate in stages, leaving performance-sensitive
       
   302 rendering code alone, while other less-sensitive portions of code
       
   303 are converted to Java. The result can be a modern Java-centric
       
   304 application, providing the benefit of portability and development
       
   305 efficiency, but one that does not sacrifice an investment in
       
   306 performance of a key piece of native code.</p>
       
   307 <p><b>References</b></p>
       
   308 <p>The definitive reference to the Java Native Interface is <i>The
       
   309 Java Native Interface: Programmer's Guide and Specification</i> by
       
   310 Sheng Liang. This book was published in June
       
   311 1999 by Addison-Wesley. The ISBN is 0-201-32577-2.</p>
       
   312 <p><b>Appendix</b></p>
       
   313 <p><b>Header Files for jawt.h and jawt_md.h</b></p>
       
   314 <a name="jawt.h"></a>
       
   315 <p>jawt.h</p>
       
   316 <pre>
       
   317 #ifndef _JAVASOFT_JAWT_H_
       
   318 #define _JAVASOFT_JAWT_H_
       
   319 
       
   320 #include "jni.h"
       
   321 
       
   322 #ifdef __cplusplus
       
   323 extern "C" {
       
   324 #endif
       
   325 
       
   326 /*
       
   327  * AWT native interface.
       
   328  *
       
   329  * The AWT native interface allows a native C or C++ application a means
       
   330  * by which to access native structures in AWT.  This is to facilitate moving
       
   331  * legacy C and C++ applications to Java and to target the needs of the
       
   332  * developers who need to do their own native rendering to canvases
       
   333  * for performance or other reasons.
       
   334  *
       
   335  * Conversely it also provides mechanisms for an application which already
       
   336  * has a native window to provide that to AWT for AWT rendering.
       
   337  *
       
   338  * Since every platform may be different in its native data structures
       
   339  * and APIs for windowing systems the application must necessarily
       
   340  * provided per-platform source and compile and deliver per-platform
       
   341  * native code  to use this API.
       
   342  *
       
   343  * These interfaces are not part of the Java SE specification and
       
   344  * a VM is not required to implement this API. However it is strongly
       
   345  * recommended that all implementations which support headful AWT
       
   346  * also support these interfaces.
       
   347  *
       
   348  */
       
   349 
       
   350 /*
       
   351  * AWT Native Drawing Surface (JAWT_DrawingSurface).
       
   352  *
       
   353  * For each platform, there is a native drawing surface structure.  This
       
   354  * platform-specific structure can be found in jawt_md.h.  It is recommended
       
   355  * that additional platforms follow the same model.  It is also recommended
       
   356  * that VMs on all platforms support the existing structures in jawt_md.h.
       
   357  *
       
   358  *******************
       
   359  * EXAMPLE OF USAGE:
       
   360  *******************
       
   361  *
       
   362  * On Microsoft Windows, a programmer wishes to access the HWND of a canvas
       
   363  * to perform native rendering into it.  The programmer has declared the
       
   364  * paint() method for their canvas subclass to be native:
       
   365  *
       
   366  *
       
   367  * MyCanvas.java:
       
   368  *
       
   369  * import java.awt.*;
       
   370  *
       
   371  * public class MyCanvas extends Canvas {
       
   372  *
       
   373  *     static {
       
   374  *         System.loadLibrary("mylib");
       
   375  *     }
       
   376  *
       
   377  *     public native void paint(Graphics g);
       
   378  * }
       
   379  *
       
   380  *
       
   381  * myfile.c:
       
   382  *
       
   383  * #include "jawt_md.h"
       
   384  * #include &lt;assert.h&gt;
       
   385  *
       
   386  * JNIEXPORT void JNICALL
       
   387  * Java_MyCanvas_paint(JNIEnv* env, jobject canvas, jobject graphics)
       
   388  * {
       
   389  *     JAWT awt;
       
   390  *     JAWT_DrawingSurface* ds;
       
   391  *     JAWT_DrawingSurfaceInfo* dsi;
       
   392  *     JAWT_Win32DrawingSurfaceInfo* dsi_win;
       
   393  *     jboolean result;
       
   394  *     jint lock;
       
   395  *
       
   396  *     // Get the AWT. Request version 9 to access features in that release.
       
   397  *     awt.version = JAWT_VERSION_9;
       
   398  *     result = JAWT_GetAWT(env, &amp;awt);
       
   399  *     assert(result != JNI_FALSE);
       
   400  *
       
   401  *     // Get the drawing surface
       
   402  *     ds = awt.GetDrawingSurface(env, canvas);
       
   403  *     assert(ds != NULL);
       
   404  *
       
   405  *     // Lock the drawing surface
       
   406  *     lock = ds-&gt;Lock(ds);
       
   407  *     assert((lock &amp; JAWT_LOCK_ERROR) == 0);
       
   408  *
       
   409  *     // Get the drawing surface info
       
   410  *     dsi = ds-&gt;GetDrawingSurfaceInfo(ds);
       
   411  *
       
   412  *     // Get the platform-specific drawing info
       
   413  *     dsi_win = (JAWT_Win32DrawingSurfaceInfo*)dsi-&gt;platformInfo;
       
   414  *
       
   415  *     //////////////////////////////
       
   416  *     // !!! DO PAINTING HERE !!! //
       
   417  *     //////////////////////////////
       
   418  *
       
   419  *     // Free the drawing surface info
       
   420  *     ds-&gt;FreeDrawingSurfaceInfo(dsi);
       
   421  *
       
   422  *     // Unlock the drawing surface
       
   423  *     ds-&gt;Unlock(ds);
       
   424  *
       
   425  *     // Free the drawing surface
       
   426  *     awt.FreeDrawingSurface(ds);
       
   427  * }
       
   428  *
       
   429  */
       
   430 
       
   431 /*
       
   432  * JAWT_Rectangle
       
   433  * Structure for a native rectangle.
       
   434  */
       
   435 typedef struct jawt_Rectangle {
       
   436     jint x;
       
   437     jint y;
       
   438     jint width;
       
   439     jint height;
       
   440 } JAWT_Rectangle;
       
   441 
       
   442 struct jawt_DrawingSurface;
       
   443 
       
   444 /*
       
   445  * JAWT_DrawingSurfaceInfo
       
   446  * Structure for containing the underlying drawing information of a component.
       
   447  */
       
   448 typedef struct jawt_DrawingSurfaceInfo {
       
   449     /*
       
   450      * Pointer to the platform-specific information.  This can be safely
       
   451      * cast to a JAWT_Win32DrawingSurfaceInfo on Microsoft Windows or a
       
   452      * JAWT_X11DrawingSurfaceInfo on Linux and Solaris. On MacOS this is a
       
   453      * pointer to a NSObject that conforms to the JAWT_SurfaceLayers protocol.
       
   454      * See jawt_md.h for details.
       
   455      */
       
   456     void* platformInfo;
       
   457     /* Cached pointer to the underlying drawing surface */
       
   458     struct jawt_DrawingSurface* ds;
       
   459     /* Bounding rectangle of the drawing surface */
       
   460     JAWT_Rectangle bounds;
       
   461     /* Number of rectangles in the clip */
       
   462     jint clipSize;
       
   463     /* Clip rectangle array */
       
   464     JAWT_Rectangle* clip;
       
   465 } JAWT_DrawingSurfaceInfo;
       
   466 
       
   467 #define JAWT_LOCK_ERROR                 0x00000001
       
   468 #define JAWT_LOCK_CLIP_CHANGED          0x00000002
       
   469 #define JAWT_LOCK_BOUNDS_CHANGED        0x00000004
       
   470 #define JAWT_LOCK_SURFACE_CHANGED       0x00000008
       
   471 
       
   472 /*
       
   473  * JAWT_DrawingSurface
       
   474  * Structure for containing the underlying drawing information of a component.
       
   475  * All operations on a JAWT_DrawingSurface MUST be performed from the same
       
   476  * thread as the call to GetDrawingSurface.
       
   477  */
       
   478 typedef struct jawt_DrawingSurface {
       
   479     /* Cached reference to the Java environment of the calling thread.
       
   480      * If Lock(), Unlock(), GetDrawingSurfaceInfo() or
       
   481      * FreeDrawingSurfaceInfo() are called from a different thread,
       
   482      * this data member should be set before calling those functions.
       
   483      */
       
   484     JNIEnv* env;
       
   485     /* Cached reference to the target object */
       
   486     jobject target;
       
   487     /*
       
   488      * Lock the surface of the target component for native rendering.
       
   489      * When finished drawing, the surface must be unlocked with
       
   490      * Unlock().  This function returns a bitmask with one or more of the
       
   491      * following values:
       
   492      *
       
   493      * JAWT_LOCK_ERROR - When an error has occurred and the surface could not
       
   494      * be locked.
       
   495      *
       
   496      * JAWT_LOCK_CLIP_CHANGED - When the clip region has changed.
       
   497      *
       
   498      * JAWT_LOCK_BOUNDS_CHANGED - When the bounds of the surface have changed.
       
   499      *
       
   500      * JAWT_LOCK_SURFACE_CHANGED - When the surface itself has changed
       
   501      */
       
   502     jint (JNICALL *Lock)
       
   503         (struct jawt_DrawingSurface* ds);
       
   504     /*
       
   505      * Get the drawing surface info.
       
   506      * The value returned may be cached, but the values may change if
       
   507      * additional calls to Lock() or Unlock() are made.
       
   508      * Lock() must be called before this can return a valid value.
       
   509      * Returns NULL if an error has occurred.
       
   510      * When finished with the returned value, FreeDrawingSurfaceInfo must be
       
   511      * called.
       
   512      */
       
   513     JAWT_DrawingSurfaceInfo* (JNICALL *GetDrawingSurfaceInfo)
       
   514         (struct jawt_DrawingSurface* ds);
       
   515     /*
       
   516      * Free the drawing surface info.
       
   517      */
       
   518     void (JNICALL *FreeDrawingSurfaceInfo)
       
   519         (JAWT_DrawingSurfaceInfo* dsi);
       
   520     /*
       
   521      * Unlock the drawing surface of the target component for native rendering.
       
   522      */
       
   523     void (JNICALL *Unlock)
       
   524         (struct jawt_DrawingSurface* ds);
       
   525 } JAWT_DrawingSurface;
       
   526 
       
   527 /*
       
   528  * JAWT
       
   529  * Structure for containing native AWT functions.
       
   530  */
       
   531 typedef struct jawt {
       
   532     /*
       
   533      * Version of this structure.  This must always be set before
       
   534      * calling JAWT_GetAWT(). It affects the functions returned.
       
   535      * Must be one of the known pre-defined versions.
       
   536      */
       
   537     jint version;
       
   538     /*
       
   539      * Return a drawing surface from a target jobject.  This value
       
   540      * may be cached.
       
   541      * Returns NULL if an error has occurred.
       
   542      * Target must be a java.awt.Component (should be a Canvas
       
   543      * or Window for native rendering).
       
   544      * FreeDrawingSurface() must be called when finished with the
       
   545      * returned JAWT_DrawingSurface.
       
   546      */
       
   547     JAWT_DrawingSurface* (JNICALL *GetDrawingSurface)
       
   548         (JNIEnv* env, jobject target);
       
   549     /*
       
   550      * Free the drawing surface allocated in GetDrawingSurface.
       
   551      */
       
   552     void (JNICALL *FreeDrawingSurface)
       
   553         (JAWT_DrawingSurface* ds);
       
   554     /*
       
   555      * Since 1.4
       
   556      * Locks the entire AWT for synchronization purposes
       
   557      */
       
   558     void (JNICALL *Lock)(JNIEnv* env);
       
   559     /*
       
   560      * Since 1.4
       
   561      * Unlocks the entire AWT for synchronization purposes
       
   562      */
       
   563     void (JNICALL *Unlock)(JNIEnv* env);
       
   564     /*
       
   565      * Since 1.4
       
   566      * Returns a reference to a java.awt.Component from a native
       
   567      * platform handle.  On Windows, this corresponds to an HWND;
       
   568      * on Solaris and Linux, this is a Drawable.  For other platforms,
       
   569      * see the appropriate machine-dependent header file for a description.
       
   570      * The reference returned by this function is a local
       
   571      * reference that is only valid in this environment.
       
   572      * This function returns a NULL reference if no component could be
       
   573      * found with matching platform information.
       
   574      */
       
   575     jobject (JNICALL *GetComponent)(JNIEnv* env, void* platformInfo);
       
   576 
       
   577     /**
       
   578      * Since 9
       
   579      * Creates a java.awt.Frame placed in a native container. Container is
       
   580      * referenced by the native platform handle. For example on Windows this
       
   581      * corresponds to an HWND. For other platforms, see the appropriate
       
   582      * machine-dependent header file for a description. The reference returned
       
   583      * by this function is a local reference that is only valid in this
       
   584      * environment. This function returns a NULL reference if no frame could be
       
   585      * created with matching platform information.
       
   586      */
       
   587     jobject (JNICALL *CreateEmbeddedFrame) (JNIEnv *env, void* platformInfo);
       
   588 
       
   589     /**
       
   590      * Since 9
       
   591      * Moves and resizes the embedded frame. The new location of the top-left
       
   592      * corner is specified by x and y parameters relative to the native parent
       
   593      * component. The new size is specified by width and height.
       
   594      *
       
   595      * The embedded frame should be created by CreateEmbeddedFrame() method, or
       
   596      * this function will not have any effect.
       
   597      *
       
   598      * java.awt.Component.setLocation() and java.awt.Component.setBounds() for
       
   599      * EmbeddedFrame really don't move it within the native parent. These
       
   600      * methods always locate the embedded frame at (0, 0) for backward
       
   601      * compatibility. To allow moving embedded frames this method was
       
   602      * introduced, and it works just the same way as setLocation() and
       
   603      * setBounds() for usual, non-embedded components.
       
   604      *
       
   605      * Using usual get/setLocation() and get/setBounds() together with this new
       
   606      * method is not recommended.
       
   607      */
       
   608     void (JNICALL *SetBounds) (JNIEnv *env, jobject embeddedFrame,
       
   609             jint x, jint y, jint w, jint h);
       
   610     /**
       
   611      * Since 9
       
   612      * Synthesize a native message to activate or deactivate an EmbeddedFrame
       
   613      * window depending on the value of parameter doActivate, if "true"
       
   614      * activates the window; otherwise, deactivates the window.
       
   615      *
       
   616      * The embedded frame should be created by CreateEmbeddedFrame() method, or
       
   617      * this function will not have any effect.
       
   618      */
       
   619     void (JNICALL *SynthesizeWindowActivation) (JNIEnv *env,
       
   620             jobject embeddedFrame, jboolean doActivate);
       
   621 } JAWT;
       
   622 
       
   623 /*
       
   624  * Get the AWT native structure.  This function returns JNI_FALSE if
       
   625  * an error occurs.
       
   626  */
       
   627 _JNI_IMPORT_OR_EXPORT_
       
   628 jboolean JNICALL JAWT_GetAWT(JNIEnv* env, JAWT* awt);
       
   629 
       
   630 /*
       
   631  * Specify one of these constants as the JAWT.version
       
   632  * Specifying an earlier version will limit the available functions to
       
   633  * those provided in that earlier version of JAWT.
       
   634  * See the "Since" note on each API. Methods with no "Since"
       
   635  * may be presumed to be present in JAWT_VERSION_1_3.
       
   636  */
       
   637 #define JAWT_VERSION_1_3 0x00010003
       
   638 #define JAWT_VERSION_1_4 0x00010004
       
   639 #define JAWT_VERSION_1_7 0x00010007
       
   640 #define JAWT_VERSION_9 0x00090000
       
   641 
       
   642 
       
   643 #ifdef __cplusplus
       
   644 } /* extern "C" */
       
   645 #endif
       
   646 
       
   647 #endif /* !_JAVASOFT_JAWT_H_ */
       
   648 
       
   649 </pre>
       
   650 <p>jawt_md.h (Linux/Solaris/X11 operating environment version)</p>
       
   651 <pre>
       
   652 #ifndef _JAVASOFT_JAWT_MD_H_
       
   653 #define _JAVASOFT_JAWT_MD_H_
       
   654 
       
   655 #include &lt;X11/Xlib.h&gt;
       
   656 #include &lt;X11/Xutil.h&gt;
       
   657 #include &lt;X11/Intrinsic.h&gt;
       
   658 #include "jawt.h"
       
   659 
       
   660 #ifdef __cplusplus
       
   661 extern "C" {
       
   662 #endif
       
   663 
       
   664 /*
       
   665  * X11-specific declarations for AWT native interface.
       
   666  * See notes in jawt.h for an example of use.
       
   667  */
       
   668 typedef struct jawt_X11DrawingSurfaceInfo {
       
   669     Drawable drawable;
       
   670     Display* display;
       
   671     VisualID visualID;
       
   672     Colormap colormapID;
       
   673     int depth;
       
   674 } JAWT_X11DrawingSurfaceInfo;
       
   675 
       
   676 #ifdef __cplusplus
       
   677 }
       
   678 #endif
       
   679 
       
   680 #endif /* !_JAVASOFT_JAWT_MD_H_ */
       
   681 </pre>
       
   682 <p>jawt_md.h (Microsoft Windows version)</p>
       
   683 <pre>
       
   684 #ifndef _JAVASOFT_JAWT_MD_H_
       
   685 #define _JAVASOFT_JAWT_MD_H_
       
   686 
       
   687 #include &lt;windows.h&gt;
       
   688 #include "jawt.h"
       
   689 
       
   690 #ifdef __cplusplus
       
   691 extern "C" {
       
   692 #endif
       
   693 
       
   694 /*
       
   695  * Microsoft Windows specific declarations for AWT native interface.
       
   696  * See notes in jawt.h for an example of use.
       
   697  */
       
   698 typedef struct jawt_Win32DrawingSurfaceInfo {
       
   699     /* Native window, DDB, or DIB handle */
       
   700     union {
       
   701         HWND hwnd;
       
   702         HBITMAP hbitmap;
       
   703         void* pbits;
       
   704     };
       
   705     /*
       
   706      * This HDC should always be used instead of the HDC returned from
       
   707      * BeginPaint() or any calls to GetDC().
       
   708      */
       
   709     HDC hdc;
       
   710     HPALETTE hpalette;
       
   711 } JAWT_Win32DrawingSurfaceInfo;
       
   712 
       
   713 #ifdef __cplusplus
       
   714 }
       
   715 #endif
       
   716 
       
   717 #endif /* !_JAVASOFT_JAWT_MD_H_ */
       
   718 </pre>
       
   719 <p>jawt_md.h (MacOS version)</p>
       
   720 <pre>
       
   721 #ifndef _JAVASOFT_JAWT_MD_H_
       
   722 #define _JAVASOFT_JAWT_MD_H_
       
   723 
       
   724 #include "jawt.h"
       
   725 
       
   726 #ifdef __OBJC__
       
   727 #import <QuartzCore/CALayer.h>
       
   728 #endif
       
   729 
       
   730 #ifdef __cplusplus
       
   731 extern "C" {
       
   732 #endif
       
   733 
       
   734 /*
       
   735  * MacOS specific declarations for AWT native interface.
       
   736  * See notes in jawt.h for an example of use.
       
   737  */
       
   738 
       
   739 /*
       
   740  * When calling JAWT_GetAWT with a JAWT version less than 1.7, you must pass this
       
   741  * flag or you will not be able to get a valid drawing surface and JAWT_GetAWT will
       
   742  * return false. This is to maintain compatibility with applications that used the
       
   743  * interface with Java 6 which had multiple rendering models. This flag is not necessary
       
   744  * when JAWT version 1.7 or greater is used as this is the only supported rendering mode.
       
   745  *
       
   746  * Example:
       
   747  *   JAWT awt;
       
   748  *   awt.version = JAWT_VERSION_1_4 | JAWT_MACOSX_USE_CALAYER;
       
   749  *   jboolean success = JAWT_GetAWT(env, &awt);
       
   750  */
       
   751 #define JAWT_MACOSX_USE_CALAYER 0x80000000
       
   752 
       
   753 /*
       
   754  * When the native Cocoa toolkit is in use, the pointer stored in
       
   755  * JAWT_DrawingSurfaceInfo->platformInfo points to a NSObject that conforms to the
       
   756  * JAWT_SurfaceLayers protocol. Setting the layer property of this object will cause the
       
   757  * specified layer to be overlaid on the Components rectangle. If the window the
       
   758  * Component belongs to has a CALayer attached to it, this layer will be accessible via
       
   759  * the windowLayer property.
       
   760  */
       
   761 #ifdef __OBJC__
       
   762 @protocol JAWT_SurfaceLayers
       
   763 @property (readwrite, retain) CALayer *layer;
       
   764 @property (readonly) CALayer *windowLayer;
       
   765 @end
       
   766 #endif
       
   767 
       
   768 #ifdef __cplusplus
       
   769 }
       
   770 #endif
       
   771 
       
   772 #endif /* !_JAVASOFT_JAWT_MD_H_ */
       
   773 </pre>
       
   774 <!-- Body text ends here -->
       
   775 </body>
       
   776 </html>