Statistics
| Revision:

svn-gvsig-desktop / trunk / org.gvsig.desktop / org.gvsig.desktop.library / org.gvsig.exportto / org.gvsig.exportto.swing / org.gvsig.exportto.swing.impl / src / main / java / org / gvsig / export / swing / impl / DefaultJExportConfigPanelView.java @ 43925

History | View | Annotate | Download (4.7 KB)

1
package org.gvsig.export.swing.impl;
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.JFrame;
13
import javax.swing.JLabel;
14
import javax.swing.JList;
15
import javax.swing.JPanel;
16
import javax.swing.JScrollPane;
17

    
18

    
19
public class DefaultJExportConfigPanelView extends JPanel
20
{
21
   JLabel lblHeader = new JLabel();
22
   JList lstServiceFactories = new JList();
23
   JLabel lblServiceFactories = new JLabel();
24

    
25
   /**
26
    * Default constructor
27
    */
28
   public DefaultJExportConfigPanelView()
29
   {
30
      initializePanel();
31
   }
32

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

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

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

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

    
73
   }
74

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

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

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

    
119
      lblHeader.setName("lblHeader");
120
      lblHeader.setText("exportto_preferences_panel_description");
121
      jpanel1.add(lblHeader,cc.xy(2,2));
122

    
123
      lstServiceFactories.setName("lstServiceFactories");
124
      JScrollPane jscrollpane1 = new JScrollPane();
125
      jscrollpane1.setViewportView(lstServiceFactories);
126
      jscrollpane1.setVerticalScrollBarPolicy(JScrollPane.VERTICAL_SCROLLBAR_AS_NEEDED);
127
      jscrollpane1.setHorizontalScrollBarPolicy(JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);
128
      jpanel1.add(jscrollpane1,cc.xy(2,6));
129

    
130
      lblServiceFactories.setName("lblServiceFactories");
131
      lblServiceFactories.setText("_Check_the_formats_you_want_to_be_enabled_in_the_export_tool");
132
      jpanel1.add(lblServiceFactories,cc.xy(2,4));
133

    
134
      addFillComponents(jpanel1,new int[]{ 1,2,3 },new int[]{ 1,2,3,4,5,6,7 });
135
      return jpanel1;
136
   }
137

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

    
147

    
148
}