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 / panels / SelectFormatPanelView.java @ 44168
History | View | Annotate | Download (4.93 KB)
1 |
package org.gvsig.export.swing.impl.panels; |
---|---|
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 |
import javax.swing.JTextArea; |
18 |
import javax.swing.border.EmptyBorder; |
19 |
|
20 |
|
21 |
public class SelectFormatPanelView extends JPanel |
22 |
{ |
23 |
JList lstServices = new JList(); |
24 |
JTextArea txtDescription = new JTextArea(); |
25 |
JLabel lblEmpty = new JLabel(); |
26 |
|
27 |
/**
|
28 |
* Default constructor
|
29 |
*/
|
30 |
public SelectFormatPanelView()
|
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:DEFAULT:NONE,FILL:DEFAULT:GROW(1.0),FILL:DEFAULT:NONE","CENTER:DEFAULT:NONE,FILL:DEFAULT:GROW(0.8),CENTER:DEFAULT:NONE,FILL:DEFAULT:GROW(0.2),CENTER:DEFAULT:NONE"); |
118 |
CellConstraints cc = new CellConstraints();
|
119 |
jpanel1.setLayout(formlayout1); |
120 |
|
121 |
lstServices.setName("lstServices");
|
122 |
JScrollPane jscrollpane1 = new JScrollPane(); |
123 |
jscrollpane1.setViewportView(lstServices); |
124 |
jscrollpane1.setVerticalScrollBarPolicy(JScrollPane.VERTICAL_SCROLLBAR_AS_NEEDED);
|
125 |
jscrollpane1.setHorizontalScrollBarPolicy(JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);
|
126 |
jpanel1.add(jscrollpane1,cc.xy(2,2)); |
127 |
|
128 |
txtDescription.setEditable(false);
|
129 |
txtDescription.setName("txtDescription");
|
130 |
EmptyBorder emptyborder1 = new EmptyBorder(0,0,0,0); |
131 |
txtDescription.setBorder(emptyborder1); |
132 |
JScrollPane jscrollpane2 = new JScrollPane(); |
133 |
jscrollpane2.setViewportView(txtDescription); |
134 |
jscrollpane2.setVerticalScrollBarPolicy(JScrollPane.VERTICAL_SCROLLBAR_AS_NEEDED);
|
135 |
jscrollpane2.setHorizontalScrollBarPolicy(JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);
|
136 |
jpanel1.add(jscrollpane2,cc.xy(2,4)); |
137 |
|
138 |
lblEmpty.setName("lblEmpty");
|
139 |
jpanel1.add(lblEmpty,cc.xy(2,5)); |
140 |
|
141 |
addFillComponents(jpanel1,new int[]{ 1,2,3 },new int[]{ 1,2,3,4,5 }); |
142 |
return jpanel1;
|
143 |
} |
144 |
|
145 |
/**
|
146 |
* Initializer
|
147 |
*/
|
148 |
protected void initializePanel() |
149 |
{ |
150 |
setLayout(new BorderLayout()); |
151 |
add(createPanel(), BorderLayout.CENTER);
|
152 |
} |
153 |
|
154 |
|
155 |
} |