Statistics
| Revision:

gvsig-projects-pool / org.gvsig.winmgr / trunk / org.gvsig.winmgr.app / org.gvsig.winmgr.app.mainplugin / src / main / java / org / gvsig / coreplugin / preferences / general / appearance / AppearancePageView.java @ 682

History | View | Annotate | Download (4.96 KB)

1
package org.gvsig.coreplugin.preferences.general.appearance;
2

    
3
import com.jeta.open.i18n.I18NUtils;
4
import com.jgoodies.forms.layout.CellConstraints;
5
import com.jgoodies.forms.layout.FormLayout;
6
import java.awt.BorderLayout;
7
import java.awt.ComponentOrientation;
8
import java.awt.Container;
9
import java.awt.Dimension;
10
import javax.swing.Box;
11
import javax.swing.ImageIcon;
12
import javax.swing.JCheckBox;
13
import javax.swing.JComboBox;
14
import javax.swing.JFrame;
15
import javax.swing.JLabel;
16
import javax.swing.JPanel;
17
import org.gvsig.andami.preferences.AbstractPreferencePage;
18

    
19

    
20
public abstract class AppearancePageView extends AbstractPreferencePage
21
{
22
   JLabel lbllookAndFeel = new JLabel();
23
   JComboBox cboLookAndFeel = new JComboBox();
24
   JCheckBox chkUseNativeFileChooser = new JCheckBox();
25
   JLabel lblNeedRestart = new JLabel();
26

    
27
   /**
28
    * Default constructor
29
    */
30
   public AppearancePageView()
31
   {
32
      initializePanel();
33
   }
34

    
35
   /**
36
    * Adds fill components to empty cells in the first row and first column of the grid.
37
    * This ensures that the grid spacing will be the same as shown in the designer.
38
    * @param cols an array of column indices in the first row where fill components should be added.
39
    * @param rows an array of row indices in the first column where fill components should be added.
40
    */
41
   void addFillComponents( Container panel, int[] cols, int[] rows )
42
   {
43
      Dimension filler = new Dimension(10,10);
44

    
45
      boolean filled_cell_11 = false;
46
      CellConstraints cc = new CellConstraints();
47
      if ( cols.length > 0 && rows.length > 0 )
48
      {
49
         if ( cols[0] == 1 && rows[0] == 1 )
50
         {
51
            /** add a rigid area  */
52
            panel.add( Box.createRigidArea( filler ), cc.xy(1,1) );
53
            filled_cell_11 = true;
54
         }
55
      }
56

    
57
      for( int index = 0; index < cols.length; index++ )
58
      {
59
         if ( cols[index] == 1 && filled_cell_11 )
60
         {
61
            continue;
62
         }
63
         panel.add( Box.createRigidArea( filler ), cc.xy(cols[index],1) );
64
      }
65

    
66
      for( int index = 0; index < rows.length; index++ )
67
      {
68
         if ( rows[index] == 1 && filled_cell_11 )
69
         {
70
            continue;
71
         }
72
         panel.add( Box.createRigidArea( filler ), cc.xy(1,rows[index]) );
73
      }
74

    
75
   }
76

    
77
   /**
78
    * Helper method to load an image file from the CLASSPATH
79
    * @param imageName the package and name of the file to load relative to the CLASSPATH
80
    * @return an ImageIcon instance with the specified image file
81
    * @throws IllegalArgumentException if the image resource cannot be loaded.
82
    */
83
   public ImageIcon loadImage( String imageName )
84
   {
85
      try
86
      {
87
         ClassLoader classloader = getClass().getClassLoader();
88
         java.net.URL url = classloader.getResource( imageName );
89
         if ( url != null )
90
         {
91
            ImageIcon icon = new ImageIcon( url );
92
            return icon;
93
         }
94
      }
95
      catch( Exception e )
96
      {
97
         e.printStackTrace();
98
      }
99
      throw new IllegalArgumentException( "Unable to load image: " + imageName );
100
   }
101

    
102
   /**
103
    * Method for recalculating the component orientation for 
104
    * right-to-left Locales.
105
    * @param orientation the component orientation to be applied
106
    */
107
   public void applyComponentOrientation( ComponentOrientation orientation )
108
   {
109
      // Not yet implemented...
110
      // I18NUtils.applyComponentOrientation(this, orientation);
111
      super.applyComponentOrientation(orientation);
112
   }
113

    
114
   public JPanel createPanel()
115
   {
116
      JPanel jpanel1 = new JPanel();
117
      FormLayout formlayout1 = new FormLayout("FILL:4DLU:NONE,LEFT:DEFAULT:GROW(1.0),FILL:4DLU:NONE","CENTER:4DLU:NONE,CENTER:DEFAULT:NONE,CENTER:4DLU:NONE,CENTER:DEFAULT:NONE,CENTER:4DLU:NONE,CENTER:DEFAULT:NONE,CENTER:4DLU:NONE,CENTER:DEFAULT:NONE,CENTER:DEFAULT:NONE,CENTER:4DLU:NONE");
118
      CellConstraints cc = new CellConstraints();
119
      jpanel1.setLayout(formlayout1);
120

    
121
      lbllookAndFeel.setName("lbllookAndFeel");
122
      lbllookAndFeel.setText("Usar apariencia");
123
      jpanel1.add(lbllookAndFeel,cc.xy(2,2));
124

    
125
      cboLookAndFeel.setName("cboLookAndFeel");
126
      jpanel1.add(cboLookAndFeel,new CellConstraints(2,4,1,1,CellConstraints.FILL,CellConstraints.DEFAULT));
127

    
128
      chkUseNativeFileChooser.setActionCommand("Usar selector de ficheros nativo");
129
      chkUseNativeFileChooser.setName("chkUseNativeFileChooser");
130
      chkUseNativeFileChooser.setText("Usar selector de ficheros nativo");
131
      jpanel1.add(chkUseNativeFileChooser,cc.xy(2,8));
132

    
133
      lblNeedRestart.setName("lblNeedRestart");
134
      lblNeedRestart.setText("(Debera reiniciar para cambiar la apariencia)");
135
      jpanel1.add(lblNeedRestart,new CellConstraints(2,6,1,1,CellConstraints.RIGHT,CellConstraints.DEFAULT));
136

    
137
      addFillComponents(jpanel1,new int[]{ 1,2,3 },new int[]{ 1,2,3,4,5,6,7,8,9,10 });
138
      return jpanel1;
139
   }
140

    
141
   /**
142
    * Initializer
143
    */
144
   protected void initializePanel()
145
   {
146
      setLayout(new BorderLayout());
147
      add(createPanel(), BorderLayout.CENTER);
148
   }
149

    
150

    
151
}