/************************************************************** * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ package ov; import java.awt.Color; import java.awt.Component; import java.awt.GridBagLayout; import java.awt.GridBagConstraints; import java.awt.Insets; import java.util.Vector; import java.lang.reflect.Method; import java.lang.NoSuchMethodException; import java.lang.IllegalAccessException; import java.lang.reflect.InvocationTargetException; import javax.swing.JPanel; import javax.swing.JTree; import javax.swing.BorderFactory; import javax.swing.border.Border; import javax.swing.border.BevelBorder; import com.sun.star.accessibility.XAccessibleContext; import com.sun.star.accessibility.XAccessibleComponent; import com.sun.star.accessibility.XAccessibleSelection; import com.sun.star.uno.UnoRuntime; public class ObjectViewContainer extends JPanel { public ObjectViewContainer () { maViewTemplates = new Vector (); maViewBorder = BorderFactory.createBevelBorder (BevelBorder.RAISED); setLayout (new GridBagLayout ()); System.out.println ("ObjectViewContainer"); RegisterView (ContextView.class); // RegisterView (StateSetView.class); RegisterView (FocusView.class); RegisterView (TextView.class); } /** Remove all existing views and create new ones according to the interfaces supported by the given object. */ public void SetObject (XAccessibleContext xContext) { // Call Destroy at all views to give them a chance to release their // resources. int n = getComponentCount(); for (int i=0; i= 0) maViewTemplates.setElementAt (aSubstitution, nIndex); } /** Add an object view and place it below all previously added views. @param aView This argument may be null. In this case nothing happens. */ private void Add (ObjectView aView) { if (aView != null) { GridBagConstraints constraints = new GridBagConstraints (); constraints.gridx = 0; constraints.gridy = getComponentCount(); constraints.gridwidth = 1; constraints.gridheight = 1; constraints.weightx = 1; constraints.weighty = 0; constraints.ipadx = 2; constraints.ipady = 5; constraints.insets = new Insets (5,5,5,5); constraints.anchor = GridBagConstraints.NORTH; constraints.fill = GridBagConstraints.HORIZONTAL; aView.setBorder ( BorderFactory.createTitledBorder ( maViewBorder, aView.GetTitle())); add (aView, constraints); } } /** Update the layout manager by setting the vertical weight of the bottom entry to 1 and so make it strech to over the available space. */ private void UpdateLayoutManager () { // Adapt the layout manager. if (getComponentCount() > 0) { Component aComponent = getComponent (getComponentCount()-1); GridBagLayout aLayout = (GridBagLayout)getLayout(); GridBagConstraints aConstraints = aLayout.getConstraints (aComponent); aConstraints.weighty = 1; aLayout.setConstraints (aComponent, aConstraints); } } /// Observe this tree for selection changes and notify them to all /// children. private JTree maTree; private Border maViewBorder; /// List of view templates which are instantiated when new object is set. private Vector maViewTemplates; }