풀스크린 윈도우 (FullScreen Window) 만들기
import java.awt.*;
import java.awt.event.*;
import javax.swing.*;
public class FullScreen1 {
GraphicsDevice device;
public FullScreen1() {
GraphicsEnvironment ge = GraphicsEnvironment
.getLocalGraphicsEnvironment();
device = ge.getDefaultScreenDevice();
GraphicsConfiguration gc = device.getDefaultConfiguration();
try {
JFrame frame = new JFrame(gc);
//프레임의 테두리를 없앤다.
frame.setUndecorated(true);
JButton button = new JButton("OK");
button.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
device.setFullScreenWindow(null);
System.exit(0);
}
});
frame.getContentPane().add(button);
//frame을 스크린에 가득차도록 풀스크린 윈도우로 만듬
device.setFullScreenWindow(frame);
frame.setVisible(true);
} catch (Exception ex) {
device.setFullScreenWindow(null);
System.exit(0);
}
}
public static void main(String[] args) {
new FullScreen1();
}
}
전체 글
- 풀스크린 윈도우 만들기.. 2007.08.20 1
- 원어데이 (One a day) 지름신의 강림?! 2007.08.20
- Jakarta Ant II탄 상세편 2007.08.20
풀스크린 윈도우 만들기..
원어데이 (One a day) 지름신의 강림?!
원어데이 (One a day) http://www.oneaday.co.kr |
![]() |
인터넷 최저가로 하루에 한개의 상품만을 판매한다는 원어데이...
아이디어가 기발한 사이트이다.. 왠지 매력이 있지만....
이곳에 가게되면 지름신의 강림이.. ㅠㅠ 현명한 선택이 필요한 사이트
므튼 인터넷 최저가로 판매한다니... 가볼만 하다..
Jakarta Ant II탄 상세편
Jakarta Ant
-. 이번 강좌에서는 지난 시간에 이어 ant 사용에 필수적인 task들에 대해 알아보고
예제를 통해 한번더 알아보도록 하겠습니다.
만약 지난 강좌를 아직 보지 않았다면 다음 링크를 참조하세요
http://www.jakartaproject.com/article/jakarta/1114617006525
I. 집합 태그
1. <fileset>
①개요
-. fileset이란 말 그대로 파일의 집합을 말하며 특정 태스크에서 파일을 포함하여야 할때
손쉽게 특정 파일이나 집합을 지정해 주는데 사용된다
주로 클래스패스나, 압축, 파일 카피등의 task에서 사용되어진다
②예제
사용예제-1
모든 디렉토리의 java파일을 포함시키면서 파일이름중 Test가 들어가는 파일은 제외하는 fileset을 나타낸다
위 세가지 fileset은 같은 의미이다
사용예제-2
","를 사용하여 나타낼 수도 있고 다로 분리하여 tag를 사용할 수도 있다
위 두 fileset은 같은 의미이다
③ 속성
속성 | 설명 | 필수여부 |
dir | 파일집합의 최상위 디렉토리 (루트 디렉토리) | dir나 file둘중 하나는 필수 |
file | 특정 하나의 파일을 지정할때 사용 | |
defaultexcludes | default excludes 에 명시된 파일 및 디렉토리를 자동적으로 제외하는 속성이며 이기능을 사용하려면 생략한다. 혹은 yes/no 로 값을 준다 | No |
includes | 컴마나 스페이스로 구분된 파일의 패턴을 포함하는 속성이며 모든 파일을 사용하려면 생략한다 | No |
includesfile | 특정 각각의 파일을 포함할때 사용하는 속성 | No |
excludes | 컴마나 스페이스로 구분된 파일의 패턴을 제외하는 속성이며 생략하면 default excludes를 제외하고 어떠한 파일도 제외하지 않는다 | No |
excludesfile | 특정 각각의 파일을 제외할때 사용하는 속성 | No |
casesensitive | 패턴의 대소문자를 구분할지 여부를 나타내는 속성으로 기본값은 true이다 | No |
followsymlinks | symbolic links를 허용할지 여부를 나타내며 기본값은 true이다 | No |
excludes를 사용하지 않아도 기본적으로 제외되는 파일 및 디렉토리
자 이정도면 fileset은 이제 빠~삭해 지셨겠죠?
2. <dirset>
① 개요
-. fileset이 파일 집합을 나타냈다면 dirset task는 디렉토리의 집합을 나타낸다. 기본적인 속성은 fileset과 동일하다
차이점은 defaultexcludes가 없다
② 사용예제
apps 이하 디렉토리중 classes 디렉토리를 포함하고 apps 이하 디렉토리중 디렉토리 이름중 Test가 들어가는 디렉토리는 제외한 dirset을 의미한다
③ 속성
속성 | 설명 | 필수여부 |
dir | 파일집합의 최상위 디렉토리 (루트 디렉토리) | YES |
includes | 컴마나 스페이스로 구분된 디렉토리의 패턴을 포함하는 속성이며 모든 파일을 사용하려면 생략한다 | No |
includesfile | 특정 각각의 디렉토리를 포함할때 사용하는 속성 | No |
excludes | 컴마나 스페이스로 구분된 디렉토리의 패턴을 제외하는 속성이며 생략하면 어떠한 디렉토리도 제외하지 않는다 | No |
excludesfile | 특정 각각의 디렉토리를 제외할때 사용하는 속성 | No |
casesensitive | 패턴의 대소문자를 구분할지 여부를 나타내는 속성으로 기본값은 true이다 | No |
followsymlinks | symbolic links를 허용할지 여부를 나타내며 기본값은 true이다 | No |
3. <patternset>
① 개요
-. 여러 파일이나 디렉토리를 미리 그룹핑해 놓고 이를 특정 아이디를 통해 사용하는 방식을 제공한다. 즉 워드의 매크로 같은 기능이라 보면 쉽게 이해가 갑니다
② 사용예제
예제를 보는바와 같이 patternset은 여러곳에서 동일한 패턴을 사용할때 이를 미리 정의해 놓고 지정한 id의 값을 refid를 통해 재사용 할 수 있다
paternset을 사용하면 코딩양을 줄일 수 있고 변동사항이 있으면 손쉽게 변동 할 수 있다는 점이다
③ 속성
속성 | 설명 | 필수여부 |
includes | 컴마나 스페이스로 구분된 디렉토리의 패턴을 포함하는 속성이며 모든 파일을 사용하려면 생략한다 | No |
includesfile | 특정 각각의 디렉토리를 포함할때 사용하는 속성 | No |
excludes | 컴마나 스페이스로 구분된 디렉토리의 패턴을 제외하는 속성이며 생략하면 어떠한 디렉토리도 제외하지 않는다 | No |
excludesfile | 특정 각각의 디렉토리를 제외할때 사용하는 속성 | No |
4. <path>
① 개요
-. 파일과 디렉토리를 함께 나타낼 수 있는 집합. 클래스패스에는 경로뿐만 아니라 *.jar 같은 파일이 같이 사용되듯이 이 path task는 주로 클래스패스로 자주 이용된다
fileset, dirset과 비슷하지만 파일과 디렉토리를 함께 나타낼 수 있다는 점에서 틀리다
path tag역시 patternset과 같이 지정된 id 값을 이용하여 여러 곳에서 재사용 할 수 있다.
② 사용예제
아래 예제는 ${basedir}/lib/struts.jar, ${base.dir}/lib/log4j.jar 그리고 ${base.dir}/classes 에 클래스패스를 잡는 예제이다.
path에 대한 정의를 해놓고 base.path라는 아이디를 이용하여 여러 곳에서 사용할 수 있다
location 속성은 single 파일이나 탐색할 하나의 디렉토리만을 설정할수 있는 반면에,
path는 ";"나 ":"를 사용하여 여러 파일들이나 디렉토리를 설정할 수 있다
II. 파일 태그
1. <copy>
① 개요
-. 소스 파일을 타겟으로 파일을 복사하는데 사용한다
② 사용예제
③ 속성
속성 | 설명 | 필수여부 |
file | 복사할 파일 | fileset tag를 사용하지 않는다면 필수 |
preservelastmodified |
소스와 타겟의 최종 수정날짜 파일을 유지하며 복사한다 기본값은 false |
No |
tofile | 복사할 소스파일 | fileset tag와 함께 소스 및 타겟을 지정할수있다 |
todir | 복사할 소스 디렉토리 | |
overwrite | 타겟의 파일이 최근의 파일이라도 덮어쓸지 여부를 나타내며 기본값은 false | No |
filtering |
복사하는동안 filter를 사용할것인지 여부를 나타내며 기본값은 false 단 이 값이 false일지라도 nested 하게 <filterset>을 사용할수 있다 |
No |
flatten |
소스 디렉토리의 구조를 무시하고 특정 디렉토리 한곳에 모든 파일을 복사할지 여부를 나타내며 기본값은 false |
No |
includeEmptyDirs |
<fileset>을 지정하여 복사될 디렉토리중에 파일이 없는 비어있는 디렉토리까지 복사할지 여부를 나타내며 기본값을 true |
No |
failonerror |
복사중 에러가 발생할때 false이면 warning 메세지 로그를, 그렇지 않으면 build시 중지한다 기본값은 true |
No |
verbose | 복사되고 있는 파일의 로그 여부를 나타내며 기본값은 false | No |
encoding |
필터 복사중 사용할 encoding을 나타내며 기본값은 JVM 기본 encoding을 따른다 (ant 1.5 이후) |
No |
outputencoding |
파일기록에 사용할 encoding을 나타낸다 (ant 1.6이후) |
No |
enablemultiplemappings |
true면 주어진 소스 path에대해 모든 mapping 처리를 하며 false이면 첫번째 파일이나 디렉토리에 대해서만 mapping 처리를 한다 이 속성은 <mapper> subelement가 있을때만 관련있다 기본값은 false (ant 1.6이후) |
No |
granularity |
최근 수정된 시간을 기준으로 파일을 비교 복사시 기준이 되는 시간으로부터 여유분 시간을 나타낸다 즉 소스 파일 서버와 타겟 파일 서버가 다른경우 두 머신간에 시간차이가 있을 수 있기 때문에 이를 사용한다 (ant 1.6.2 이후) |
2. <delete>
① 개요
-. 하나의 파일, 하나의 디렉토리 혹은 fileset으로 지정한 특정한 파일들을 삭제할수 있다
② 사용예제
③ 속성
속성 | 설명 | 필수사항 |
file |
삭제할 파일 (상대경로나 절대경로나 상관없음) |
<fileset>을 사용하지 않는다면 file혹은 dir둘중 하나는 사용하여야 한다 |
dir |
삭제할 디렉토리 | |
verbose |
각 삭제되는 파일의 이름을 보져줄 것인지 여부를 나타내며 기본값은 false |
No |
quiet |
시스템이 사용하고 있어 삭제할수 없는 파일이거나 존재하지 않는 파일, 디렉토리등의 메세지를 나태낼지 여부를 나타내며 기본값은 false |
No |
failonerror |
파일 삭제시 에러가 발생하면 build를 중단 하고 현재 사항을 레포팅해줄지 여부를 나타내며 기본값은 true |
No |
includeemptydirs | fileset을 사용할 때 빈 디렉토리empty directory)를 삭제할 것인지 여부를 나타내며 기본값은 false | No |
includes | Deprecated. Use <fileset> . |
No |
includesfile | Deprecated. Use <fileset> . |
No |
excludes | Deprecated. Use <fileset> . |
No |
excludesfile | Deprecated. Use <fileset> . |
No |
defaultexcludes |
Deprecated. Use 기본값은 true |
No |
deleteonexit |
파일 삭제시 실패했을때 JVM이 종료될 때 이 파일을 지우도록 할것인지 여부를 나타내며 기본값은 false (ant 1.6.2 이후) |
No |
3. <mkdir>
① 설명
-. 디렉토리를 생성
② 사용예제
③ 속성
속성 | 설명 | 필수여부 |
dir | 생성할 디렉토리 | Yes |
4. <move>
① 설명
-. 파일 혹은 디렉토리를 타겟으로 이동시킵니다 디폴트로 타겟에 이미 파일이 존재하면 덮어씁니다.
② 사용예제
③ 속성
-. delete 속성과 동일합니다
III. java 태그
1. <javac>
① 설명
-. 자바소스를 컴파일 하는 tag입니다
기본적으로 타겟에 특정 .java에 대해 .class 파일이 없거나 오래된 .class 파일이면 컴파일 대상입니다
② 사용예제
③ 속성
width=20%>속성 | 설명 | 필수여부 |
srcdir | 자바 소스가 위치한 디렉토리 |
Yes
|
destdir | 컴파일된 클래스파일이 위치할 디렉토리 | No |
includes | 컴마나 스페이스로 구분된 파일집합의 패턴을 포함하여 컴파일하며 모든 파일을 사용하려면 생략한다 | No |
includesfile | 각각 개개의 파일을 포함하여 컴파일 | No |
excludes | 컴마나 스페이스로 구분된 파일의 패턴을 제외하하여 컴파일하며 생략하면 어떠한 디렉토리도 제외하지 않는다 | No |
excludesfile | 각각 개개의 파일을 제외하여 컴파일 | No |
classpath | 사용할 클래스 패스 | No |
sourcepath |
사용할 소스패스이며 기본값은 srcdir 값이다 |
No |
bootclasspath | bootstrap 클래스 패스 | No |
classpathref | 참조를 통해 사용할 클래스 패스 (refid를 이용한 path 태그) | No |
sourcepathref | 참조를 통해 사용할 소스 패스 | No |
bootclasspathref | 참조를 통해 사용할 bootstrap 패스 | No |
extdirs | 사용할 extednsion이 위치한 경로 (${java_home}/lib/ext/를 말하는것 같음) | No |
encoding | 소스파일에 사용할 encoding (javac의 -encoding과 동일) | No |
nowarn |
컴파일시 -nowarn 옵션을 을 줄지 여부를 나타내며 기본값은 off 반대값은 on |
No |
debug | 컴파일시 debug 모드로 컴파일 하며 기본값은 off | No |
optimize | 컴파일시 optimize 옵션을 사용한다 기본값은 off | No |
deprecation | 컴파일시 deprecation 옵션을 사용한다 기본값은 off | No |
target | 특정 VM 버젼으로 컴파일 할수 있도록 한다 | No |
verbose |
컴파일시 그 내용을 화면에 출력한다 기본값은 no |
No |
depend |
이를 지원하는 컴파일러는 dependecy-tracking를 가능하게 한다 |
No |
includeAntRuntime |
ant run time library를 포함하여 컴파일하며 기본값은 yes |
No |
includeJavaRuntime |
VM이 실행될때의 run time library를 포함하여 컴파일하며 기본값은 no |
No |
fork | 외부의 JDK를 사용하여 컴파일 하며 기본값은 no | No |
executable |
fork를 yes로 하였을경우 javac가 실행될 경로를 나타내며 기본값으로는 ant에서 현재 사용중인 java version의 컴파일러를 나타낸다 |
No |
memoryInitialSize |
VM내에서 초기 메모리 사이즈를 설정하며 기본값은 VM에 설정된 기본값을 사용한다 |
No |
memoryMaximumSize | VM내에서 최대 메모리 사이즈를 설정 | No |
failonerror |
컴파일시 에러가 발생하였을 경우 계속 진행할지 여부를 나타내며 기본값은 true |
No |
source | -source 옵션을 이용하여 컴파일 한다 | No |
compiler |
사용할 컴파일러 설정 list |
No |
listfiles |
컴파일 되는 소스파일들을 list할지 여부를 나타내며 기본값은 no |
No |
tempdir |
ant가 사용하는 임시디렉토리 기본값은 java.io.tmpdir (ant 1.6이후) |
No |
2. <javadoc>
① 개요
-. 자바 소스 파일로 부터 javadoc API 문서를 생성한다
② 사용예제
③ 속성
속성 | 설명 | 사용범위 | 필수여부 |
sourcepath | 자바 소스 위치 | all | At least one of the three or nested <sourcepath> , <fileset> or <packageset> |
sourcepathref | 참조된 경로 아이디를 사용하여 소스위치를 지정 (path 의 refid를 사용) | all | |
sourcefiles | 컴마로 구분하여 소스 파일을 지정 | all | |
destdir | 결과물(java docs) 디렉토리를 지정 | all | Yes, unless a doclet has been specified. |
maxmemory |
javadoc VM에 할당할 최대 메모리 사이즈 |
all | No |
packagenames |
컴마로 구분된 패키지 파일 목록 ("*"로 끝나면 하위 패키지까지 모두 javadoc으로 처리한다) |
all | No |
packageList | 처리할 패키지를 포함하고있는 파일명 | all | No |
classpath | 사용할 클래스 패스 | all | No |
Bootclasspath |
사용할 bootstrap 클래스 패스 |
all | No |
classpathref | 참조된 경로 아이디를 사용하여 클래스 패스를 지정 (path 의 refid) | all | No |
bootclasspathref | 참조된 경로 아이디를 사용하여 bootstrap classpath를 지정 | all | No |
Extdirs | 설치된 extension 위치 | all | No |
Overview |
HTML 문서로부터 overview 문서를 읽어온다 |
all | No |
access |
Access mode를 지정한다
|
all | No |
Public | 생성된 문서에 public 클래스와 멤버만 보여준다 | all | No |
Protected | 생성된 문서에 protected/public 클래스와 멤버만 보여준다 | all | No |
Package | 생성된 문서에 package/protected/public 클래스와 멤버만 보여준다 | all | No |
Private | 생성된 문서에 모든 클래스와 멤버를 보여준다 | all | No |
Old | jdk 1.1 버젼으로 문서를 생성한다 | 1.2 | No |
Verbose | javadoc을 생성하는동안 메세지를 화면에 출력한다 | all | No |
Locale |
사용할 Locale 을 지정한다 (en_US, en_US_WIN, ko_KR) |
all | No |
Encoding | 소스파일 encoding 이름 | all | No |
Version | @version 단락을 포함한다 | all | No |
Use | 클래스와 패키지 사용법에 대한 페이지를 생성한다 | all | No |
Author | @author 단락을 포함한다 | all | No |
Splitindex | Split index into one file per letter | all | No |
Windowtitle | 생성된 문서의 브라우져 타이트을 지정한다 (텍스트) | all | No |
Doctitle |
패키지 인덱스 페이지에 대한 타이틀을 지정한다 (html 코드) |
all | No |
Header |
각페이지에대한 헤더부분을 지정한다 (html 코드) |
all | No |
Footer | 각페이지에대한 푸터부분을 지정한다 (html 코드) | all | No |
bottom | 각페이지에대한 버텀부분을 지정한다 (html 코드) | all | No |
link |
주어진 URL로 javadoc 출력물에 link를 생성한다 |
all | No |
linkoffline | Link to docs at <url> using package list at <url2> - separate the URLs by using a space character -- see also the nested link element. |
all | No |
group | 특정 패키지들에 대한 overview 페이지를 생성한다 | all | No |
nodeprecated | @deprecated 정보를 포함하지 않는다 | all | No |
nodeprecatedlist | deprecated 목록을 생성하지 않는다 | all | No |
notree | 클래스 하이라키를 생성하지 않는다 | all | No |
noindex | 인덱스를 생성하지 않는다 | all | No |
nohelp | 도움말 link를 생성하지 않는다 | all | No |
nonavbar | 네비게이션 바를 생성하지 않는다 | all | No |
serialwarn | @serial tag 대한 warning을 생성한다 | all | No |
helpfile | help 파일로 사용될 HTML 파일을 지정한다 | all | No |
stylesheetfile | CSS 로 사용할 파일을 지정한다 | all | No |
charset | 문서를 생성할때 사용될 charset을 지정한다 | all | No |
docencoding | 결과 파일(문서)에 사용될 encoding을 지정한다 | all | No |
doclet |
doclet을 시작하는 클래스 파일을 지정한다 |
all | No |
docletpath |
doclet 클래스 패스를 지정한다 |
all | No |
docletpathref | 참조 아이디값을 이용해 docletpath를 지정한다 | all | No |
additionalparam |
javadoc 명령에서 추가적인 파라미터를 추가하도록 한다 |
all | No |
failonerror |
에러 발생시 build 중단할지 여부를 나타낸다 |
all | No |
excludepackagenames | 문서를 생성하지 않을 패키지를 컴마로 구분하여 지정한다ment. | all | No |
defaultexcludes |
기본적으로 제외되는 목록을 사용할 것인지 여부를 나타낸다 |
all | No |
useexternalfile |
명령줄을 간단히하기위해 임시파일에 기록된 소스파일명을 지정한다 기본값은 No |
all | No |
source |
j2se 1.4 소스코드에 나타난 주장을 처리하도록 javadoc에서 설정한다 |
1.4+ | No |
linksource |
소스파일에 hyperlinks 생성한다 기본값은 No (ant 1.6이후) |
1.4+ | No |
breakiterator |
새로운 breakiterator 알고리즘을 사용한다 기본값은 No (ant 1.6이후) |
1.4+ | No |
noqualifier |
-noqualifier 옵션을 설정한다 (ant 1.6이후) |
1.4+ | No |
includenosourcepackages |
"true"이면 자바소스가 아닌 패키지된 html을 가지고 문서 생성이 한다 (ant 1.6.3이후) |
all | No (default is false ) |
executable |
실행될 javadoc 위치를 지정한다 (ant 1.6이후) |
all | No |
3. <war>
① 개요
-. 웹 어플리케이션 배포 파일인 war 파일을 생성해 준다
② 사용예제
③ 속성
속성 | 설명 | 필수여부 |
destfile | 생성될 WAR 파일 지정 | 둘중 하나는 필수 |
warfile | Deprecated | |
webxml | 사용할 deployment descriptor (WEB-INF/web.xml)를 지정 | Yes |
basedir | jar파일로 압축할 디렉토리를 지정한다 | No |
compress |
data를 압축할지 여부를 나타내며 기본값은 true이다 keepcompression 속성을 false로 했을지라도 이는 적용된다 |
No |
keepcompression |
이미 존재하는 파일 묶음에 대해 compress을 계속 유지할 것인지 여부를 나타내며 기본값은 fale 이다 (ant 1.6이후) |
No |
encoding |
압축될 파일명에 사용할 encoding을 지정한다 기본값은 UTF8 |
No |
filesonly |
Store only file entries 기본값은 false |
No |
includes | 지정된 컴마나 스페이스로 구분된 파일 패턴을 WAR에 포함하며 생략하면 모든 파일을 WAR한다 | No |
includesfile | 지정된 개개의 파일을 WAR에 포함한다 | No |
excludes | 지정된 컴마나 스페이스로 구분된 파일 패턴을 WAR에서 제외시키며 생략하면 어떠한 파일로 제외하지 않는다 | No |
excludesfile | 지정된 개개의 파일을 WAR에서 제외시킨다 | No |
defaultexcludes | 기본적으로 제외시키는 기능을 사용할것인지 여부를 나타낸다 | No |
manifest | 사용할 manifest 파일을 지정한다 | No |
update | 이미 존재하는 파일이라면 업데이트할지 덮어쓸지를 결정하며 기본값은 false이다 | No |
duplicate |
중복된 파일이 나타났을 때 "add"할지 "preserve"할지 혹은 "fail"할지를 지정하며 기본값은 "add"이다 |
No |
roundup |
파일 시간 비교시 파일 변경 시간을 다음 짝수 횟수의 초(seconds)에 반올림 할지 혹은 내림할지 여부를 나타낸다 기본값은 true |
No |
from http://ant.apache.org/manual/index.html
=============================================
본문서는 자유롭게 배포/복사 할수 있지만
이문서의 저자에 대한 언급을 삭제하시면 안됩니다
저자 : GoodBug (unicorn@jakartaproject.com)
최초 : http://www.jakartaproject.com
=============================================