Revision 60
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/pom.xml | ||
---|---|---|
1 |
<?xml version="1.0" encoding="UTF-8"?> |
|
2 |
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"> |
|
3 |
<modelVersion>4.0.0</modelVersion> |
|
4 |
|
|
5 |
<groupId>org.gvsig</groupId> |
|
6 |
<artifactId>org.gvsig.toolbox</artifactId> |
|
7 |
<packaging>pom</packaging> |
|
8 |
<name>Algorithms</name> |
|
9 |
<version>1.0.3-SNAPSHOT</version> |
|
10 |
|
|
11 |
<parent> |
|
12 |
<groupId>org.gvsig</groupId> |
|
13 |
<artifactId>org.gvsig.desktop</artifactId> |
|
14 |
<version>2.0.25</version> |
|
15 |
</parent> |
|
16 |
|
|
17 |
<scm> |
|
18 |
<connection>scm:svn:https://devel.gvsig.org/svn/gvsig-toolbox/org.gvsig.toolbox/trunk/org.gvsig.toolbox</connection> |
|
19 |
<developerConnection>scm:svn:https://devel.gvsig.org/svn/gvsig-toolbox/org.gvsig.toolbox/trunk/org.gvsig.toolbox</developerConnection> |
|
20 |
<url>https://devel.gvsig.org/redmine/projects/gvsig-toolbox/repository/show/org.gvsig.toolbox/trunk/org.gvsig.toolbox</url> |
|
21 |
</scm> |
|
22 |
|
|
23 |
<repositories> |
|
24 |
<repository> |
|
25 |
<id>gvsig-public-http-repository</id> |
|
26 |
<name>gvSIG maven public HTTP repository</name> |
|
27 |
<url>http://devel.gvsig.org/m2repo/j2se</url> |
|
28 |
<releases> |
|
29 |
<enabled>true</enabled> |
|
30 |
<updatePolicy>daily</updatePolicy> |
|
31 |
<checksumPolicy>warn</checksumPolicy> |
|
32 |
</releases> |
|
33 |
<snapshots> |
|
34 |
<enabled>true</enabled> |
|
35 |
<updatePolicy>daily</updatePolicy> |
|
36 |
<checksumPolicy>warn</checksumPolicy> |
|
37 |
</snapshots> |
|
38 |
</repository> |
|
39 |
</repositories> |
|
40 |
|
|
41 |
<properties> |
|
42 |
<maven.compiler.source>1.6</maven.compiler.source> |
|
43 |
<maven.compiler.target>1.6</maven.compiler.target> |
|
44 |
</properties> |
|
45 |
|
|
46 |
<build> |
|
47 |
|
|
48 |
<pluginManagement> |
|
49 |
<plugins> |
|
50 |
<plugin> |
|
51 |
<groupId>org.codehaus.mojo</groupId> |
|
52 |
<artifactId>animal-sniffer-maven-plugin</artifactId> |
|
53 |
<version>1.7</version> |
|
54 |
</plugin> |
|
55 |
</plugins> |
|
56 |
</pluginManagement> |
|
57 |
|
|
58 |
<sourceDirectory>src</sourceDirectory> |
|
59 |
|
|
60 |
<resources> |
|
61 |
<resource> |
|
62 |
<directory>resources</directory> |
|
63 |
<includes> |
|
64 |
<include>**/*</include> |
|
65 |
</includes> |
|
66 |
</resource> |
|
67 |
</resources> |
|
68 |
|
|
69 |
<plugins> |
|
70 |
<plugin> |
|
71 |
<groupId>org.apache.maven.plugins</groupId> |
|
72 |
<artifactId>maven-compiler-plugin</artifactId> |
|
73 |
<version>2.0.2</version> |
|
74 |
<configuration> |
|
75 |
<source>1.6</source> |
|
76 |
<target>1.6</target> |
|
77 |
<encoding>ISO-8859-1</encoding> |
|
78 |
</configuration> |
|
79 |
</plugin> |
|
80 |
|
|
81 |
<plugin> |
|
82 |
<groupId>org.codehaus.mojo</groupId> |
|
83 |
<artifactId>animal-sniffer-maven-plugin</artifactId> |
|
84 |
<executions> |
|
85 |
<execution> |
|
86 |
<id>check-java-api</id> |
|
87 |
<phase>test</phase> |
|
88 |
<goals> |
|
89 |
<goal>check</goal> |
|
90 |
</goals> |
|
91 |
<configuration> |
|
92 |
<signature> |
|
93 |
<groupId>org.codehaus.mojo.signature |
|
94 |
</groupId> |
|
95 |
<artifactId>java16</artifactId> |
|
96 |
<version>1.0</version> |
|
97 |
</signature> |
|
98 |
</configuration> |
|
99 |
</execution> |
|
100 |
</executions> |
|
101 |
</plugin> |
|
102 |
|
|
103 |
<plugin> |
|
104 |
<groupId>org.apache.maven.plugins</groupId> |
|
105 |
<artifactId>maven-release-plugin</artifactId> |
|
106 |
<configuration> |
|
107 |
<tagBase>https://devel.gvsig.org/svn/gvsig-toolbox/org.gvsig.toolbox/tags/</tagBase> |
|
108 |
<goals>deploy</goals> |
|
109 |
</configuration> |
|
110 |
</plugin> |
|
111 |
|
|
112 |
</plugins> |
|
113 |
</build> |
|
114 |
|
|
115 |
<dependencyManagement> |
|
116 |
<dependencies> |
|
117 |
<dependency> |
|
118 |
<groupId>gishur</groupId> |
|
119 |
<artifactId>gishur_x</artifactId> |
|
120 |
<version>unknown</version> |
|
121 |
</dependency> |
|
122 |
<dependency> |
|
123 |
<groupId>gishur</groupId> |
|
124 |
<artifactId>gishur_core</artifactId> |
|
125 |
<version>unknown</version> |
|
126 |
</dependency> |
|
127 |
<dependency> |
|
128 |
<groupId>com.vividsolutions</groupId> |
|
129 |
<artifactId>jts</artifactId> |
|
130 |
<version>1.13</version> |
|
131 |
</dependency> |
|
132 |
<dependency> |
|
133 |
<groupId>org.gvsig</groupId> |
|
134 |
<artifactId>org.gvsig.toolbox.core</artifactId> |
|
135 |
<version>1.0.3-SNAPSHOT</version> |
|
136 |
</dependency> |
|
137 |
<dependency> |
|
138 |
<groupId>org.gvsig</groupId> |
|
139 |
<artifactId>org.gvsig.toolbox.gui</artifactId> |
|
140 |
<version>1.0.3-SNAPSHOT</version> |
|
141 |
</dependency> |
|
142 |
<dependency> |
|
143 |
<groupId>org.gvsig</groupId> |
|
144 |
<artifactId>org.gvsig.toolbox.math</artifactId> |
|
145 |
<version>1.0.3-SNAPSHOT</version> |
|
146 |
</dependency> |
|
147 |
<dependency> |
|
148 |
<groupId>gnu.trove</groupId> |
|
149 |
<artifactId>trove</artifactId> |
|
150 |
<version>0.1.8</version> |
|
151 |
</dependency> |
|
152 |
<dependency> |
|
153 |
<groupId>org.gvsig.legacy</groupId> |
|
154 |
<artifactId>jama</artifactId> |
|
155 |
<version>1.0.2</version> |
|
156 |
</dependency> |
|
157 |
<dependency> |
|
158 |
<groupId>org.nfunk</groupId> |
|
159 |
<artifactId>jep</artifactId> |
|
160 |
<version>2.4.0</version> |
|
161 |
</dependency> |
|
162 |
<dependency> |
|
163 |
<groupId>commons-codec</groupId> |
|
164 |
<artifactId>commons-codec</artifactId> |
|
165 |
<version>1.8</version> |
|
166 |
</dependency> |
|
167 |
<dependency> |
|
168 |
<groupId>es.unex</groupId> |
|
169 |
<artifactId>sextante_wps</artifactId> |
|
170 |
<version>0.6.0</version> |
|
171 |
</dependency> |
|
172 |
<dependency> |
|
173 |
<groupId>es.unex</groupId> |
|
174 |
<artifactId>libDocEngines</artifactId> |
|
175 |
<version>0.6.0</version> |
|
176 |
</dependency> |
|
177 |
<dependency> |
|
178 |
<groupId>org.beanshell</groupId> |
|
179 |
<artifactId>bsh</artifactId> |
|
180 |
<version>2.0b4</version> |
|
181 |
</dependency> |
|
182 |
<dependency> |
|
183 |
<groupId>org.japura</groupId> |
|
184 |
<artifactId>org.japura</artifactId> |
|
185 |
<version>1.14.0</version> |
|
186 |
</dependency> |
|
187 |
<dependency> |
|
188 |
<groupId>commons-codec</groupId> |
|
189 |
<artifactId>commons-codec</artifactId> |
|
190 |
<version>1.8</version> |
|
191 |
</dependency> |
|
192 |
</dependencies> |
|
193 |
</dependencyManagement> |
|
194 |
|
|
195 |
<modules> |
|
196 |
<module>org.gvsig.toolbox.math</module> |
|
197 |
<module>org.gvsig.toolbox.gui</module> |
|
198 |
<module>org.gvsig.toolbox.core</module> |
|
199 |
<module>org.gvsig.toolbox.algorithm</module> |
|
200 |
</modules> |
|
201 |
</project> |
|
0 | 202 |
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/MANIFEST.MF | ||
---|---|---|
1 |
Manifest-Version: 1.0 |
|
2 |
Ant-Version: Apache Ant 1.7.1 |
|
3 |
Created-By: 20.1-b02 (Sun Microsystems Inc.) |
|
4 |
Implementation-Version: 0.7 |
|
5 |
Built-Date: 2013-03-04 16:06:37 |
|
6 |
|
|
0 | 7 |
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/src/jsh/shell/Utils.java | ||
---|---|---|
1 |
/* |
|
2 |
* 20:25:20 20/05/99 |
|
3 |
* |
|
4 |
* The Java Shell: Utilities. |
|
5 |
* (C)1999 Romain Guy, Osvaldo Pinali Doederlein. |
|
6 |
* |
|
7 |
* LICENSE |
|
8 |
* ======= |
|
9 |
* This program is free software; you can redistribute it and/or |
|
10 |
* modify it under the terms of the GNU General Public License |
|
11 |
* as published by the Free Software Foundation; either version 2 |
|
12 |
* of the License, or any later version. |
|
13 |
* |
|
14 |
* This program is distributed in the hope that it will be useful, |
|
15 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
16 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
17 |
* GNU General Public License for more details. |
|
18 |
* |
|
19 |
* You should have received a copy of the GNU General Public License |
|
20 |
* along with this program; if not, write to the Free Software |
|
21 |
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
|
22 |
* |
|
23 |
* CHANGES |
|
24 |
* ======= |
|
25 |
* 1.0.8 - Filled the listRoots method (Romain & Osvaldo) |
|
26 |
* 1.0.7 - Several bug fixes in constructPath (Romain) |
|
27 |
* 1.0.6 - Split JDK1.1/1.2 (Osvaldo) |
|
28 |
* 1.0.5 - Important bug fix in constructPath(String) (Romain) |
|
29 |
* 1.0.4 - Added getSize(Enumeration) (Osvaldo) |
|
30 |
* 1.0.3 - Changed sortStrings bubble-sort algorithm to (Romain) |
|
31 |
* quick-sort (James Gosling) |
|
32 |
* 1.0.2 - Fixed two little bug in constructPath(String) (Romain) |
|
33 |
* 1.0.1 - Added listFiles(String[], boolean) (Romain) |
|
34 |
* - Removed unecessary createWhiteSpace(int) (Romain) |
|
35 |
* - Modified getWildCardMatches(String, boolean) (Romain) |
|
36 |
* - Slighty improved javadoc comments (Romain) |
|
37 |
* 1.0.0 - Initial release. (Romain & Osvaldo) |
|
38 |
* |
|
39 |
* LINKS |
|
40 |
* ===== |
|
41 |
* Contact: mailto@osvaldo.visionnaire.com.br |
|
42 |
* Site #1: http://www.geocities.com/ResearchTriangle/Node/2005/ |
|
43 |
* Site #2: http://student.vub.ac.be/~opinalid/ |
|
44 |
*/ |
|
45 |
|
|
46 |
package jsh.shell; |
|
47 |
|
|
48 |
import java.io.File; |
|
49 |
import java.util.Enumeration; |
|
50 |
import java.util.Vector; |
|
51 |
|
|
52 |
import es.unex.sextante.gui.core.SextanteGUI; |
|
53 |
|
|
54 |
/** |
|
55 |
* The Java Shell: Utility pack. |
|
56 |
* |
|
57 |
* @author Romain Guy. |
|
58 |
* @author Osvaldo Pinali Doederlein. |
|
59 |
*/ |
|
60 |
|
|
61 |
public class Utils { |
|
62 |
|
|
63 |
/** |
|
64 |
* Removes some elements from a String array. |
|
65 |
* |
|
66 |
* @param arr |
|
67 |
* The array. |
|
68 |
* @param first |
|
69 |
* First element to keep (new 0-index). |
|
70 |
* @param last |
|
71 |
* Last element to keep. |
|
72 |
* @return Copy of arr[first..] |
|
73 |
*/ |
|
74 |
public static String[] subarray(final String[] arr, |
|
75 |
int first, |
|
76 |
final int last) { |
|
77 |
final String[] newArr = new String[last - first + 1]; |
|
78 |
|
|
79 |
for (int i = 0; i < newArr.length; ++i, ++first) { |
|
80 |
newArr[i] = arr[first]; |
|
81 |
} |
|
82 |
|
|
83 |
return newArr; |
|
84 |
} |
|
85 |
|
|
86 |
|
|
87 |
/** |
|
88 |
* Removes some leading elements from a String array. |
|
89 |
* |
|
90 |
* @param arr |
|
91 |
* The array. |
|
92 |
* @param first |
|
93 |
* First element to keep (new 0-index). |
|
94 |
* @return Copy of arr[first..] |
|
95 |
*/ |
|
96 |
public static String[] subarray(final String[] arr, |
|
97 |
final int first) { |
|
98 |
return subarray(arr, first, arr.length - 1); |
|
99 |
} |
|
100 |
|
|
101 |
|
|
102 |
/** |
|
103 |
* Formats a number of bytes for output. |
|
104 |
* |
|
105 |
* @param bytes |
|
106 |
* Number of bytes. |
|
107 |
* @return "xxxxK" form. |
|
108 |
*/ |
|
109 |
public static String fmtBytes(final long bytes) { |
|
110 |
return Long.toString(bytes / 1024) + "K"; |
|
111 |
} |
|
112 |
|
|
113 |
|
|
114 |
/** |
|
115 |
* Formats time for output. |
|
116 |
* |
|
117 |
* @param bytes |
|
118 |
* Number of milliseconds. |
|
119 |
* @return "x,yyys" form. |
|
120 |
*/ |
|
121 |
public static String fmtTime(final long ms) { |
|
122 |
return Float.toString(ms / 1000.0f) + "s"; |
|
123 |
} |
|
124 |
|
|
125 |
|
|
126 |
/** |
|
127 |
* Return a String made of spaces. |
|
128 |
* |
|
129 |
* @param len |
|
130 |
* Number of spaces |
|
131 |
*/ |
|
132 |
public static String getSpaces(final int len) { |
|
133 |
final StringBuffer buf = new StringBuffer(); |
|
134 |
|
|
135 |
for (int i = 0; i < len; i++) { |
|
136 |
buf.append(' '); |
|
137 |
} |
|
138 |
|
|
139 |
return buf.toString(); |
|
140 |
} |
|
141 |
|
|
142 |
|
|
143 |
public static String[] toArray(final Vector strings) { |
|
144 |
final String[] arr = new String[strings.size()]; |
|
145 |
|
|
146 |
for (int i = 0; i < strings.size(); ++i) { |
|
147 |
arr[i] = (String) strings.elementAt(i); |
|
148 |
} |
|
149 |
|
|
150 |
return arr; |
|
151 |
} |
|
152 |
|
|
153 |
|
|
154 |
/** |
|
155 |
* When the user has to specify file names, he can use wildcards (*, ?). This methods handles the usage of these wildcards. |
|
156 |
* |
|
157 |
* @param s |
|
158 |
* Wilcards |
|
159 |
* @param sort |
|
160 |
* Set to true will sort file names |
|
161 |
* @return An array of String which contains all files matching <code>s</code> in current directory. |
|
162 |
* @see Utils#match(String, String) |
|
163 |
*/ |
|
164 |
|
|
165 |
public static String[] getWildCardMatches(final String s, |
|
166 |
final boolean sort) { |
|
167 |
final String args = new String(s.trim()); |
|
168 |
String files[]; |
|
169 |
final Vector filesThatMatchVector = new Vector(); |
|
170 |
String filesThatMatch[]; |
|
171 |
|
|
172 |
files = (new File(getUserDirectory())).list(); |
|
173 |
|
|
174 |
for (int i = 0; i < files.length; i++) { |
|
175 |
if (match(args, files[i])) { |
|
176 |
final File temp = new File(getUserDirectory(), files[i]); |
|
177 |
filesThatMatchVector.addElement(new String(temp.getName())); |
|
178 |
} |
|
179 |
} |
|
180 |
|
|
181 |
filesThatMatch = new String[filesThatMatchVector.size()]; |
|
182 |
filesThatMatchVector.copyInto(filesThatMatch); |
|
183 |
|
|
184 |
if (sort) { |
|
185 |
sortStrings(filesThatMatch); |
|
186 |
} |
|
187 |
|
|
188 |
return filesThatMatch; |
|
189 |
} |
|
190 |
|
|
191 |
|
|
192 |
/** |
|
193 |
* This method can determine if a String matches a pattern of wildcards |
|
194 |
* |
|
195 |
* @param pattern |
|
196 |
* The pattern used for comparison |
|
197 |
* @param string |
|
198 |
* The String to be checked |
|
199 |
* @return true if <code>string</code> matches <code>pattern</code> |
|
200 |
* @see Utils#getWildCardMatches(String) |
|
201 |
*/ |
|
202 |
|
|
203 |
public static boolean match(final String pattern, |
|
204 |
final String string) { |
|
205 |
for (int p = 0;; p++) { |
|
206 |
for (int s = 0;; p++, s++) { |
|
207 |
final boolean sEnd = (s >= string.length()); |
|
208 |
final boolean pEnd = (p >= pattern.length() || pattern.charAt(p) == '|'); |
|
209 |
|
|
210 |
if (sEnd && pEnd) { |
|
211 |
return true; |
|
212 |
} |
|
213 |
if (sEnd || pEnd) { |
|
214 |
break; |
|
215 |
} |
|
216 |
if (pattern.charAt(p) == '?') { |
|
217 |
continue; |
|
218 |
} |
|
219 |
|
|
220 |
if (pattern.charAt(p) == '*') { |
|
221 |
int i; |
|
222 |
p++; |
|
223 |
|
|
224 |
for (i = string.length(); i >= s; --i) { |
|
225 |
if (match(pattern.substring(p), string.substring(i))) { |
|
226 |
return true; |
|
227 |
} |
|
228 |
} |
|
229 |
|
|
230 |
break; |
|
231 |
} |
|
232 |
|
|
233 |
if (pattern.charAt(p) != string.charAt(s)) { |
|
234 |
break; |
|
235 |
} |
|
236 |
} |
|
237 |
|
|
238 |
p = pattern.indexOf('|', p); |
|
239 |
|
|
240 |
if (p == -1) { |
|
241 |
return false; |
|
242 |
} |
|
243 |
} |
|
244 |
} |
|
245 |
|
|
246 |
|
|
247 |
/** |
|
248 |
* Quick sort an array of Strings. |
|
249 |
* |
|
250 |
* @param string |
|
251 |
* Strings to be sorted |
|
252 |
*/ |
|
253 |
|
|
254 |
public static void sortStrings(final String[] strings) { |
|
255 |
sortStrings(strings, 0, strings.length - 1); |
|
256 |
} |
|
257 |
|
|
258 |
|
|
259 |
/** |
|
260 |
* Quick sort an array of Strings. |
|
261 |
* |
|
262 |
* @param a |
|
263 |
* Strings to be sorted |
|
264 |
* @param lo0 |
|
265 |
* Lower bound |
|
266 |
* @param hi0 |
|
267 |
* Higher bound |
|
268 |
*/ |
|
269 |
|
|
270 |
public static void sortStrings(final String a[], |
|
271 |
final int lo0, |
|
272 |
final int hi0) { |
|
273 |
int lo = lo0; |
|
274 |
int hi = hi0; |
|
275 |
String mid; |
|
276 |
|
|
277 |
if (hi0 > lo0) { |
|
278 |
mid = a[(lo0 + hi0) / 2]; |
|
279 |
|
|
280 |
while (lo <= hi) { |
|
281 |
while (lo < hi0 && a[lo].compareTo(mid) < 0) { |
|
282 |
++lo; |
|
283 |
} |
|
284 |
|
|
285 |
while (hi > lo0 && a[hi].compareTo(mid) > 0) { |
|
286 |
--hi; |
|
287 |
} |
|
288 |
|
|
289 |
if (lo <= hi) { |
|
290 |
swap(a, lo, hi); |
|
291 |
++lo; |
|
292 |
--hi; |
|
293 |
} |
|
294 |
} |
|
295 |
|
|
296 |
if (lo0 < hi) { |
|
297 |
sortStrings(a, lo0, hi); |
|
298 |
} |
|
299 |
|
|
300 |
if (lo < hi0) { |
|
301 |
sortStrings(a, lo, hi0); |
|
302 |
} |
|
303 |
} |
|
304 |
} |
|
305 |
|
|
306 |
|
|
307 |
/** |
|
308 |
* Swaps two Strings. |
|
309 |
* |
|
310 |
* @param a |
|
311 |
* The array to be swapped |
|
312 |
* @param i |
|
313 |
* First String index |
|
314 |
* @param j |
|
315 |
* Second String index |
|
316 |
*/ |
|
317 |
|
|
318 |
public static void swap(final String a[], |
|
319 |
final int i, |
|
320 |
final int j) { |
|
321 |
String T; |
|
322 |
T = a[i]; |
|
323 |
a[i] = a[j]; |
|
324 |
a[j] = T; |
|
325 |
} |
|
326 |
|
|
327 |
|
|
328 |
/** |
|
329 |
* Returns the user current directory. |
|
330 |
*/ |
|
331 |
public static String getUserDirectory() { |
|
332 |
|
|
333 |
String folder = SextanteGUI.getOutputFolder(); |
|
334 |
if (folder == null) { |
|
335 |
folder = System.getProperty("user.home"); |
|
336 |
} |
|
337 |
|
|
338 |
return folder; |
|
339 |
|
|
340 |
} |
|
341 |
|
|
342 |
|
|
343 |
/** |
|
344 |
* Sometimes, Strings are too long to be correctly displayed. This method will reduce a String, keeping first and last |
|
345 |
* characters. |
|
346 |
* |
|
347 |
* @param longString |
|
348 |
* The String to be modified |
|
349 |
* @param maxLength |
|
350 |
* The maximum length of the String |
|
351 |
* @return A shorter String |
|
352 |
*/ |
|
353 |
|
|
354 |
public static String getShortStringOf(final String longString, |
|
355 |
final int maxLength) { |
|
356 |
final int len = longString.length(); |
|
357 |
|
|
358 |
if (len < maxLength) { |
|
359 |
return longString; |
|
360 |
} |
|
361 |
else { |
|
362 |
return longString.substring(0, maxLength / 2) + "..." + longString.substring(len - (maxLength / 2)); |
|
363 |
} |
|
364 |
} |
|
365 |
|
|
366 |
|
|
367 |
/** |
|
368 |
* Because a lot of people still use JDK 1.1, we need this method to create an array of Files from an array of String. |
|
369 |
* |
|
370 |
* @param names |
|
371 |
* Names of the files |
|
372 |
* @param construct |
|
373 |
* Set it to true if names does not contain full paths |
|
374 |
* @return An array of Files |
|
375 |
*/ |
|
376 |
public static File[] listFiles(final String[] names, |
|
377 |
final boolean construct) { |
|
378 |
final File[] files = new File[names.length]; |
|
379 |
|
|
380 |
String path = Utils.getUserDirectory(); |
|
381 |
|
|
382 |
if (construct) { |
|
383 |
if (!path.endsWith(File.separator)) { |
|
384 |
path += File.separator; |
|
385 |
} |
|
386 |
} |
|
387 |
|
|
388 |
for (int i = 0; i < files.length; i++) { |
|
389 |
if (construct) { |
|
390 |
files[i] = new File(path + names[i]); |
|
391 |
} |
|
392 |
else { |
|
393 |
files[i] = new File(names[i]); |
|
394 |
} |
|
395 |
} |
|
396 |
|
|
397 |
return files; |
|
398 |
} |
|
399 |
|
|
400 |
|
|
401 |
/** |
|
402 |
* Counts things in an Enumeration (and destroys it as a side effect). |
|
403 |
* |
|
404 |
* @param enum |
|
405 |
* The enumeration, in the start position. |
|
406 |
* @return Elements found. |
|
407 |
*/ |
|
408 |
public static int getSize(final Enumeration enu) { |
|
409 |
int size = 0; |
|
410 |
|
|
411 |
while (enu.hasMoreElements()) { |
|
412 |
++size; |
|
413 |
enu.nextElement(); |
|
414 |
} |
|
415 |
|
|
416 |
return size; |
|
417 |
} |
|
418 |
|
|
419 |
|
|
420 |
/** |
|
421 |
* Constructs a new path from current user path. This is an easy way to get a path if the user specified, for example, |
|
422 |
* "..\Java" as new path. This method will return the argument if this one is a path to a root (i.e, if <code>change</code> |
|
423 |
* is equal to C:\Jdk, constructPath will return C:\Jdk). |
|
424 |
* |
|
425 |
* @param change |
|
426 |
* The modification to apply to the path |
|
427 |
* @see Utils#beginsWithRoot(String), Utils#getRoot(String) |
|
428 |
*/ |
|
429 |
|
|
430 |
public static String constructPath(final String change) { |
|
431 |
if (change == null || beginsWithRoot(change)) { |
|
432 |
return change; |
|
433 |
} |
|
434 |
|
|
435 |
String newPath = getUserDirectory(); |
|
436 |
|
|
437 |
char current; |
|
438 |
char lastChar = '\0'; |
|
439 |
boolean toAdd = false; |
|
440 |
StringBuffer buf = new StringBuffer(change.length()); |
|
441 |
|
|
442 |
for (int i = 0; i < change.length(); i++) { |
|
443 |
switch ((current = change.charAt(i))) { |
|
444 |
case '.': |
|
445 |
if (lastChar == '.') { |
|
446 |
final String parent = (new File(newPath)).getParent(); |
|
447 |
if (parent != null) { |
|
448 |
newPath = parent; |
|
449 |
} |
|
450 |
} |
|
451 |
else if (lastChar != '\0' && lastChar != '\\' && lastChar != '/') { |
|
452 |
buf.append('.'); |
|
453 |
} |
|
454 |
lastChar = '.'; |
|
455 |
break; |
|
456 |
case '\\': |
|
457 |
case '/': |
|
458 |
if (lastChar == '\0') { |
|
459 |
newPath = getRoot(newPath); |
|
460 |
} |
|
461 |
else { |
|
462 |
if (!newPath.endsWith("\\")) { |
|
463 |
newPath += File.separator + buf.toString(); |
|
464 |
} |
|
465 |
else { |
|
466 |
newPath += buf.toString(); |
|
467 |
} |
|
468 |
buf = new StringBuffer(); |
|
469 |
toAdd = false; |
|
470 |
} |
|
471 |
lastChar = '\\'; |
|
472 |
break; |
|
473 |
case '~': |
|
474 |
if (i < change.length() - 1) { |
|
475 |
if (change.charAt(i + 1) == '\\' || change.charAt(i + 1) == '/') { |
|
476 |
newPath = System.getProperties().getProperty("user.home"); |
|
477 |
} |
|
478 |
else { |
|
479 |
buf.append('~'); |
|
480 |
} |
|
481 |
} |
|
482 |
else if (i == 0) { |
|
483 |
newPath = System.getProperties().getProperty("user.home"); |
|
484 |
} |
|
485 |
else { |
|
486 |
buf.append('~'); |
|
487 |
} |
|
488 |
lastChar = '~'; |
|
489 |
break; |
|
490 |
default: |
|
491 |
lastChar = current; |
|
492 |
buf.append(current); |
|
493 |
toAdd = true; |
|
494 |
break; |
|
495 |
} |
|
496 |
} |
|
497 |
|
|
498 |
if (toAdd) { |
|
499 |
if (!newPath.endsWith(File.separator)) { |
|
500 |
newPath += File.separator + buf.toString(); |
|
501 |
} |
|
502 |
else { |
|
503 |
newPath += buf.toString(); |
|
504 |
} |
|
505 |
} |
|
506 |
|
|
507 |
return newPath; |
|
508 |
} |
|
509 |
|
|
510 |
|
|
511 |
/** |
|
512 |
* It can be necessary to determine which is the root of a path. For example, the root of D:\Projects\Java is D:\. |
|
513 |
* |
|
514 |
* @param path |
|
515 |
* The path used to get a root |
|
516 |
* @return The root which contais the specified path |
|
517 |
*/ |
|
518 |
|
|
519 |
public static String getRoot(final String path) { |
|
520 |
final File roots[] = listRoots(new File(path)); |
|
521 |
|
|
522 |
for (int i = 0; i < roots.length; i++) { |
|
523 |
if (path.startsWith(roots[i].getPath())) { |
|
524 |
return roots[i].getPath(); |
|
525 |
} |
|
526 |
} |
|
527 |
|
|
528 |
return path; |
|
529 |
} |
|
530 |
|
|
531 |
|
|
532 |
/** |
|
533 |
* It can be necessary to determine if a path begins with a root. |
|
534 |
* |
|
535 |
* @param path |
|
536 |
* The path to check |
|
537 |
* @return True if path begins with a root, false otherwise |
|
538 |
*/ |
|
539 |
|
|
540 |
public static boolean beginsWithRoot(final String path) { |
|
541 |
final File roots[] = listRoots(new File(path)); |
|
542 |
|
|
543 |
for (int i = 0; i < roots.length; i++) { |
|
544 |
if (path.regionMatches(true, 0, roots[i].getPath(), 0, roots[i].getPath().length())) { |
|
545 |
return true; |
|
546 |
} |
|
547 |
} |
|
548 |
|
|
549 |
return false; |
|
550 |
} |
|
551 |
|
|
552 |
|
|
553 |
/** |
|
554 |
* We override a Java2 specific method. |
|
555 |
* |
|
556 |
* @param f |
|
557 |
* A File |
|
558 |
* @return A list of standards roots |
|
559 |
*/ |
|
560 |
|
|
561 |
public static File[] listRoots(final File f) { |
|
562 |
if (System.getProperty("os.name").startsWith("Windows")) { |
|
563 |
return new File[] { new File("A:\\"), new File("B:\\"), new File("C:\\"), new File("D:\\"), new File("E:\\"), |
|
564 |
new File("F:\\"), new File("G:\\"), new File("H:\\"), new File("I:\\") }; |
|
565 |
//return new File[]{new File(System.getProperty("java.home").substring(0, 3))}; |
|
566 |
} |
|
567 |
else { |
|
568 |
return new File[] { new File("/") }; |
|
569 |
} |
|
570 |
} |
|
571 |
|
|
572 |
|
|
573 |
/** |
|
574 |
* We override a Java2 spcific method. |
|
575 |
* |
|
576 |
* @param file |
|
577 |
* Determine if this file is hidden or not |
|
578 |
* @return Always false |
|
579 |
*/ |
|
580 |
|
|
581 |
public boolean isHidden(final File file) { |
|
582 |
return false; |
|
583 |
} |
|
584 |
|
|
585 |
} |
|
586 |
|
|
587 |
// End of Utils.java |
|
0 | 588 |
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/src/es/unex/sextante/gui/core/RenderingData.java | ||
---|---|---|
1 |
|
|
2 |
|
|
3 |
package es.unex.sextante.gui.core; |
|
4 |
|
|
5 |
public class RenderingData { |
|
6 |
|
|
7 |
public String algName; |
|
8 |
public String outputName; |
|
9 |
public Object rendering; |
|
10 |
|
|
11 |
} |
|
0 | 12 |
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/src/es/unex/sextante/gui/core/GenericInfoDialog.java | ||
---|---|---|
1 |
package es.unex.sextante.gui.core; |
|
2 |
|
|
3 |
import java.awt.BorderLayout; |
|
4 |
import java.awt.Component; |
|
5 |
import java.awt.Frame; |
|
6 |
|
|
7 |
import javax.swing.JDialog; |
|
8 |
import javax.swing.JPanel; |
|
9 |
|
|
10 |
/** |
|
11 |
* A simple dialog to show a java component |
|
12 |
* |
|
13 |
* @author volaya |
|
14 |
* |
|
15 |
*/ |
|
16 |
public class GenericInfoDialog |
|
17 |
extends |
|
18 |
JDialog { |
|
19 |
|
|
20 |
/** |
|
21 |
* constructor |
|
22 |
* |
|
23 |
* @param component |
|
24 |
* the component to show in the dialog |
|
25 |
* @param sTitle |
|
26 |
* the title of the dialog |
|
27 |
* @param parent |
|
28 |
* the parent frame |
|
29 |
*/ |
|
30 |
public GenericInfoDialog(final Component component, |
|
31 |
final String sTitle, |
|
32 |
final Frame parent) { |
|
33 |
|
|
34 |
super(parent, sTitle, true); |
|
35 |
|
|
36 |
initGUI(component); |
|
37 |
|
|
38 |
pack(); |
|
39 |
setLocationRelativeTo(null); |
|
40 |
|
|
41 |
} |
|
42 |
|
|
43 |
|
|
44 |
protected void initGUI(final Component component) { |
|
45 |
|
|
46 |
setPreferredSize(component.getPreferredSize()); |
|
47 |
setSize(component.getPreferredSize()); |
|
48 |
final BorderLayout thisLayout = new BorderLayout(); |
|
49 |
final JPanel pane = new JPanel(); |
|
50 |
pane.setLayout(thisLayout); |
|
51 |
setContentPane(pane); |
|
52 |
pane.add(component, BorderLayout.CENTER); |
|
53 |
|
|
54 |
} |
|
55 |
|
|
56 |
|
|
57 |
} |
|
0 | 58 |
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/src/es/unex/sextante/gui/core/IPostProcessTaskFactory.java | ||
---|---|---|
1 |
package es.unex.sextante.gui.core; |
|
2 |
|
|
3 |
import es.unex.sextante.core.GeoAlgorithm; |
|
4 |
import es.unex.sextante.gui.additionalResults.AdditionalResults; |
|
5 |
|
|
6 |
/** |
|
7 |
* Interface to be implemented by post process factories. A post process factory is used to define the task that should be |
|
8 |
* performed with algorithm results, once a SEXTANTE geoalgorithm has been executed from the SEXTANTE GUI |
|
9 |
* |
|
10 |
* @author volaya |
|
11 |
* |
|
12 |
*/ |
|
13 |
public interface IPostProcessTaskFactory { |
|
14 |
|
|
15 |
/** |
|
16 |
* Returns a task to post-process the given algorithm. This task should take the outputs generated by the algorithm, adding |
|
17 |
* them to the GUI or doing with them whatever is needed. |
|
18 |
* |
|
19 |
* To be compatible with the {@link AdditionalResults} class, charts and text result has to be added as java Components. Check |
|
20 |
* the documentation of that class for more information. |
|
21 |
* |
|
22 |
* @param alg |
|
23 |
* the algorithm to post-process |
|
24 |
* @param bShowResultsDialog |
|
25 |
* if this parameter is true, the task will show the results dialog if the algorithm has produced some kind of |
|
26 |
* output other than layers or tables. If it is false, those results will be added to the set of current |
|
27 |
* results, but the results dialog will not be shown |
|
28 |
* @return a task to post-process the given algorithm |
|
29 |
*/ |
|
30 |
public Runnable getPostProcessTask(GeoAlgorithm alg, |
|
31 |
boolean bShowResultsDialog); |
|
32 |
|
|
33 |
|
|
34 |
} |
|
0 | 35 |
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/src/es/unex/sextante/gui/core/IDataRenderer.java | ||
---|---|---|
1 |
|
|
2 |
|
|
3 |
package es.unex.sextante.gui.core; |
|
4 |
|
|
5 |
import java.util.HashMap; |
|
6 |
|
|
7 |
import es.unex.sextante.dataObjects.ILayer; |
|
8 |
|
|
9 |
|
|
10 |
/** |
|
11 |
* A class containing information needed to set rendering styles for layers generated by SEXTANTE geoalgorithms |
|
12 |
* |
|
13 |
* @author volaya |
|
14 |
* |
|
15 |
*/ |
|
16 |
public interface IDataRenderer { |
|
17 |
|
|
18 |
public Object getRenderingForLayer(String sAlgCmdName, |
|
19 |
String sOutputName); |
|
20 |
|
|
21 |
|
|
22 |
public void setRenderingForAlgorithm(String sAlgCmdName, |
|
23 |
HashMap<String, Object> renderer); |
|
24 |
|
|
25 |
|
|
26 |
public void save(); |
|
27 |
|
|
28 |
|
|
29 |
public void open(); |
|
30 |
|
|
31 |
|
|
32 |
public Object getRenderingDataFromLayer(ILayer layer); |
|
33 |
|
|
34 |
} |
|
0 | 35 |
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/src/es/unex/sextante/gui/core/IAlgorithmProvider.java | ||
---|---|---|
1 |
package es.unex.sextante.gui.core; |
|
2 |
|
|
3 |
import java.util.ArrayList; |
|
4 |
import java.util.HashMap; |
|
5 |
|
|
6 |
import javax.swing.ImageIcon; |
|
7 |
|
|
8 |
import es.unex.sextante.core.GeoAlgorithm; |
|
9 |
import es.unex.sextante.gui.settings.Setting; |
|
10 |
|
|
11 |
public interface IAlgorithmProvider { |
|
12 |
|
|
13 |
/** |
|
14 |
* Performs the initialization needed to load the corresponding algorithm into the algorithm provider |
|
15 |
*/ |
|
16 |
public void initialize(); |
|
17 |
|
|
18 |
|
|
19 |
/** |
|
20 |
* Returns the name of the algorithm provider. This will be used as the group name in the toolbox |
|
21 |
* |
|
22 |
* @return |
|
23 |
*/ |
|
24 |
public String getName(); |
|
25 |
|
|
26 |
|
|
27 |
/** |
|
28 |
* Returns a map with algorithm command-line names as keys and geoalgorithms as values |
|
29 |
* |
|
30 |
* @return a map with algorithm command-line names as keys and geoalgorithms as values |
|
31 |
*/ |
|
32 |
public HashMap<String, GeoAlgorithm> getAlgorithms(); |
|
33 |
|
|
34 |
|
|
35 |
/** |
|
36 |
* Returns a map of custom parameter panels. Keys are algorithm command-line names, and values are the corresponding panel |
|
37 |
* classes |
|
38 |
* |
|
39 |
* @return a map of custom parameter panels. |
|
40 |
*/ |
|
41 |
public HashMap<String, Class> getCustomModelerParameterPanels(); |
|
42 |
|
|
43 |
|
|
44 |
/** |
|
45 |
* Returns a map of custom modeler parameter panels. Keys are algorithm command-line names, and values are the corresponding |
|
46 |
* panel classes |
|
47 |
* |
|
48 |
* @return a map of custom modeler parameter panels. |
|
49 |
*/ |
|
50 |
public HashMap<String, Class> getCustomParameterPanels(); |
|
51 |
|
|
52 |
|
|
53 |
/** |
|
54 |
* Returns the icon to use for the algorithms provided by this provider |
|
55 |
* |
|
56 |
* @return the icon to use for the algorithms provided by this provider |
|
57 |
*/ |
|
58 |
public ImageIcon getIcon(); |
|
59 |
|
|
60 |
|
|
61 |
/** |
|
62 |
* Returns the settings object corresponding to this provider |
|
63 |
* |
|
64 |
* @return the settings object corresponding to this provider |
|
65 |
*/ |
|
66 |
public Setting getSettings(); |
|
67 |
|
|
68 |
|
|
69 |
/** |
|
70 |
* Updates the list of algorithms in this provider |
|
71 |
*/ |
|
72 |
public void update(); |
|
73 |
|
|
74 |
|
|
75 |
/** |
|
76 |
* |
|
77 |
* Returns the help associated with the passed algorithm as a HTML string or a URL |
|
78 |
* |
|
79 |
* @param alg |
|
80 |
* the algorithm |
|
81 |
* @return the help associated with the passed algorithm as a HTML string or a URL |
|
82 |
*/ |
|
83 |
public Object getAlgorithmHelp(GeoAlgorithm alg); |
|
84 |
|
|
85 |
|
|
86 |
/** |
|
87 |
* Returns the filename where the help for a given algorithm is stored |
|
88 |
* |
|
89 |
* @param alg |
|
90 |
* the algorithm |
|
91 |
* @param bForceCurrentLocale |
|
92 |
* if true it will return the current locale folder, even if the help file does not exists |
|
93 |
* @return |
|
94 |
*/ |
|
95 |
public String getAlgorithmHelpFilename(GeoAlgorithm alg, |
|
96 |
boolean bForceCurrentLocale); |
|
97 |
|
|
98 |
|
|
99 |
/** |
|
100 |
* Returns true if the help files associated with the algorithms from this provider can be edited by the user |
|
101 |
* |
|
102 |
* @return true if the help files associated with the algorithms from this provider can be edited by the user |
|
103 |
*/ |
|
104 |
public boolean canEditHelp(); |
|
105 |
|
|
106 |
|
|
107 |
/** |
|
108 |
* Returns the toolbox actions to be added to the toolbox by this algorithm provider. |
|
109 |
* |
|
110 |
* @return A Map containing toolbox actions to be added to the toolbox by this algorithm provider |
|
111 |
*/ |
|
112 |
public HashMap<NameAndIcon, ArrayList<ToolboxAction>> getToolboxActions(); |
|
113 |
|
|
114 |
|
|
115 |
/** |
|
116 |
* Return the right button actions to be added to the toolbox by this algorithm provider. These actions should work on the |
|
117 |
* particular type of algorithms provided by the provider |
|
118 |
* |
|
119 |
* @return the right button actions to be added to the toolbox by this algorithm provider. |
|
120 |
*/ |
|
121 |
public IToolboxRightButtonAction[] getToolboxRightButtonActions(); |
|
122 |
|
|
123 |
|
|
124 |
} |
|
0 | 125 |
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/src/es/unex/sextante/gui/core/ProgressMonitor.java | ||
---|---|---|
1 |
package es.unex.sextante.gui.core; |
|
2 |
|
|
3 |
import info.clearthought.layout.TableLayout; |
|
4 |
import info.clearthought.layout.TableLayoutConstants; |
|
5 |
|
|
6 |
import java.awt.Dimension; |
|
7 |
import java.awt.event.ActionEvent; |
|
8 |
import java.awt.event.ActionListener; |
|
9 |
|
|
10 |
import javax.swing.JButton; |
|
11 |
import javax.swing.JDialog; |
|
12 |
import javax.swing.JLabel; |
|
13 |
import javax.swing.JProgressBar; |
|
14 |
import javax.swing.SwingUtilities; |
|
15 |
import javax.swing.WindowConstants; |
|
16 |
|
|
17 |
import es.unex.sextante.core.Sextante; |
|
18 |
import es.unex.sextante.gui.grass.GrassUtils; |
|
19 |
|
|
20 |
/** |
|
21 |
* A progress monitor showing a progress bar and a cancel button |
|
22 |
* |
|
23 |
* @author volaya |
|
24 |
* |
|
25 |
*/ |
|
26 |
public class ProgressMonitor |
|
27 |
extends |
|
28 |
JDialog { |
|
29 |
|
|
30 |
private JLabel jTitle; |
|
31 |
private JButton jButtonCancel; |
|
32 |
private JProgressBar jProgressBar; |
|
33 |
private JLabel jProgressText; |
|
34 |
private boolean m_bCanceled; |
|
35 |
private String m_sPrefix = ""; |
|
36 |
private String m_sDescription = ""; |
|
37 |
|
|
38 |
|
|
39 |
/** |
|
40 |
* Constructor |
|
41 |
* |
|
42 |
* @param sText |
|
43 |
* The title text to show |
|
44 |
* @param bDeterminate |
|
45 |
* true if the process to monitor is determinate |
|
46 |
* @param parent |
|
47 |
* the parent dialog |
|
48 |
*/ |
|
49 |
public ProgressMonitor(final String sText, |
|
50 |
final boolean bDeterminate, |
|
51 |
final JDialog parent) { |
|
52 |
|
|
53 |
super(parent, "", false); |
|
54 |
|
|
55 |
setDefaultCloseOperation(WindowConstants.DO_NOTHING_ON_CLOSE); |
|
56 |
setLocationRelativeTo(null); |
|
57 |
|
|
58 |
m_bCanceled = false; |
|
59 |
m_sDescription = sText; |
|
60 |
|
|
61 |
initGUI(bDeterminate); |
|
62 |
|
|
63 |
} |
|
64 |
|
|
65 |
|
|
66 |
/** |
|
67 |
* Constructor. Uses the main frame as the parent component |
|
68 |
* |
|
69 |
* @param sText |
|
70 |
* The title text to show |
|
71 |
* @param bDeterminate |
|
72 |
* true if the process to monitor is determinate |
|
73 |
*/ |
|
74 |
public ProgressMonitor(final String sText, |
|
75 |
final boolean bDeterminate) { |
|
76 |
|
|
77 |
super(SextanteGUI.getMainFrame(), "", false); |
|
78 |
|
|
79 |
setDefaultCloseOperation(WindowConstants.DO_NOTHING_ON_CLOSE); |
|
80 |
setLocationRelativeTo(null); |
|
81 |
|
|
82 |
m_bCanceled = false; |
|
83 |
m_sDescription = sText; |
|
84 |
|
|
85 |
initGUI(bDeterminate); |
|
86 |
|
|
87 |
} |
|
88 |
|
|
89 |
|
|
90 |
private void initGUI(boolean bDeterminate) { |
|
91 |
|
|
92 |
final TableLayout thisLayout = new TableLayout(new double[][] { |
|
93 |
{ 6.0, TableLayoutConstants.FILL, TableLayoutConstants.FILL, 6.0 }, |
|
94 |
{ 1.0, TableLayoutConstants.FILL, TableLayoutConstants.FILL, 1, 15.0, 1.0, 25.0, 1.0 } }); |
|
95 |
thisLayout.setHGap(5); |
|
96 |
thisLayout.setVGap(5); |
|
97 |
setPreferredSize(new Dimension(350, 150)); |
|
98 |
setSize(new Dimension(350, 150)); |
|
99 |
getContentPane().setLayout(thisLayout); |
|
100 |
{ |
|
101 |
jTitle = new JLabel(m_sDescription); |
|
102 |
getContentPane().add(jTitle, "1, 1, 2, 1"); |
|
103 |
} |
|
104 |
{ |
|
105 |
jButtonCancel = new JButton(); |
|
106 |
getContentPane().add(jButtonCancel, "2, 6"); |
|
107 |
jButtonCancel.setText(Sextante.getText("Cancel")); |
|
108 |
jButtonCancel.addActionListener(new ActionListener() { |
|
109 |
public void actionPerformed(final ActionEvent evt) { |
|
110 |
cancel(); |
|
111 |
} |
|
112 |
}); |
|
113 |
} |
|
114 |
{ |
|
115 |
jProgressBar = new JProgressBar(); |
|
116 |
jProgressBar.setIndeterminate(!bDeterminate); |
|
117 |
if (bDeterminate) { |
|
118 |
jProgressBar.setMinimum(0); |
|
119 |
jProgressBar.setMaximum(100); |
|
120 |
jProgressBar.setValue(0); |
|
121 |
} |
|
122 |
getContentPane().add(jProgressBar, "1, 4, 2, 4"); |
|
123 |
} |
|
124 |
{ |
|
125 |
jProgressText = new JLabel(); |
|
126 |
getContentPane().add(jProgressText, "1, 2"); |
|
127 |
} |
|
128 |
|
|
129 |
} |
|
130 |
|
|
131 |
|
|
132 |
private void cancel() { |
|
133 |
|
|
134 |
//If this is a running GRASS process: kill it |
|
135 |
GrassUtils.cancelProcess(); |
|
136 |
|
|
137 |
m_bCanceled = true; |
|
138 |
|
|
139 |
} |
|
140 |
|
|
141 |
|
|
142 |
/** |
|
143 |
* Returns true if the process has been canceled using the cancel button |
|
144 |
* |
|
145 |
* @return true if the process has been canceled |
|
146 |
*/ |
|
147 |
public boolean isCanceled() { |
|
148 |
|
|
149 |
return m_bCanceled; |
|
150 |
|
|
151 |
} |
|
152 |
|
|
153 |
|
|
154 |
/** |
|
155 |
* Sets the text describing the current phase of the process being monitored |
|
156 |
* |
|
157 |
* @param sText |
|
158 |
* the description |
|
159 |
*/ |
|
160 |
public void setProgressText(final String sText) { |
|
161 |
|
|
162 |
try { |
|
163 |
final Runnable runnable = new Runnable() { |
|
164 |
public void run() { |
|
165 |
jProgressText.setText(sText); |
|
166 |
} |
|
167 |
}; |
|
168 |
if (SwingUtilities.isEventDispatchThread()) { |
|
169 |
runnable.run(); |
|
170 |
} |
|
171 |
else { |
|
172 |
SwingUtilities.invokeAndWait(runnable); |
|
173 |
} |
|
174 |
} |
|
175 |
catch (final Exception e) {} |
|
176 |
|
|
177 |
|
|
178 |
} |
|
179 |
|
|
180 |
|
|
181 |
/** |
|
182 |
* Sets the description to show at the top of the progress monitor |
|
183 |
* |
|
184 |
* @param sDescription |
|
185 |
* the description |
|
186 |
*/ |
|
187 |
public void setDescription(final String sDescription) { |
|
188 |
|
|
189 |
m_sDescription = sDescription; |
|
190 |
updateTitle(); |
|
191 |
|
|
192 |
} |
|
193 |
|
|
194 |
|
|
195 |
private void updateTitle() { |
|
196 |
|
|
197 |
try { |
|
198 |
|
|
199 |
final Runnable runnable = new Runnable() { |
|
200 |
public void run() { |
|
201 |
jTitle.setText(m_sPrefix + m_sDescription); |
|
202 |
} |
|
203 |
}; |
|
204 |
if (SwingUtilities.isEventDispatchThread()) { |
|
205 |
runnable.run(); |
|
206 |
} |
|
207 |
else { |
|
208 |
SwingUtilities.invokeAndWait(runnable); |
|
209 |
} |
|
210 |
} |
|
211 |
catch (final Exception e) {} |
|
212 |
|
|
213 |
} |
|
214 |
|
|
215 |
|
|
216 |
/** |
|
217 |
* Sets the current progress value (in the range 1-100) |
|
218 |
* |
|
219 |
* @param iValue |
|
220 |
*/ |
|
221 |
public void setProgress(final int iValue) { |
|
222 |
|
|
223 |
try { |
|
224 |
final Runnable runnable = new Runnable() { |
|
225 |
public void run() { |
|
226 |
jProgressBar.setValue(iValue); |
|
227 |
} |
|
228 |
}; |
|
229 |
if (SwingUtilities.isEventDispatchThread()) { |
|
230 |
runnable.run(); |
|
231 |
} |
|
232 |
else { |
|
233 |
SwingUtilities.invokeAndWait(runnable); |
|
234 |
} |
|
235 |
} |
|
236 |
catch (final Exception e) {} |
|
237 |
|
|
238 |
} |
|
239 |
|
|
240 |
|
|
241 |
/** |
|
242 |
* Sets whether the process being monitored is determinate or not |
|
243 |
* |
|
244 |
* @param bDeterminate |
|
245 |
*/ |
|
246 |
public void setDeterminate(final boolean bDeterminate) { |
|
247 |
|
|
248 |
try { |
|
249 |
final Runnable runnable = new Runnable() { |
|
250 |
public void run() { |
|
251 |
jProgressBar.setIndeterminate(!bDeterminate); |
|
252 |
} |
|
253 |
}; |
|
254 |
if (SwingUtilities.isEventDispatchThread()) { |
|
255 |
runnable.run(); |
|
256 |
} |
|
257 |
else { |
|
258 |
SwingUtilities.invokeAndWait(runnable); |
|
259 |
} |
|
260 |
} |
|
261 |
catch (final Exception e) {} |
|
262 |
|
|
263 |
} |
|
264 |
|
|
265 |
|
|
266 |
/** |
|
267 |
* this method sets a prefix to be prepended to the description title. This can be used for processes that include several |
|
268 |
* algorithms, so when each algorithm sets its owns description, it will also contain a string indicating the part of the |
|
269 |
* global process that it represents. This method should, therefore, not be called by simple algorithms, but just from complex |
|
270 |
* processes |
|
271 |
* |
|
272 |
* @param sPrefix |
|
273 |
* the prefix to prepend to the description title. |
|
274 |
*/ |
|
275 |
public void setDescriptionPrefix(final String sPrefix) { |
|
276 |
|
|
277 |
m_sPrefix = sPrefix; |
|
278 |
updateTitle(); |
|
279 |
|
|
280 |
|
|
281 |
} |
|
282 |
|
|
283 |
} |
|
0 | 284 |
org.gvsig.toolbox/trunk/org.gvsig.toolbox_deprecated/org.gvsig.toolbox.gui/src/es/unex/sextante/gui/core/NameAndIcon.java | ||
---|---|---|
1 |
|
|
2 |
|
|
3 |
package es.unex.sextante.gui.core; |
|
4 |
|
|
5 |
import javax.swing.ImageIcon; |
|
6 |
|
|
7 |
|
|
8 |
public class NameAndIcon { |
|
9 |
|
|
10 |
private String m_sName; |
|
11 |
private ImageIcon m_Icon; |
|
12 |
|
|
13 |
|
|
14 |
public NameAndIcon(final String sName, |
|
15 |
final ImageIcon icon) { |
|
16 |
|
|
17 |
m_sName = sName; |
|
18 |
m_Icon = icon; |
|
19 |
|
Also available in: Unified diff