Bonjour,
J'ai construit une fenêtre où j'ai un composant "gourmand" qui bouffe presque tous les events de la fenêtre.
Les mousewheels fait sur la fenêtre mais hors du composant ne sont pas catchés par la JFrame mais sont par le composant. De même la saisie de caractères dans un JTextField dans lequel je mets le curseur arrivent directement dans ce composant.
Voici le code de création de ce composant "gourmand". Il s'agit de pomper une instance d'OpenOffice et de la mettre dans un composant de type Canvas:
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21 private static class OOCanvas extends Canvas { // this static method rightly belongs in a Utility library... @SuppressWarnings({"deprecation"}) public static long getHWnd(Component f) { ComponentPeer compPeer = f.getPeer(); if (compPeer == null) { return 0; } if (compPeer instanceof WComponentPeer) { return ((WComponentPeer) compPeer).getHWnd(); } // typically we get here if the peer is of class sun.awt.NullComponentPeer // (e.g if the Component is a Swing object - apparently these do not have a "peer") return -1; } public long getHWnd() { return getHWnd(this); } }C'est un code que j'ai trouvé sur cette page: offering integrating OOo GUI and standard Java GUI, et que, honnêtement, je ne maîtrise pas trop.
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36 /** * Initialise le container OpenOffice et le place dans le canvas */ private void initContainer() throws Exception { try { // this is the canvas with the getHWnd() method // some JNI funtions will not work without making it visible... (NB I think this is the case here...) canvas.setVisible(true); // no wrapping necessary, simply use the HWND XSystemChildFactory xFac = (XSystemChildFactory) UnoRuntime.queryInterface(XSystemChildFactory.class, xToolkit); Long nHandle = canvas.getHWnd(); byte[] lIgnoredProcessID = new byte[0]; XWindowPeer xPeer = xFac.createSystemChild((Object) nHandle, lIgnoredProcessID, SystemDependent.SYSTEM_WIN32); xWindow = (XWindow) UnoRuntime.queryInterface(XWindow.class, xPeer); Dimension canvasDim = canvas.getSize(); // canvas turns out to have a size ( 0, 0 ) Container parent = canvas.getParent(); Dimension parentDim = parent.getSize(); // set the new OOo XWindow to the full size of the contentPane xWindow.setPosSize(0, 0, parentDim.width, parentDim.height, PosSize.POSSIZE); // xWindow.setVisible(true); // Object xFrame = xSMGR.createInstance("com.sun.star.frame.Frame"); aFrame = new Frame((XFrame) UnoRuntime.queryInterface(XFrame.class, xFrame)); aFrame.initialize(xWindow); aFrame.setName(aFrame.toString()); // register the frame at the desktop // (NB these lines are necessary to prevent a "could not load bit map" exception...) XFrames xFrames = ((XFramesSupplier) UnoRuntime.queryInterface(XFramesSupplier.class, xDesktop)).getFrames(); xFrames.append(aFrame); } catch (Exception ex) { logger.error("While initializating container", ex); throw ex; } }
Remarque: dans l'ensemble, cette manière de d'intégrer OpenOffice dans java fonctionne vraiment bien, sauf ces problèmes d'events.
Est-ce que vous avez une idée de ce que je pourrais améliorer ?
L'aspect du "vol" des KeyEvents est pour moi le plus gênant et le plus urgent à résoudre.
Partager