JavaFX-빠른 가이드

Rich Internet Applications데스크톱 애플리케이션과 유사한 기능과 경험을 제공하는 웹 애플리케이션입니다. 일반 웹 응용 프로그램과 비교할 때 사용자에게 더 나은 시각적 경험을 제공합니다. 이러한 애플리케이션은 브라우저 플러그인 또는 가상 머신으로 제공되며 기존의 정적 애플리케이션을보다 향상되고 유연하며 애니메이션이 적용된 매력적인 애플리케이션으로 변환하는 데 사용됩니다.

기존 데스크톱 응용 프로그램과 달리 RIA는 추가 소프트웨어를 실행할 필요가 없습니다. 대안으로 응용 프로그램에 따라 ActiveX, Java, Flash와 같은 소프트웨어를 설치해야합니다.

RIA에서 그래픽 프리젠 테이션은 풍부한 그래픽을 지원하는 플러그인이 있기 때문에 클라이언트 측에서 처리됩니다. 요컨대, RIA의 데이터 조작은 서버 측에서 수행되고 관련 개체 조작은 클라이언트 측에서 수행됩니다.

RIA를 개발할 수있는 세 가지 주요 기술이 있습니다. 여기에는 다음이 포함됩니다.

  • 어도비 플래시
  • 마이크로 소프트 실버 라이트
  • JavaFX

어도비 플래시

이 소프트웨어 플랫폼은 Adobe Systems에서 개발했으며 리치 인터넷 애플리케이션을 만드는 데 사용됩니다. 이와 함께 벡터, 애니메이션, 브라우저 게임, 데스크톱 응용 프로그램, 모바일 응용 프로그램 및 게임 등과 같은 다른 응용 프로그램을 만들 수도 있습니다.

이것은 데스크톱 브라우저 보급률이 96 % 인 RIA를 개발하고 실행하는 데 가장 일반적으로 사용되는 플랫폼입니다.

마이크로 소프트 실버 라이트

Adobe Flash와 마찬가지로 Microsoft Silverlight는 리치 인터넷 애플리케이션을 개발하고 실행하기위한 소프트웨어 애플리케이션 프레임 워크이기도합니다. 처음에이 프레임 워크는 스트리밍 미디어에 사용되었습니다. 현재 버전은 멀티미디어, 그래픽 및 애니메이션도 지원합니다.

이 플랫폼은 데스크톱 브라우저 보급률이 66 %로 거의 사용되지 않습니다.

JavaFX

JavaFX는 리치 인터넷 애플리케이션을 개발할 수있는 Java 라이브러리입니다. Java 기술을 사용함으로써 이러한 응용 프로그램의 브라우저 보급률은 76 %입니다.

JavaFX 란 무엇입니까?

JavaFX는 리치 인터넷 애플리케이션을 빌드하는 데 사용되는 Java 라이브러리입니다. 이 라이브러리를 사용하여 작성된 응용 프로그램은 여러 플랫폼에서 일관되게 실행될 수 있습니다. JavaFX를 사용하여 개발 된 응용 프로그램은 데스크톱 컴퓨터, 휴대폰, TV, 태블릿 등과 같은 다양한 장치에서 실행할 수 있습니다.

개발하다 GUI Applications 프로그래머는 Java 프로그래밍 언어를 사용하여 다음과 같은 라이브러리에 의존합니다. Advanced Windowing ToolkitSwing. JavaFX의 출현 이후, 이러한 Java 프로그래머는 이제 풍부한 컨텐츠로 GUI 애플리케이션을 효과적으로 개발할 수 있습니다.

JavaFX의 필요성

개발하다 Client Side Applications풍부한 기능을 갖춘 프로그래머는 미디어, UI 컨트롤, 웹, 2D 및 3D 등과 같은 기능을 추가하기 위해 다양한 라이브러리에 의존했습니다. JavaFX는 이러한 모든 기능을 단일 라이브러리에 포함합니다. 이 외에도 개발자는 다음과 같은 Java 라이브러리의 기존 기능에 액세스 할 수 있습니다.Swing.

JavaFX는 풍부한 그래픽 및 미디어 API 세트를 제공하며 최신 Graphical Processing Unit하드웨어 가속 그래픽을 통해. JavaFX는 또한 개발자가 그래픽 애니메이션과 UI 제어를 결합 할 수있는 인터페이스를 제공합니다.

Java, Groovy 및 JRuby와 같은 JVM 기반 기술과 함께 JavaFX를 사용할 수 있습니다. 개발자가 JavaFX를 선택하면 위에서 언급 한 기술에 대한 사전 지식이 JavaFX를 사용하여 RIA를 개발하기에 충분할 것이므로 추가 기술을 배울 필요가 없습니다.

JavaFX의 기능

다음은 JavaFX의 중요한 기능 중 일부입니다.

  • Written in Java − JavaFX 라이브러리는 Java로 작성되었으며 다음과 같은 JVM에서 실행할 수있는 언어로 사용할 수 있습니다. Java, Groovy and JRuby. 이러한 JavaFX 응용 프로그램은 플랫폼에 독립적입니다.

  • FXML− JavaFX는 선언적 마크 업 언어와 같은 HTML 인 FXML로 알려진 언어를 특징으로합니다. 이 언어의 유일한 목적은 사용자 인터페이스를 정의하는 것입니다.

  • Scene Builder− JavaFX는 Scene Builder라는 응용 프로그램을 제공합니다. 이 애플리케이션을 Eclipse 및 NetBeans와 같은 IDE에 통합 할 때 사용자는 FXML 애플리케이션을 개발하는 데 사용되는 드래그 앤 드롭 디자인 인터페이스에 액세스 할 수 있습니다 (Swing Drag & Drop 및 DreamWeaver 애플리케이션과 유사).

  • Swing Interoperability − JavaFX 응용 프로그램에서 다음을 사용하여 Swing 콘텐츠를 포함 할 수 있습니다. Swing Node수업. 마찬가지로 임베디드 웹 콘텐츠 및 풍부한 그래픽 미디어와 같은 JavaFX 기능으로 기존 Swing 애플리케이션을 업데이트 할 수 있습니다.

  • Built-in UI controls − JavaFX 라이브러리는 완전한 기능을 갖춘 애플리케이션을 개발할 수있는 UI 컨트롤을 제공합니다.

  • CSS like Styling− JavaFX는 스타일과 같은 CSS를 제공합니다. 이것을 사용하면 CSS에 대한 간단한 지식으로 애플리케이션의 디자인을 향상시킬 수 있습니다.

  • Canvas and Printing API− JavaFX는 렌더링 API의 즉각적인 모드 스타일 인 Canvas를 제공합니다. 패키지 내javafx.scene.canvas캔버스 용 클래스 세트를 보유하고 있으며이를 사용하여 JavaFX 장면의 영역 내에서 직접 그릴 수 있습니다. JavaFX는 또한 패키지에서 인쇄용 클래스를 제공합니다.javafx.print.

  • Rich set of API’s− JavaFX 라이브러리는 GUI 애플리케이션, 2D 및 3D 그래픽 등을 개발하기위한 풍부한 API 세트를 제공합니다.이 API 세트에는 Java 플랫폼의 기능도 포함되어 있습니다. 따라서이 API를 사용하여 Generics, Annotations, Multithreading 및 Lambda Expressions와 같은 Java 언어의 기능에 액세스 할 수 있습니다. 전통적인 Java Collections 라이브러리가 향상되었고 관찰 가능한 목록 및지도와 같은 개념이 포함되었습니다. 이를 사용하여 사용자는 데이터 모델의 변화를 관찰 할 수 있습니다.

  • Integrated Graphics library − JavaFX는 2d3d 제도법.

  • Graphics pipeline− JavaFX는 Prism으로 알려진 하드웨어 가속 그래픽 파이프 라인을 기반으로 그래픽을 지원합니다. 지원되는 그래픽 카드 또는 GPU와 함께 사용하면 부드러운 그래픽을 제공합니다. 시스템이 그래픽 카드를 지원하지 않는 경우 프리즘은 소프트웨어 렌더링 스택으로 기본 설정됩니다.

JavaFX의 역사

JavaFX는 원래 Chris Oliver, 회사에서 일할 때 See Beyond Technology Corporation, 나중에 인수 Sun Microsystems 2005 년.

다음 사항은이 프로젝트에 대한 자세한 정보를 제공합니다.

  • 처음에이 프로젝트의 이름은 F3으로 지정되었습니다. (Form Follows Functions) GUI 응용 프로그램 개발을위한보다 풍부한 인터페이스를 제공하기 위해 개발되었습니다.

  • Sun Microsystems 2005 년 6 월 See Beyond 회사를 인수하여 F3 프로젝트를 JavaFX.

  • 2007 년에 JavaFX는 공식적으로 Java One, 매년 개최되는 월드 와이드 웹 컨퍼런스.

  • 2008 년에 Net BeansJavaFX와 통합이 가능했습니다. 같은 해에 JavaStandard Development Kit JavaFX 1.0이 출시되었습니다.

  • 2009 년에 Oracle Corporation은 Sun Microsystems를 인수했으며 같은 해 JavaFX (1.2)의 다음 버전도 출시되었습니다.

  • 2010 년에 JavaFX 1.3이 나왔고 2011 년에 JavaFX 2.0이 출시되었습니다.

  • 최신 버전 인 JavaFX8은 2014 년 3 월 18 일 Java의 필수 부분으로 출시되었습니다.

Java8부터 JDK (Java Development Kit) 포함 JavaFX도서관. 따라서 JavaFX 응용 프로그램을 실행하려면 시스템에 Java8 이상 버전을 설치하기 만하면됩니다.

또한 Eclipse 및 NetBeans와 같은 IDE는 JavaFX에 대한 지원을 제공합니다. 이 장에서는 다양한 방식으로 JavaFX 응용 프로그램을 실행하도록 환경을 설정하는 방법을 설명합니다.

Java8 설치

먼저 명령 프롬프트를 열고 "Java"명령을 입력하여 시스템에 Java가 설치되어 있는지 여부를 확인해야합니다.

시스템에 Java를 설치하지 않은 경우 명령 프롬프트에 다음 스크린 샷과 같은 메시지가 표시됩니다.

그런 다음 아래 단계에 따라 Java를 설치하십시오.

Step 1− JavaSE 다운로드 페이지를 방문 하여 JDK를 클릭하십시오.Download 다음 스크린 샷에 강조 표시된 버튼

Step 2 − 다운로드 버튼을 클릭하면 다음 페이지로 리디렉션됩니다. Java SE Development Kit 8 Downloads페이지. 이 페이지는 다양한 플랫폼에 대한 JDK 링크를 제공합니다.

라이센스 계약에 동의하고 해당 링크를 클릭하여 필요한 소프트웨어를 다운로드하십시오.

예를 들어 Windows 64 비트 운영 체제에서 작업하는 경우 다음 스크린 샷에 강조 표시된 JDK 버전을 다운로드해야합니다.

강조 표시된 링크를 클릭하면 Windows 64 비트 운영 체제에 적합한 Java8 개발 키트가 시스템에 다운로드됩니다.

Step 3 − 다운로드 한 바이너리 실행 파일을 실행하여 JDK8 설치를 시작합니다.

Step 4 − 설치 디렉토리를 선택하십시오.

Step 5 − 대상 폴더를 선택하고 다음을 클릭하면 JavaFX 설치 프로세스가 다음 스크린 샷과 같이 진행률 표시 줄을 표시하기 시작합니다.

Step 6 − 필요한 경우 설치 디렉토리를 변경하고, 그렇지 않으면 기본 디렉토리를 유지하고 계속 진행하십시오.

Step 7 − 다음 스크린 샷과 같이 닫기 버튼을 클릭하여 설치 과정을 마칩니다.

Windows 용 경로 설정

Java를 설치 한 후 경로 변수를 설정해야합니다. Java를 설치했다고 가정하십시오.C:\Program Files\java\jdk1.8.0_91예배 규칙서.

이제 아래에 주어진 단계를 따를 수 있습니다-

  • '내 컴퓨터'를 마우스 오른쪽 버튼으로 클릭하고 '속성'을 선택합니다.

  • '고급'탭에서 '환경 변수'버튼을 클릭합니다.

  • 이제 Java 실행 파일의 경로도 포함하도록 'Path'변수를 변경하십시오. 예를 들어 현재 경로가 'C : \ WINDOWS \ SYSTEM32'로 설정되어 있으면 경로를 'C : \ WINDOWS \ SYSTEM32'로 변경합니다. C : \ Program Files \ java \ jdk1.8.0_91 \ bin '입니다.

JavaFX의 NetBeans 환경 설정

NetBeans8JavaFX에 대한 내장 지원을 제공합니다. 이를 설치하면 추가 플러그인이나 JAR 파일없이 JavaFX 응용 프로그램을 만들 수 있습니다. NetBeans 환경을 설정하려면 아래에 제공된 단계를 따라야합니다.

Step 1− NetBeans 소프트웨어를 다운로드하려면 NetBeans 웹 사이트 NetBeans 웹 사이트를 방문하여 다운로드 버튼을 클릭하십시오.

Step 2 − 클릭시 Download, 다양한 Java 애플리케이션을위한 NetBeans 번들을 제공하는 NetBeans 소프트웨어의 다운로드 페이지로 이동합니다. NetBeans 소프트웨어 다운로드JavaSE 다음 스크린 샷과 같이.

Step 3 −이 버튼을 클릭하면 netbeans-8.0-windows.exe 시스템에 다운로드됩니다. 설치하려면이 파일을 실행하십시오. 이 파일을 실행하면 다음 스크린 샷과 같이 NetBeans 설치 프로그램이 시작됩니다.

구성이 완료되면 Welcome Page of the installer.

Step 4 − 다음 버튼을 클릭하고 설치를 계속합니다.

Step 5 − 다음 창에는 NETBEANS IDE 8.0 license agreement. 주의 깊게 읽고 "I accept the terms in the license agreement"확인란을 선택하여 계약에 동의 한 다음Next 단추.

Step 6 − 다음 창에서 다음에 대한 사용권 계약이 표시됩니다. Junit, "I accept the terms in the license agreement, Install JUnit"에서 라디오 버튼을 선택하여 동의하고 Next.

Step 7− Netbeans 8.0을 설치해야하는 대상 디렉토리를 선택하십시오. 또한 디렉토리를 검색 할 수도 있습니다.Java Development Kit 시스템에 설치되어 있고 Next 단추.

Step 8 − 마찬가지로 대상 디렉토리를 선택하십시오. Glassfish Server설치. Java Development Kit 디렉토리 (지금은 Glassfish 참조)를 검색 한 다음Next.

Step 9 − 확인 Check for Updates 자동 업데이트 상자를 선택하고 설치 버튼을 클릭하여 설치를 시작합니다.

Step 10 −이 단계는 NetBeans IDE 8.0 설치를 시작하며 시간이 걸릴 수 있습니다.

Step 11 − 프로세스가 완료되면 Finish 버튼을 눌러 설치를 완료합니다.

Step 12 − NetBeans IDE를 실행하면 다음 스크린 샷과 같은 시작 페이지가 표시됩니다.

Step 13 − 파일 메뉴에서 New Project… 다음 스크린 샷과 같이 새 프로젝트 마법사를 엽니 다.

Step 14 −에서 New Project 마법사, 선택 JavaFX 그리고 클릭 Next. 새 JavaFX 응용 프로그램을 만들기 시작합니다.

Step 15 − 프로젝트 이름과 프로젝트 위치를 선택합니다. NewJavaFX Application 창을 클릭 한 다음 Finish. 주어진 이름으로 샘플 애플리케이션을 생성합니다.

이 경우 이름이있는 애플리케이션은 javafxsample생성됩니다. 이 응용 프로그램 내에서 NetBeans IDE는 다음 이름의 Java 프로그램을 생성합니다.Javafxsample.java. 다음 스크린 샷에 표시된대로이 프로그램은 NetBeans 소스 패키지 내에 생성됩니다.→ javafxsample.

Step 16 − 파일을 마우스 오른쪽 버튼으로 클릭하고 Run File 다음 스크린 샷에 표시된대로이 코드를 실행합니다.

이 자동 생성 프로그램에는 레이블이있는 버튼이있는 간단한 JavaFX 창을 생성하는 코드가 포함되어 있습니다. Say ‘Hello World’그것에. 이 버튼을 클릭 할 때마다Hello World 아래와 같이 콘솔에 표시됩니다.

Eclipse에 JavaFX 설치

이름이 지정된 플러그인 e(fx)clipse는 JavaFX에서도 사용할 수 있습니다. 다음 단계를 사용하여 Eclipse에서 JavaFX를 설정할 수 있습니다. 우선 시스템에 Eclipse가 있는지 확인하십시오. 그렇지 않은 경우 시스템에 Eclipse를 다운로드하여 설치하십시오.

Eclipse가 설치되면 아래 단계에 따라 설치하십시오. e(fx)clipse 시스템에서.

Step 1 − 다음에서 Eclipse를 엽니 다. Help 메뉴 및 선택 Install New Software… 옵션은 아래와 같습니다.

클릭하면 Available Software 다음 스크린 샷과 같이 창입니다.

텍스트 상자에서 Work with 이 창에서 필요한 소프트웨어에 대한 플러그인 링크를 제공해야합니다.

Step 2 − 클릭 Add… 버튼. 플러그인 이름을 다음과 같이 제공하십시오.e(fx)clipse. 다음으로 다음 링크를 위치로 제공하십시오.http://download.eclipse.org/efxclipse/updates-released/2.3.0/site/

Step 3 − 플러그인의 이름과 위치를 지정한 후 다음 스크린 샷에 강조 표시된대로 확인 버튼을 클릭합니다.

Step 4 − 플러그인을 추가하면 곧 두 개의 확인란이 있습니다. e(fx)clipse – installe(fx)clipse – single components. 이 두 확인란을 모두 선택하고Add… 버튼을 클릭합니다.

Step 5− 다음으로 Eclipse IDE를 엽니 다. 파일 메뉴를 클릭하고 다음 스크린 샷과 같이 프로젝트를 선택합니다.

Step 6− 그러면 프로젝트를 생성하기 위해 Eclipse에서 제공하는 마법사 목록을 볼 수있는 창이 나타납니다. 확장JavaFX 마법사, 선택 JavaFX Project 그리고 Next 다음 스크린 샷과 같이 버튼을 클릭합니다.

Step 7 − 클릭시 Next, 새 프로젝트 마법사가 열립니다. 여기에서 필요한 프로젝트 이름을 입력하고Finish.

Step 8− 마침을 클릭하면 주어진 이름 (샘플)으로 응용 프로그램이 생성됩니다. 하위 패키지에서application, 이름을 가진 프로그램 Main.java 아래와 같이 생성됩니다.

Step 9−이 자동 생성 프로그램에는 빈 JavaFX 창을 생성하는 코드가 포함되어 있습니다. 이 파일을 마우스 오른쪽 버튼으로 클릭하고Run As → Java Application 다음 스크린 샷과 같이.

이 응용 프로그램을 실행하면 아래와 같이 빈 JavaFX 창이 나타납니다.

Note − 코드에 대한 자세한 내용은 이후 장에서 설명합니다.

JavaFX는 풍부한 그래픽으로 GUI 응용 프로그램을 구축 할 수 있도록 풍부한 클래스 및 인터페이스 세트가있는 완전한 API를 제공합니다. 이 API의 중요한 패키지는 다음과 같습니다.

  • javafx.animation − JavaFX 노드에 채우기, 페이드, 회전, 크기 조정 및 변환과 같은 전환 기반 애니메이션을 추가하는 클래스가 포함되어 있습니다.

  • javafx.application − JavaFX 응용 프로그램 수명주기를 담당하는 클래스 집합을 포함합니다.

  • javafx.css − JavaFX GUI 응용 프로그램에 CSS와 유사한 스타일을 추가하는 클래스를 포함합니다.

  • javafx.event − JavaFX 이벤트를 전달하고 처리하기위한 클래스와 인터페이스를 포함합니다.

  • javafx.geometry − 2D 객체를 정의하고 작업을 수행하는 클래스가 포함되어 있습니다.

  • javafx.stage −이 패키지는 JavaFX 애플리케이션을위한 최상위 컨테이너 클래스를 포함합니다.

  • javafx.scene−이 패키지는 장면 그래프를 지원하는 클래스와 인터페이스를 제공합니다. 또한 캔버스, 차트, 컨트롤, 효과, 이미지, 입력, 레이아웃, 미디어, 페인트, 모양, 텍스트, 변환, 웹 등과 같은 하위 패키지도 제공합니다.이 풍부한 JavaFX API를 지원하는 여러 구성 요소가 있습니다. .

다음 그림은 JavaFX API의 아키텍처를 보여줍니다. 여기에서 JavaFX API를 지원하는 구성 요소를 볼 수 있습니다.

장면 그래프

JavaFX에서 GUI 애플리케이션은 장면 그래프를 사용하여 코딩되었습니다. 장면 그래프는 GUI 애플리케이션 구축의 시작점입니다. 노드라고하는 (GUI) 애플리케이션 프리미티브를 보유합니다.

노드는 시각적 / 그래픽 객체이며 다음을 포함 할 수 있습니다.

  • Geometrical (Graphical) objects − (2D 및 3D) 원, 직사각형, 다각형 등

  • UI controls − 버튼, 체크 박스, 선택 상자, 텍스트 영역 등

  • Containers − Border Pane, Grid Pane, Flow Pane 등과 같은 (레이아웃 창)

  • Media elements − 오디오, 비디오 및 이미지 개체와 같은.

일반적으로 노드 모음은 장면 그래프를 만듭니다. 이러한 모든 노드는 아래와 같이 계층 적 순서로 배열됩니다.

장면 그래프의 각 노드에는 단일 부모가 있으며 부모를 포함하지 않는 노드는 root node.

같은 방식으로 모든 노드에는 하나 이상의 자식이 있으며 자식이없는 노드는 leaf node; 자식이있는 노드는branch node.

노드 인스턴스는 장면 그래프에 한 번만 추가 할 수 있습니다. 장면 그래프의 노드에는 효과, 불투명도, 변환, 이벤트 처리기, 이벤트 처리기, 응용 프로그램 별 상태가있을 수 있습니다.

프리즘

프리즘은 high performance hardware–accelerated graphical pipelineJavaFX에서 그래픽을 렌더링하는 데 사용됩니다. 2D 및 3D 그래픽을 모두 렌더링 할 수 있습니다.

그래픽을 렌더링하기 위해 Prism은-

  • Windows XP 및 Vista의 DirectX 9.
  • Windows 7의 DirectX 11
  • Mac 및 Linux, 임베디드 시스템의 OpenGL.

시스템의 그래픽에 대한 하드웨어 지원이 충분하지 않은 경우 Prism은 소프트웨어 렌더링 경로를 사용하여 그래픽을 처리합니다.

지원되는 그래픽 카드 또는 GPU와 함께 사용하면 더 부드러운 그래픽을 제공합니다. 시스템이 그래픽 카드를 지원하지 않는 경우에 Prism은 기본적으로 소프트웨어 렌더링 스택 (위의 두 가지 중 하나)을 사용합니다.

GWT (Glass Windowing Toolkit)

이름에서 알 수 있듯이 GWT는 Windows, 타이머, 표면 및 이벤트 큐를 관리하는 서비스를 제공합니다. GWT는 JavaFX 플랫폼을 기본 운영 체제에 연결합니다.

양자 툴킷

Prism, Glass, Media Engine 및 Web Engine의 저수준 구성 요소에 대한 추상화입니다. Prism과 GWT를 함께 묶어 JavaFX에서 사용할 수 있습니다.

WebView

JavaFX를 사용하여 HTML 콘텐츠를 장면 그래프에 포함 할 수도 있습니다. WebView는이 콘텐츠를 처리하는 데 사용되는 JavaFX의 구성 요소입니다. 그것은라는 기술을 사용합니다Web Kit, 내부 오픈 소스 웹 브라우저 엔진입니다. 이 구성 요소는 HTML5, CSS, JavaScript, DOM 및 SVG와 같은 다양한 웹 기술을 지원합니다.

WebView를 사용하면 다음을 수행 할 수 있습니다.

  • 로컬 또는 원격 URL에서 HTML 콘텐츠를 렌더링합니다.
  • 기록을 지원하고 뒤로 및 앞으로 탐색을 제공합니다.
  • 콘텐츠를 다시로드하십시오.
  • 웹 구성 요소에 효과를 적용합니다.
  • HTML 컨텐츠를 편집하십시오.
  • JavaScript 명령을 실행합니다.
  • 이벤트를 처리합니다.

일반적으로 WebView를 사용하면 Java에서 웹 콘텐츠를 제어 할 수 있습니다.

미디어 엔진

그만큼 JavaFX media engine 오픈 소스 엔진을 기반으로합니다. Streamer. 이 미디어 엔진은 비디오 및 오디오 콘텐츠의 재생을 지원합니다.

JavaFX 미디어 엔진은 다음 파일 형식에 대한 오디오 지원을 제공합니다.

Audio
  • MP3
  • WAV
  • AIFF
Video
  • FLV

패키지 javafx.scene.mediaJavaFX에서 미디어 기능을 제공하는 클래스 및 인터페이스가 포함되어 있습니다. 세 가지 구성 요소의 형태로 제공됩니다.

  • Media Object − 이것은 미디어 파일을 나타냅니다.

  • Media Player − 미디어 콘텐츠를 재생합니다.

  • Media View − 미디어를 표시합니다.

이 장에서는 JavaFX 응용 프로그램의 구조에 대해 자세히 설명하고 예제를 통해 JavaFX 응용 프로그램을 만드는 방법도 배웁니다.

JavaFX 응용 프로그램 구조

일반적으로 JavaFX 응용 프로그램에는 세 가지 주요 구성 요소가 있습니다. Stage, SceneNodes 다음 다이어그램과 같이.

단계

스테이지 (창)에는 JavaFX 애플리케이션의 모든 개체가 포함됩니다. 다음과 같이 표현됩니다.Stage 패키지 클래스 javafx.stage. 기본 단계는 플랫폼 자체에서 생성됩니다. 생성 된 스테이지 객체는 인수로start() 의 방법 Application 클래스 (다음 섹션에서 설명).

무대에는 위치를 결정하는 두 가지 매개 변수가 있습니다. WidthHeight. 콘텐츠 영역과 장식 (제목 표시 줄 및 테두리)으로 구분됩니다.

5 가지 유형의 스테이지가 있습니다.

  • Decorated
  • Undecorated
  • Transparent
  • Unified
  • Utility

당신은 전화해야 show() 단계의 내용을 표시하는 방법.

장면

장면은 JavaFX 응용 프로그램의 물리적 콘텐츠를 나타냅니다. 여기에는 장면 그래프의 모든 내용이 포함됩니다. 클래스Scene 패키지의 javafx.scene장면 개체를 나타냅니다. 인스턴스에서 장면 개체는 하나의 단계에만 추가됩니다.

장면 클래스를 인스턴스화하여 장면을 만들 수 있습니다. 크기 (높이 및 너비)와 함께 전달하여 장면의 크기를 선택할 수 있습니다.root node 생성자에.

장면 그래프 및 노드

scene graph장면의 내용을 나타내는 나무와 같은 데이터 구조 (계층 적)입니다. 대조적으로,node 장면 그래프의 시각적 / 그래픽 개체입니다.

노드에는 다음이 포함될 수 있습니다.

  • -Circle, Rectangle, Polygon 등과 같은 기하학적 (그래픽) 객체 (2D 및 3D)

  • − Button, Checkbox, Choice Box, Text Area 등과 같은 UI 컨트롤

  • 테두리 창, 격자 창, 흐름 창 등과 같은 컨테이너 (레이아웃 창)

  • 오디오, 비디오 및 이미지 개체와 같은 미디어 요소.

그만큼 Node 패키지 등급 javafx.scene JavaFX의 노드를 나타내며이 클래스는 모든 노드의 수퍼 클래스입니다.

앞서 논의했듯이 노드는 세 가지 유형입니다.

  • Root Node − 첫 번째 장면 그래프는 루트 노드로 알려져 있습니다.

  • Branch Node/Parent Node− 자식 노드가있는 노드를 분기 / 상위 노드라고합니다. 명명 된 추상 클래스Parent 패키지의 javafx.scene 모든 부모 노드의 기본 클래스이며 해당 부모 노드는 다음 유형이됩니다.

    • Group− 그룹 노드는 하위 노드 목록을 포함하는 집합 노드입니다. 그룹 노드가 렌더링 될 때마다 모든 하위 노드가 순서대로 렌더링됩니다. 그룹에 적용된 모든 변환, 효과 상태는 모든 하위 노드에 적용됩니다.

    • Region − Chart, Pane 및 Control과 같은 모든 JavaFX 노드 기반 UI 컨트롤의 기본 클래스입니다.

    • WebView −이 노드는 웹 엔진을 관리하고 그 내용을 표시합니다.

  • Leaf Node− 자식 노드가없는 노드를 리프 노드라고합니다. 예를 들어 Rectangle, Ellipse, Box, ImageView, MediaView는 리프 노드의 예입니다.

루트 노드를 장면 그래프에 전달하는 것은 필수입니다. 그룹이 루트로 전달되면 모든 노드가 장면에 잘리고 장면의 크기를 변경해도 장면의 레이아웃에 영향을주지 않습니다.

JavaFX 애플리케이션 생성

JavaFX 응용 프로그램을 만들려면 Application 클래스를 인스턴스화하고 추상 메서드를 구현해야합니다. start(). 이 방법에서는 JavaFX 응용 프로그램에 대한 코드를 작성합니다.

애플리케이션 클래스

그만큼 Application 패키지 클래스 javafx.applicationJavaFX에서 응용 프로그램의 진입 점입니다. JavaFX 응용 프로그램을 만들려면이 클래스를 상속하고 추상 메서드를 구현해야합니다.start(). 이 방법에서는 JavaFX 그래픽에 대한 전체 코드를 작성해야합니다.

에서 main 방법을 사용하여 응용 프로그램을 시작해야합니다. launch()방법. 이 메서드는 내부적으로start() 다음 프로그램과 같이 Application 클래스의 메서드.

public class JavafxSample extends Application {  
   @Override     
   public void start(Stage primaryStage) throws Exception { 
      /* 
      Code for JavaFX application. 
      (Stage, scene, scene graph) 
      */       
   }         
   public static void main(String args[]){           
      launch(args);      
   } 
}

start() 방법, 일반적인 JavaFX 응용 프로그램을 만들려면 다음 단계를 따라야합니다.

  • 필요한 노드가있는 장면 그래프를 준비합니다.

  • 필요한 치수로 장면을 준비하고 장면 그래프 (장면 그래프의 루트 노드)를 여기에 추가합니다.

  • 무대를 준비하고 무대에 장면을 추가하고 무대의 내용을 표시합니다.

장면 그래프 준비

애플리케이션에 따라 필요한 노드가있는 장면 그래프를 준비해야합니다. 루트 노드가 첫 번째 노드이므로 루트 노드를 만들어야합니다. 루트 노드는 다음 중에서 선택할 수 있습니다.Group, Region or WebView.

Group − 그룹 노드는 다음과 같은 클래스로 표시됩니다. Group 패키지에 속하는 javafx.scene, 아래와 같이이 클래스를 인스턴스화하여 그룹 노드를 만들 수 있습니다.

Group root = new Group();

그만큼 getChildren() 의 방법 Group 클래스는 당신에게 ObservableList노드를 보유하는 클래스. 이 개체를 검색하고 아래와 같이 노드를 추가 할 수 있습니다.

//Retrieving the observable list object 
ObservableList list = root.getChildren(); 
       
//Setting the text object as a node  
list.add(NodeObject);

노드 개체를 그룹에 전달하기 만하면 그룹에 추가 할 수도 있습니다. Group 아래와 같이 인스턴스화 할 때 클래스와 생성자에.

Group root = new Group(NodeObject);

Region − 다음과 같은 모든 JavaFX 노드 기반 UI 컨트롤의 기본 클래스입니다.

  • Chart −이 클래스는 모든 차트의 기본 클래스이며 패키지에 속합니다. javafx.scene.chart.

    이 클래스에는 두 개의 하위 클래스가 있습니다. PieChartXYChart. 이 두 가지는 차례로 다음과 같은 하위 클래스를 갖습니다.AreaChart, BarChart, BubbleChart등은 JavaFX에서 다양한 유형의 XY 평면 차트를 그리는 데 사용됩니다.

    이러한 클래스를 사용하여 애플리케이션에 차트를 포함 할 수 있습니다.

  • Pane − Pane은 다음과 같은 모든 레이아웃 창의 기본 클래스입니다. AnchorPane, BorderPane, DialogPane등.이 클래스는 다음과 같은 패키지에 속합니다- javafx.scene.layout.

    이러한 클래스를 사용하여 애플리케이션에 미리 정의 된 레이아웃을 삽입 할 수 있습니다.

  • Control − 다음과 같은 사용자 인터페이스 컨트롤의 기본 클래스입니다. Accordion, ButtonBar, ChoiceBox, ComboBoxBase, HTMLEditor, etc. This class belongs to the package javafx.scene.control.

    이러한 클래스를 사용하여 애플리케이션에 다양한 UI 요소를 삽입 할 수 있습니다.

그룹에서는 다음 프로그램과 같이 위에서 언급 한 클래스 중 하나를 인스턴스화하여 루트 노드로 사용할 수 있습니다.

//Creating a Stack Pane 
StackPane pane = new StackPane();       
       
//Adding text area to the pane  
ObservableList list = pane.getChildren(); 
list.add(NodeObject);

WebView −이 노드는 웹 엔진을 관리하고 그 내용을 표시합니다.

다음은 JavaFX의 노드 클래스 계층을 나타내는 다이어그램입니다.

장면 준비

JavaFX 장면은 Scene 패키지 클래스 javafx.scene. 다음 cod 블록에 표시된대로이 클래스를 인스턴스화하여 Scene을 생성 할 수 있습니다.

인스턴스화하는 동안 루트 개체를 장면 클래스의 생성자에 전달해야합니다.

Scene scene = new Scene(root);

또한 아래와 같이 장면의 높이와 너비를 나타내는 double 유형의 두 매개 변수를 전달할 수 있습니다.

Scene scene = new Scene(root, 600, 300);

무대 준비

이것은 모든 JavaFX 응용 프로그램의 컨테이너이며 응용 프로그램에 대한 창을 제공합니다. 그것은Stage 패키지 클래스 javafx.stage. 이 클래스의 객체는start() 의 방법 Application 수업.

이 개체를 사용하여 무대에서 다양한 작업을 수행 할 수 있습니다. 주로 다음을 수행 할 수 있습니다.

  • 방법을 사용하여 무대 제목 설정 setTitle().

  • 다음을 사용하여 장면 개체를 무대에 연결합니다. setScene() 방법.

  • 다음을 사용하여 장면의 내용을 표시합니다. show() 방법은 아래와 같습니다.

//Setting the title to Stage. 
primaryStage.setTitle("Sample application"); 
       
//Setting the scene to Stage 
primaryStage.setScene(scene); 
       
//Displaying the stage 
primaryStage.show();

JavaFX 응용 프로그램의 수명주기

JavaFX 애플리케이션 클래스에는 세 가지 라이프 사이클 메소드가 있습니다.

  • start() − JavaFX 그래픽 코드가 작성되는 진입 점 방법.

  • stop() − 재정의 할 수있는 빈 메서드. 여기에서 응용 프로그램을 중지하는 논리를 작성할 수 있습니다.

  • init() − 재정의 할 수있는 빈 방법이지만이 방법으로 무대 나 장면을 생성 할 수 없습니다.

이 외에도 다음과 같은 정적 메서드를 제공합니다. launch() JavaFX 응용 프로그램을 시작합니다.

이후 launch()메서드가 정적이면 정적 컨텍스트에서 호출해야합니다 (일반적으로 기본). JavaFX 응용 프로그램이 시작될 때마다 다음 작업이 동일한 순서로 수행됩니다.

  • 애플리케이션 클래스의 인스턴스가 생성됩니다.

  • Init() 메서드가 호출됩니다.

  • 그만큼 start() 메서드가 호출됩니다.

  • 런처는 애플리케이션이 완료 될 때까지 기다렸다가 stop() 방법.

JavaFX 응용 프로그램 종료

응용 프로그램의 마지막 창이 닫히면 JavaFX 응용 프로그램이 암시 적으로 종료됩니다. 정적 메서드에 부울 값 "False"를 전달하여이 동작을 끌 수 있습니다. setImplicitExit() (정적 컨텍스트에서 호출해야 함).

메소드를 사용하여 JavaFX 애플리케이션을 명시 적으로 종료 할 수 있습니다. Platform.exit() 또는 System.exit(int).

예 1 – 빈 창 만들기

이 섹션에서는 빈 창을 표시하는 JavaFX 샘플 응용 프로그램을 만드는 방법을 설명합니다. 다음은 단계입니다-

1 단계 : 클래스 생성

Java 클래스를 만들고 상속 Application 패키지 클래스 javafx.application 다음과 같이이 클래스의 start () 메서드를 구현합니다.

public class JavafxSample extends Application {  
   @Override     
   public void start(Stage primaryStage) throws Exception {      
   }    
}

2 단계 : 그룹 개체 만들기

에서 start() 메서드는 패키지에 속하는 Group이라는 클래스를 인스턴스화하여 그룹 개체를 만듭니다. javafx.scene, 다음과 같이.

Group root = new Group();

3 단계 : 장면 개체 만들기

라는 클래스를 인스턴스화하여 장면을 만듭니다. Scene 패키지에 속하는 javafx.scene. 이 클래스에 Group 객체를 전달합니다.(root), 이전 단계에서 생성되었습니다.

루트 객체 외에도 다음과 같이 Group 클래스의 객체와 함께 화면의 높이와 너비를 나타내는 두 개의 이중 매개 변수를 전달할 수 있습니다.

Scene scene = new Scene(root,600, 300);

4 단계 : 스테이지 제목 설정

다음을 사용하여 무대에 제목을 설정할 수 있습니다. setTitle() 의 방법 Stage수업. 그만큼primaryStage 씬 클래스의 시작 메서드에 매개 변수로 전달되는 Stage 객체입니다.

사용 primaryStage 개체, 장면의 제목을 Sample Application 아래 그림과 같이.

primaryStage.setTitle("Sample Application");

5 단계 : 무대에 장면 추가

방법을 사용하여 무대에 장면 개체를 추가 할 수 있습니다. setScene() 명명 된 클래스의 Stage. 아래와 같이이 방법을 사용하여 이전 단계에서 준비한 Scene 개체를 추가합니다.

primaryStage.setScene(scene);

6 단계 : 스테이지 내용 표시

이름이 지정된 방법을 사용하여 장면의 내용을 표시합니다. show()Stage 다음과 같이 수업.

primaryStage.show();

7 단계 : 애플리케이션 시작

정적 메서드를 호출하여 JavaFX 응용 프로그램을 시작합니다. launch()Application 다음과 같이 main 메소드에서 클래스.

public static void main(String args[]){   
   launch(args);      
}

다음 프로그램은 빈 JavaFX 창을 생성합니다. 이 코드를 이름으로 파일에 저장하십시오.JavafxSample.java

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.paint.Color; 
import javafx.stage.Stage;  

public class JavafxSample extends Application { 
   @Override     
   public void start(Stage primaryStage) throws Exception {            
      //creating a Group object 
      Group group = new Group(); 
       
      //Creating a Scene by passing the group object, height and width   
      Scene scene = new Scene(group ,600, 300); 
      
      //setting color to the scene 
      scene.setFill(Color.BROWN);  
      
      //Setting the title to Stage. 
      primaryStage.setTitle("Sample Application"); 
   
      //Adding the scene to Stage 
      primaryStage.setScene(scene); 
       
      //Displaying the contents of the stage 
      primaryStage.show(); 
   }    
   public static void main(String args[]){          
      launch(args);     
   }         
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac JavafxSample.java 
java JavafxSample

위 프로그램은 실행시 아래와 같이 JavaFX 창을 생성합니다.

예 2 – 직선 그리기

이전 예에서는 빈 스테이지를 만드는 방법을 보았습니다. 이제이 예에서는 JavaFX 라이브러리를 사용하여 직선을 그려 보겠습니다.

다음은 단계입니다-

1 단계 : 클래스 생성

Java 클래스를 만들고 상속 Application 패키지 클래스 javafx.application 및 구현 start() 이 클래스의 메서드는 다음과 같습니다.

public class DrawingLine extends Application {
   @Override     
   public void start(Stage primaryStage) throws Exception {     
   }    
}

2 단계 : 라인 생성

JavaFX에서 다음과 같은 클래스를 인스턴스화하여 줄을 만들 수 있습니다. Line 패키지에 속하는 javafx.scene.shape,이 클래스를 다음과 같이 인스턴스화하십시오.

//Creating a line object         
Line line = new Line();

3 단계 : 속성을 선에 설정

속성을 설정하여 XY 평면에 선을 그릴 좌표를 지정합니다. startX, startY, endXendY, 다음 코드 블록에 표시된대로 각각의 setter 메서드를 사용합니다.

line.setStartX(100.0); 
line.setStartY(150.0); 
line.setEndX(500.0); 
line.setEndY(150.0);

4 단계 : 그룹 개체 만들기

start () 메서드에서 패키지 javafx.scene에 속하는 Group이라는 클래스를 인스턴스화하여 그룹 객체를 만듭니다.

다음과 같이 그룹에 추가하기 위해 이전 단계에서 생성 된 Line (노드) 객체를 Group 클래스의 생성자에 매개 변수로 전달합니다.

Group root = new Group(line);

5 단계 : 장면 개체 만들기

라는 클래스를 인스턴스화하여 장면을 만듭니다. Scene 패키지에 속하는 javafx.scene. 이 클래스에 Group 객체를 전달합니다.(root) 이전 단계에서 생성되었습니다.

루트 객체 외에도 다음과 같이 Group 클래스의 객체와 함께 화면의 높이와 너비를 나타내는 두 개의 이중 매개 변수를 전달할 수 있습니다.

Scene scene = new Scene(group ,600, 300);

6 단계 : 스테이지 제목 설정

다음을 사용하여 무대에 제목을 설정할 수 있습니다. setTitle() 의 방법 Stage수업. 그만큼primaryStage 씬 클래스의 시작 메서드에 매개 변수로 전달되는 Stage 객체입니다.

사용 primaryStage 개체, 장면의 제목을 Sample Application 다음과 같이.

primaryStage.setTitle("Sample Application");

7 단계 : 무대에 장면 추가

방법을 사용하여 무대에 장면 개체를 추가 할 수 있습니다. setScene() 명명 된 클래스의 Stage. 다음과 같이이 방법을 사용하여 이전 단계에서 준비한 Scene 개체를 추가합니다.

primaryStage.setScene(scene);

8 단계 : 스테이지 내용 표시

이름이 지정된 방법을 사용하여 장면의 내용을 표시합니다. show()Stage 다음과 같이 수업.

primaryStage.show();

9 단계 : 애플리케이션 시작

정적 메서드를 호출하여 JavaFX 응용 프로그램을 시작합니다. launch()Application 다음과 같이 main 메소드에서 클래스.

public static void main(String args[]){   
   launch(args);      
}

다음 프로그램은 JavaFX를 사용하여 직선을 생성하는 방법을 보여줍니다. 이 코드를 이름으로 파일에 저장하십시오.JavafxSample.java.

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.shape.Line; 
import javafx.stage.Stage;  

public class DrawingLine extends Application{ 
   @Override 
   public void start(Stage stage) { 
      //Creating a line object 
      Line line = new Line(); 
         
      //Setting the properties to a line 
      line.setStartX(100.0); 
      line.setStartY(150.0); 
      line.setEndX(500.0); 
      line.setEndY(150.0); 
         
      //Creating a Group 
      Group root = new Group(line); 
         
      //Creating a Scene 
      Scene scene = new Scene(root, 600, 300); 
         
      //Setting title to the scene 
      stage.setTitle("Sample application"); 
         
      //Adding the scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of a scene 
      stage.show(); 
   }      
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac DrawingLine.java 
java DrawingLine

위의 프로그램을 실행하면 아래와 같이 직선을 표시하는 JavaFX 창이 생성됩니다.

예 3 – 텍스트 표시

JavaFX 장면에 텍스트를 포함 할 수도 있습니다. 이 예는 JavaFX에 텍스트를 포함하는 방법을 보여줍니다.

다음은 단계입니다-

1 단계 : 클래스 생성

Java 클래스를 생성하고 Application 패키지 클래스 javafx.application 및 구현 start() 이 클래스의 메서드는 다음과 같습니다.

public class DrawingLine extends Application {  
   @Override     
   public void start(Stage primaryStage) throws Exception {     
   } 
}

2 단계 : 텍스트 삽입

다음과 같은 클래스를 인스턴스화하여 JavaFX 장면에 텍스트를 포함 할 수 있습니다. Text 패키지에 속하는 javafx.scene.shape,이 클래스를 인스턴스화하십시오.

포함 할 텍스트를 String 형식으로 전달하여이 클래스를 인스턴스화 할 수 있습니다. 또는 아래와 같이 기본 생성자를 사용하여 텍스트 개체를 만들 수 있습니다.

//Creating a Text object 
Text text = new Text();

3 단계 : 글꼴 설정

다음을 사용하여 글꼴을 텍스트로 설정할 수 있습니다. setFont() 의 방법 Text수업. 이 메서드는 글꼴 개체를 매개 변수로받습니다. 주어진 텍스트의 글꼴을 아래와 같이 45로 설정합니다.

//Setting font to the text 
text.setFont(new Font(45));

4 단계 : 텍스트 위치 설정

각각의 setter 메서드를 사용하여 X, Y 좌표를 설정하여 XY 평면에서 텍스트의 위치를 ​​설정할 수 있습니다. setX()setY() 다음과 같이.

//setting the position of the text 
text.setX(50); 
text.setY(150);

5 단계 : 추가 할 텍스트 설정

Text 클래스의 setText () 메서드를 사용하여 추가 할 텍스트를 설정할 수 있습니다. 이 메서드는 추가 할 텍스트를 나타내는 문자열 매개 변수를받습니다.

text.setText("Welcome to Tutorialspoint");

6 단계 : 그룹 개체 만들기

에서 start() 메서드에서 패키지에 속하는 Group이라는 클래스를 인스턴스화하여 그룹 개체를 만듭니다. javafx.scene.

다음과 같이 그룹에 추가하기 위해 이전 단계에서 생성 된 Text (노드) 객체를 Group 클래스의 생성자에 매개 변수로 전달합니다.

Group root = new Group(text)

7 단계 : 장면 개체 만들기

라는 클래스를 인스턴스화하여 장면을 만듭니다. Scene 패키지에 속하는 javafx.scene. 이 클래스에 Group 객체를 전달합니다.(root), 이전 단계에서 생성되었습니다.

루트 객체 외에도 다음과 같이 Group 클래스의 객체와 함께 화면의 높이와 너비를 나타내는 두 개의 이중 매개 변수를 전달할 수 있습니다.

Scene scene = new Scene(group ,600, 300);

8 단계 : 스테이지 제목 설정

다음을 사용하여 무대에 제목을 설정할 수 있습니다. setTitle() 의 방법 Stage수업. 그만큼primaryStage 씬 클래스의 시작 메서드에 매개 변수로 전달되는 Stage 객체입니다.

사용 primaryStage 개체, 장면의 제목을 Sample Application 아래 그림과 같이.

primaryStage.setTitle("Sample Application");

9 단계 : 무대에 장면 추가

방법을 사용하여 무대에 장면 개체를 추가 할 수 있습니다. setScene() 명명 된 클래스의 Stage. 다음과 같이이 방법을 사용하여 이전 단계에서 준비한 Scene 개체를 추가합니다.

primaryStage.setScene(scene);

10 단계 : 스테이지 내용 표시

이름이 지정된 방법을 사용하여 장면의 내용을 표시합니다. show()Stage 다음과 같이 수업.

primaryStage.show();

11 단계 : 애플리케이션 시작

정적 메서드를 호출하여 JavaFX 응용 프로그램을 시작합니다. launch()Application 다음과 같이 main 메소드에서 클래스.

public static void main(String args[]){ 
   launch(args);      
}

다음은 JavaFX를 사용하여 텍스트를 표시하는 프로그램입니다. 이 코드를 이름이있는 파일에 저장DisplayingText.java.

import javafx.application.Application; 
import javafx.collections.ObservableList; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.stage.Stage; 
import javafx.scene.text.Font; 
import javafx.scene.text.Text; 
         
public class DisplayingText extends Application { 
   @Override 
   public void start(Stage stage) {       
      //Creating a Text object 
      Text text = new Text(); 
       
      //Setting font to the text 
      text.setFont(new Font(45)); 
       
      //setting the position of the text 
      text.setX(50); 
      text.setY(150);          
      
      //Setting the text to be added. 
      text.setText("Welcome to Tutorialspoint"); 
         
      //Creating a Group object  
      Group root = new Group(); 
       
      //Retrieving the observable list object 
      ObservableList list = root.getChildren(); 
       
      //Setting the text object as a node to the group object 
      list.add(text);       
               
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300); 
       
      //Setting title to the Stage 
      stage.setTitle("Sample Application"); 
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   }   
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac DisplayingText.java 
java DisplayingText

위의 프로그램을 실행하면 아래와 같이 텍스트를 표시하는 JavaFX 창이 생성됩니다.

이전 장에서 우리는 JavaFX의 기본 응용 프로그램을 보았습니다. 여기서 빈 창을 만드는 방법과 JavaFX의 XY 평면에 선을 그리는 방법을 배웠습니다. 선 외에도 몇 가지 다른 2D 모양을 그릴 수도 있습니다.

2D 모양

일반적으로 2D 도형은 XY 평면에 그릴 수있는 기하학적 도형으로 Line, Rectangle, Circle 등이 있습니다.

JavaFX 라이브러리를 사용하여 그릴 수 있습니다.

  • Line, Rectangle, Circle, Ellipse, Polygon, Polyline, Cubic Curve, Quad Curve, Arc와 같은 미리 정의 된 모양.

  • MoveTO Path Element, Line, Horizontal Line, Vertical Line, Cubic Curve, Quadratic Curve, Arc와 같은 경로 요소.

  • 이 외에도 SVG 경로를 구문 분석하여 2D 모양을 그릴 수도 있습니다.

위에서 언급 한 각 2D 모양은 클래스로 표현되며 이러한 모든 클래스는 패키지에 속합니다. javafx.scene.shape. 명명 된 클래스Shape JavaFX의 모든 2 차원 도형의 기본 클래스입니다.

2D 모양 만들기

차트를 만들려면 다음을 수행해야합니다.

  • 필요한 셰이프의 각 클래스를 인스턴스화합니다.
  • 도형의 속성을 설정합니다.
  • 그룹에 모양 개체를 추가합니다.

각 클래스 인스턴스화

2 차원 모양을 만들려면 먼저 해당 클래스를 인스턴스화해야합니다.

예를 들어, 라인을 생성하려면 다음과 같이 Line이라는 클래스를 인스턴스화해야합니다.

Line line = new Line();

모양의 속성 설정

클래스를 인스턴스화 한 후 setter 메서드를 사용하여 셰이프의 속성을 설정해야합니다.

예를 들어 선을 그리려면 선의 시작점과 끝점의 x 및 y 좌표를 전달해야합니다. 다음과 같이 각각의 setter 메서드를 사용하여 이러한 값을 지정할 수 있습니다.

//Setting the Properties of the Line 
line.setStartX(150.0f); 
line.setStartY(140.0f);         
line.setEndX(450.0f); 
line.setEndY(140.0f);

그룹에 모양 개체 추가

마지막으로 아래와 같이 생성자의 매개 변수로 전달하여 모양의 객체를 그룹에 추가해야합니다.

//Creating a Group object  
Group root = new Group(line);

다음 표는 JavaFX에서 제공하는 다양한 모양 (클래스) 목록을 제공합니다.

S. 아니 모양 및 설명
1

선은 두 점을 연결하는 기하학적 구조입니다. 그만큼Line 패키지 클래스 javafx.scene.shape XY 평면의 선을 나타냅니다.

2 직사각형

일반적으로 직사각형은 모든 내부 각도가 직각 인 두 쌍의 평행 및 동시 변이있는 4면 다각형입니다. JavaFX에서 Rectangle은 다음과 같은 클래스로 표시됩니다.Rectangle. 이 클래스는 패키지에 속합니다.javafx.scene.shape.

둥근 직사각형

JavaFX에서는 날카로운 모서리 또는 아치형 모서리가있는 사각형을 그릴 수 있으며 아치형 모서리가있는 사각형을 둥근 사각형이라고합니다.

4

원은 중심점에서 고정 된 거리에있는 모든 점이 닫힌 루프를 형성하는 선입니다. JavaFX에서 원은 다음과 같은 클래스로 표시됩니다.Circle. 이 클래스는 패키지에 속합니다.javafx.scene.shape.

5 타원

타원은 각각 초점이라고하는 두 점으로 정의됩니다. 타원의 한 점을 찍으면 초점 점까지의 거리 합계가 일정합니다. 타원의 크기는이 두 거리의 합으로 결정됩니다.

JavaFX에서 타원은 다음과 같은 클래스로 표시됩니다. Ellipse. 이 클래스는 패키지에 속합니다.javafx.scene.shape.

6 다각형

끝에서 끝까지 연결된 다수의 동일 평면상의 선 세그먼트로 형성된 닫힌 모양입니다. JavaFX에서 다각형은 다음과 같은 클래스로 표현됩니다.Polygon. 이 클래스는 패키지에 속합니다.javafx.scene.shape.

7 폴리 라인

폴리 라인은 폴리 라인이 끝이 닫히지 않는다는 점을 제외하면 폴리곤과 동일합니다. 또는 하나 이상의 선분으로 구성된 연속 선입니다. JavaFX에서 Polyline은 다음과 같은 클래스로 표시됩니다.Polygon. 이 클래스는 패키지에 속합니다.javafx.scene.shape.

8 큐빅 곡선

3 차 곡선은 XY 평면의 베 지어 매개 변수 곡선입니다. JavaFX에서 3 차 곡선은 다음과 같은 클래스로 표현됩니다. CubicCurve. 이 클래스는 패키지에 속합니다.javafx.scene.shape.

9 쿼드 커브

2 차 곡선은 XY 평면에서 베 지어 매개 변수 곡선입니다. 2 차 곡선입니다. JavaFX에서 QuadCurve는 QuadCurve라는 클래스로 표시됩니다. 이 클래스는 패키지에 속합니다.javafx.scene.shape.

10

호는 곡선의 일부입니다. JavaFX에서 호는 다음과 같은 클래스로 표시됩니다.Arc. 이 클래스는 패키지에 속합니다-javafx.scene.shape.

호의 종류

이 외에도 세 가지 유형의 호를 그릴 수 있습니다. Open, Chord, Round.

11 SVGPath

JavaFX에서는 SVG 경로를 구문 분석하여 이미지를 구성 할 수 있습니다. 이러한 모양은 다음과 같은 클래스로 표현됩니다.SVGPath. 이 클래스는 패키지에 속합니다.javafx.scene.shape. 이 클래스에는content문자열 데이터 유형의. 이미지를 그려야하는 SVG 경로 인코딩 문자열을 나타냅니다.

경로 클래스를 통해 더 많은 모양 그리기

이전 섹션에서는 클래스를 인스턴스화하고 각 매개 변수를 설정하여 미리 정의 된 간단한 모양을 그리는 방법을 살펴 보았습니다.

그러나 이러한 미리 정의 된 모양만으로는에서 제공하는 기본 요소 이외의 복잡한 모양을 만들기에 충분하지 않습니다. javafx.shape package.

예를 들어, 다음 다이어그램과 같이 그래픽 요소를 그리려는 경우 이러한 단순한 모양에 의존 할 수 없습니다.

경로 클래스

이러한 복잡한 구조를 그리기 위해 JavaFX는 Path. 이 클래스는 도형의 기하학적 윤곽을 나타냅니다.

다양한 정보를 담고있는 관찰 가능한 목록에 첨부됩니다. Path Elements moveTo, LineTo, HlineTo, VlineTo, ArcTo, QuadCurveTo, CubicCurveTo 등.

인스턴스화 할 때이 클래스는 지정된 경로 요소를 기반으로 경로를 구성합니다.

다음과 같이 인스턴스화하는 동안 경로 요소를이 클래스에 전달할 수 있습니다.

Path myshape = new Path(pathElement1, pathElement2, pathElement3);

또는 관찰 가능한 목록을 얻고 다음을 사용하여 모든 경로 요소를 추가 할 수 있습니다. addAll() 다음과 같이 방법-

Path myshape = new Path(); 
myshape.getElements().addAll(pathElement1, pathElement2, pathElement3);

add () 메서드를 사용하여 요소를 개별적으로 추가 할 수도 있습니다.

Path myshape = new Path(); 
myshape.getElements().add(pathElement1);

경로로 이동 요소

경로 요소 MoveTo경로의 현재 위치를 지정된 지점으로 이동하는 데 사용됩니다. 일반적으로 경로 요소를 사용하여 그린 모양의 시작점을 설정하는 데 사용됩니다.

다음과 같은 클래스로 표시됩니다. LineTo 패키지의 javafx.scene.shape. 즉, 이중 데이터 유형의 두 가지 속성이 있습니다-

  • X − 현재 위치에서 선이 그려 질 지점의 x 좌표.

  • Y − 현재 위치에서 선이 그려 질 지점의 y 좌표.

MoveTo 클래스를 인스턴스화하고 다음과 같이 새 지점의 x, y 좌표를 전달하여 경로로 이동 요소를 만들 수 있습니다.

MoveTo moveTo = new MoveTo(x, y);

생성자에 값을 전달하지 않으면 새 점이 (0,0)으로 설정됩니다.

다음과 같이 각각의 setter 메서드를 사용하여 x, y 좌표로 값을 설정할 수도 있습니다.

setX(value); 
setY(value);

예 – 복잡한 경로 그리기

이 예에서는 다음을 사용하여 다음 모양을 그리는 방법을 보여줍니다. Path, MoveToLine 클래스.

이 코드를 이름으로 파일에 저장하십시오. ComplexShape.java.

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.stage.Stage; 
import javafx.scene.shape.LineTo; 
import javafx.scene.shape.MoveTo; 
import javafx.scene.shape.Path; 
         
public class ComplexShape extends Application { 
   @Override 
   public void start(Stage stage) { 
      //Creating a Path 
      Path path = new Path(); 
       
      //Moving to the starting point 
      MoveTo moveTo = new MoveTo(108, 71); 
        
      //Creating 1st line 
      LineTo line1 = new LineTo(321, 161);  
       
      //Creating 2nd line 
      LineTo line2 = new LineTo(126,232);       
       
      //Creating 3rd line 
      LineTo line3 = new LineTo(232,52);  
       
      //Creating 4th line 
      LineTo line4 = new LineTo(269, 250);   
       
      //Creating 4th line 
      LineTo line5 = new LineTo(108, 71);  
       
      //Adding all the elements to the path 
      path.getElements().add(moveTo); 
      path.getElements().addAll(line1, line2, line3, line4, line5);        
         
      //Creating a Group object  
      Group root = new Group(path); 
         
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300);  
      
      //Setting title to the Stage 
      stage.setTitle("Drawing an arc through a path");
      
      //Adding scene to the stage 
      stage.setScene(scene);
      
      //Displaying the contents of the stage 
      stage.show();         
   } 
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac ComplexShape.java 
java ComplexShape

위 프로그램은 실행시 아래 그림과 같이 현재 위치에서 지정된 지점까지 그려지는 호를 표시하는 JavaFX 창을 생성합니다.

다음은 JavaFX에서 제공하는 다양한 경로 요소 (클래스)입니다. 이러한 클래스는 패키지에 있습니다.javafx.shape. 이 모든 클래스는 클래스를 상속합니다.PathElement.

S. 아니 모양 및 설명
1 LineTo

경로 요소 line현재 위치에서 지정된 좌표의 점까지 직선을 그리는 데 사용됩니다. 다음과 같은 클래스로 표시됩니다.LineTo. 이 클래스는 패키지에 속합니다.javafx.scene.shape.

2 HlineTo

경로 요소 HLineTo현재 위치에서 지정된 좌표의 점까지 수평선을 그리는 데 사용됩니다. 다음과 같은 클래스로 표시됩니다.HLineTo. 이 클래스는 패키지에 속합니다.javafx.scene.shape.

VLineTo

경로 요소 vertical line현재 위치에서 지정된 좌표의 점까지 수직선을 그리는 데 사용됩니다. 다음과 같은 클래스로 표시됩니다.VLineTo. 이 클래스는 패키지에 속합니다.javafx.scene.shape.

4 QuadCurveTo

경로 요소 2 차 곡선을 사용하여 quadratic curve현재 위치에서 지정된 좌표의 한 지점으로. 다음과 같은 클래스로 표시됩니다.QuadraticCurveTo. 이 클래스는 패키지에 속합니다.javafx.scene.shape.

5 CubicCurveTo

경로 요소 cubic curve현재 위치에서 지정된 좌표의 점으로 3 차 곡선을 그리는 데 사용됩니다. 다음과 같은 클래스로 표시됩니다.CubicCurveTo. 이 클래스는 패키지에 속합니다.javafx.scene.shape.

6 ArcTo

경로 요소 Arc현재 위치에서 지정된 좌표의 점으로 호를 그리는 데 사용됩니다. 다음과 같은 클래스로 표시됩니다.ArcTo. 이 클래스는 패키지에 속합니다.javafx.scene.shape.

2D 개체의 속성

모든 2D 객체에 대해 채우기, 스트로크, StrokeType 등과 같은 다양한 속성을 설정할 수 있습니다. 다음 섹션에서는 2D 객체의 다양한 속성에 대해 설명합니다.

  • 스트로크 유형
  • 스트로크 폭
  • 스트로크 채우기
  • Stroke
  • 스트로크 라인
  • 스트로크 마이 터 한계
  • 스트로크 라인 캡
  • Smooth

2D 개체에 대한 작업

그룹에 둘 이상의 도형을 추가하면 아래와 같이 첫 번째 도형이 두 번째 도형과 겹칩니다.

변형 (회전, 크기 조절, 변환 등), 전환 (애니메이션) 외에도 2D 개체에 대해 다음과 같은 세 가지 작업을 수행 할 수 있습니다. Union, SubtractionIntersection.

S. 아니 작동 및 설명
1 조합 운영

이 작업은 두 개 이상의 셰이프를 입력으로 사용하고 그 셰이프가 차지하는 영역을 반환합니다.

2 교차로 운영

이 작업은 두 개 이상의 셰이프를 입력으로 사용하고 그 사이의 교차 영역을 반환합니다.

빼기 연산

이 작업은 두 개 이상의 셰이프를 입력으로 사용합니다. 그런 다음 두 번째 도형과 겹치는 영역을 제외한 첫 번째 도형의 영역을 반환합니다.

다양한 모양과 마찬가지로 JavaFX에서 텍스트 노드를 만들 수도 있습니다. 텍스트 노드는 다음과 같은 클래스로 표시됩니다.Text, 패키지에 속하는 javafx.scene.text.

이 클래스에는 JavaFX에서 텍스트를 만들고 모양을 수정하는 여러 속성이 포함되어 있습니다. 이 클래스는 패키지에 속하는 Shape 클래스도 상속합니다.javafx.scene.shape.

따라서 글꼴, 정렬, 줄 간격, 텍스트 등과 같은 텍스트 속성 외에도 다음과 같은 기본 모양 노드 속성을 상속합니다. strokeFill, stroke, strokeWidth, strokeType, 기타

텍스트 노드 만들기

패키지의 클래스 Text 이후 javafx.scene.text JavaFX의 텍스트 노드를 나타내며 다음과 같이이 클래스를 인스턴스화하여 텍스트를 만들 수 있습니다.

Text text = new Text();

Text 클래스에는 text 작성할 텍스트를 나타내는 문자열 유형입니다.

Text 클래스를 인스턴스화 한 후 다음을 사용하여이 속성에 값을 설정해야합니다. setText() 방법은 아래와 같습니다.

String text = "Hello how are you" 
Text.setText(text);

각각의 setter 메서드를 사용하여 속성 x 및 y에 값을 지정하여 텍스트의 위치 (원점)를 설정할 수도 있습니다. setX()setY() 다음 코드 블록에서 볼 수 있듯이-

text.setX(50); 
text.setY(50);

다음 프로그램은 JavaFX에서 텍스트 노드를 만드는 방법을 보여주는 예제입니다. 이 코드를 이름이있는 파일에 저장TextExample.java.

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene;
import javafx.stage.Stage; 
import javafx.scene.text.Text; 
         
public class TextExample extends Application { 
   @Override 
   public void start(Stage stage) {       
      //Creating a Text object 
      Text text = new Text();      
      
      //Setting the text to be added. 
      text.setText("Hello how are you"); 
       
      //setting the position of the text 
      text.setX(50); 
      text.setY(50); 
         
      //Creating a Group object  
      Group root = new Group(text);   
               
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300);  
      
      //Setting title to the Stage 
      stage.setTitle("Sample Application"); 
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   }      
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac TextExample.java 
java TextExample

실행시 위의 프로그램은 다음과 같이 지정된 텍스트를 표시하는 JavaFX 창을 생성합니다.

텍스트의 위치 및 글꼴

기본적으로 텍스트 클래스에 의해 생성되는 텍스트는 글꼴…, 크기… 및 검정색 색상입니다.

다음을 사용하여 텍스트의 글꼴 크기와 색상을 변경할 수 있습니다. setFont()방법. 이 메서드는Font 수업.

명명 된 클래스 Font 패키지의 javafx.scene.text텍스트의 글꼴을 정의하는 데 사용됩니다. 이 클래스에는font().

이 방법은 네 개의 매개 변수를받습니다.

  • family − 이것은 문자열 유형이며 텍스트에 적용하려는 글꼴 패밀리를 나타냅니다.

  • weight−이 속성은 글꼴의 두께를 나타냅니다. 9 개의 값을 허용합니다.FontWeight.BLACK, FontWeight.BOLD, FontWeight.EXTRA_BOLD, FontWeight.EXTRA_LIGHT, LIGHT, MEDIUM, NORMAL, SEMI_BOLD, THIN.

  • posture−이 속성은 글꼴 자세 (일반 또는 기울임 꼴)를 나타냅니다. 두 가지 값을 허용합니다.FontPosture.REGULARFontPosture.ITALIC.

  • size −이 속성은 double 유형이며 글꼴의 크기를 나타냅니다.

다음 방법을 사용하여 텍스트에 글꼴을 설정할 수 있습니다-

text.setFont(Font.font("verdana", FontWeight.BOLD, FontPosture.REGULAR, 20));

다음 프로그램은 JavaFX에서 텍스트 노드의 글꼴을 설정하는 방법을 보여주는 예제입니다. 여기서는 글꼴을 Verdana로, 두께를 굵게, 자세를 보통으로, 크기를 20으로 설정합니다.

이 코드를 이름으로 파일에 저장하십시오. TextFontExample.java.

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.stage.Stage; 
import javafx.scene.text.Font; 
import javafx.scene.text.FontPosture; 
import javafx.scene.text.FontWeight; 
import javafx.scene.text.Text; 
         
public class TextFontExample extends Application { 
   @Override 
   public void start(Stage stage) {       
      //Creating a Text object 
      Text text = new Text(); 
        
      //Setting font to the text 
      text.setFont(Font.font("verdana", FontWeight.BOLD, FontPosture.REGULAR, 20)); 
       
      //setting the position of the text
      text.setX(50); 
      text.setY(130);          
      
      //Setting the text to be added. 
      text.setText("Hi how are you"); 
         
      //Creating a Group object  
      Group root = new Group(text);   
               
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300);  
      
      //Setting title to the Stage 
      stage.setTitle("Setting Font to the text"); 
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   }      
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac TextFontExample.java 
java TextFontExample

실행시 위의 프로그램은 다음과 같이 지정된 글꼴로 텍스트를 표시하는 JavaFX 창을 생성합니다.

획과 색상

Text 클래스는 패키지의 Shape 클래스도 상속합니다. 따라서 다음을 사용할 수 있습니다.javafx.scene.shape 획과 색상을 텍스트 노드에도 설정할 수 있습니다.

텍스트에 색상을 설정할 수 있습니다. setFill() 다음과 같이 모양 (상속 된) 클래스의 방법-

text.setFill(Color.BEIGE);

마찬가지로 방법을 사용하여 텍스트의 획 색상을 설정할 수 있습니다. setStroke(). 획의 너비는 방법을 사용하여 설정할 수 있지만setStrokeWidth() 다음과 같이-

//Setting the color 
text.setFill(Color.BROWN); 
        
//Setting the Stroke  
text.setStrokeWidth(2); 
       
//Setting the stroke color 
text.setStroke(Color.BLUE);

다음 프로그램은 텍스트 노드의 색상, strokeWidth 및 strokeColor를 설정하는 방법을 보여주는 예제입니다. 이 코드에서는 획 색상을 – 파란색으로, 텍스트 색상을 – 갈색으로, 획 너비를 – 2로 설정합니다.

이 코드를 이름으로 파일에 저장하십시오. StrokeExample.java.

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.paint.Color; 
import javafx.stage.Stage; 
import javafx.scene.text.Font; 
import javafx.scene.text.FontPosture; 
import javafx.scene.text.FontWeight; 
import javafx.scene.text.Text; 
         
public class StrokeExample extends Application { 
   @Override 
   public void start(Stage stage) {       
      //Creating a Text object 
      Text text = new Text(); 
       
      //Setting font to the text 
      text.setFont(Font.font("verdana", FontWeight.BOLD, FontPosture.REGULAR, 50)); 
       
      //setting the position of the text  
      text.setX(50); 
      text.setY(130);     
       
      //Setting the color 
      text.setFill(Color.BROWN); 
       
      //Setting the Stroke  
      text.setStrokeWidth(2); 
      
      // Setting the stroke color
      text.setStroke(Color.BLUE);        
      
      //Setting the text to be added. 
      text.setText("Hi how are you"); 
         
      //Creating a Group object  
      Group root = new Group(text);   
               
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300);  
      
      //Setting title to the Stage 
      stage.setTitle("Setting font to the text"); 
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   }      
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac StrokeExample.java 
java StrokeExample

실행시 위의 프로그램은 다음과 같이 지정된 스트로크 및 색상 속성을 가진 텍스트를 표시하는 JavaFX 창을 생성합니다.

텍스트에 장식 적용

스트라이크 스루와 같은 장식을 적용 할 수도 있습니다. 이 경우 텍스트를 통해 행이 전달됩니다. 다음 방법을 사용하여 텍스트에 밑줄을 긋을 수 있습니다.Text 수업.

방법을 사용하여 텍스트를 취소 할 수 있습니다. setStrikethrough(). 이것은 부울 값을 받아들이고 값을 전달합니다.true 이 방법으로 다음 코드 상자에 표시된대로 텍스트를 뚫습니다.

//Striking through the text 
text1.setStrikethrough(true);

같은 방식으로 값을 전달하여 텍스트에 밑줄을 긋을 수 있습니다. true 방법에 setUnderLine() 다음과 같이-

//underlining the text     
text2.setUnderline(true);

다음 프로그램은 다음과 같은 장식을 적용하는 방법을 보여주는 예제입니다. underline 또는 strike through텍스트에. 이 코드를 이름으로 파일에 저장하십시오.DecorationsExample.java.

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.stage.Stage; 
import javafx.scene.text.Font; 
import javafx.scene.text.FontPosture;
import javafx.scene.text.FontWeight; 
import javafx.scene.text.Text; 
         
public class DecorationsExample extends Application { 
   @Override 
   public void start(Stage stage) {       
      //Creating a Text_Example object 
      Text text1 = new Text("Hi how are you");       
      
      //Setting font to the text 
      text1.setFont(Font.font("verdana", FontWeight.BOLD, FontPosture.REGULAR, 20));
      
      //setting the position of the text 
      text1.setX(50); 
      text1.setY(75);     
      
      //Striking through the text 
      text1.setStrikethrough(true); 
       
      //Creating a Text_Example object  
      Text text2 = new Text("Welcome to Tutorialspoint");     
      
      //Setting font to the text 
      text2.setFont(Font.font("verdana", FontWeight.BOLD, FontPosture.REGULAR, 20));
      
      //setting the position of the text 
      text2.setX(50); 
      text2.setY(150);      
      
      //underlining the text     
      text2.setUnderline(true);  
         
      //Creating a Group object  
      Group root = new Group(text1, text2);   
               
      //Creating a scene object
      Scene scene = new Scene(root, 600, 300);  
      
      //Setting title to the Stage 
      stage.setTitle("Decorations Example"); 
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   }      
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac DecorationsExample.java 
java DecorationsExample

실행시 위의 프로그램은 아래와 같이 JavaFX 창을 생성합니다.

효과는 그래픽의 모양을 향상시키는 모든 동작입니다. JavaFX에서 효과는 시각적으로 모양을 향상시키기 위해 노드에 적용되는 알고리즘입니다. 효과 속성Node 클래스는 효과를 지정하는 데 사용됩니다.

JavaFX에서는 다음과 같은 노드에 다양한 효과를 설정할 수 있습니다. bloom, blurglow. 이러한 각 효과는 클래스로 표시되며 이러한 모든 클래스는javafx.scene.effect.

노드에 효과 적용

다음을 사용하여 노드에 효과를 적용 할 수 있습니다. setEffect()방법. 이 방법을 사용하려면 효과의 개체를 전달해야합니다.

노드에 효과를 적용하려면 다음을 수행해야합니다.

  • 노드를 만듭니다.

  • 적용해야하는 효과의 각 클래스를 인스턴스화합니다.

  • 효과의 속성을 설정합니다.

  • 다음을 사용하여 노드에 효과를 적용합니다. setEffect() 방법.

노드 생성

우선, 각각의 클래스를 인스턴스화하여 JavaFX 응용 프로그램에서 노드를 만듭니다.

예를 들어 응용 프로그램의 이미지에 광선 효과를 적용하려는 경우입니다. 먼저 Image 클래스를 인스턴스화하여 이미지 노드를 생성하고 아래와 같이 뷰를 설정해야합니다.

//Creating an image 
Image image = new Image("https://www.tutorialspoint.com/green/images/logo.png"); 
       
//Setting the image view 
ImageView imageView = new ImageView(image); 

//Setting the position of the image 
imageView.setX(100); 
imageView.setY(70);  

//setting the fit height and width of the image view 
imageView.setFitHeight(200);
imageView.setFitWidth(400); 

//Setting the preserve ratio of the image view 
imageView.setPreserveRatio(true);

각 클래스 인스턴스화

생성 된 노드에 적용해야하는 효과를 나타내는 클래스를 인스턴스화합니다.

예 : 글로우 효과를 적용하려면 다음을 인스턴스화해야합니다. Glow 다음 코드 상자에 표시된 클래스-

Glow glow = new Glow();

효과의 속성 설정

클래스를 인스턴스화 한 후에는 setter 메서드를 사용하여 효과에 대한 속성을 설정해야합니다.

예 : 3 차원 상자를 그리려면 너비, 높이 및 깊이를 전달해야합니다. 아래와 같이 각각의 setter 메서드를 사용하여 이러한 값을 지정할 수 있습니다.

//setting the level property 
glow.setLevel(0.9);

노드에 효과 추가

마지막으로 다음을 사용하여 노드에 필요한 효과를 적용 할 수 있습니다. setEffect()방법. 예 : 이미지 노드에 글로우 효과를 설정하려면 다음과 같이 Glow 클래스의 객체를이 메서드에 전달해야합니다.

imageView.setEffect(glow);

JavaFX Effects− 다음 표는 JavaFX에서 제공하는 다양한 효과 (클래스) 목록을 제공합니다. 이러한 클래스는 다음과 같은 패키지에 있습니다.javafx.scene.effect.

S. 아니 모양 및 설명
1 색상 조정

색상 조정 효과를 적용하여 이미지의 색상을 조정할 수 있습니다. 여기에는 조정이 포함됩니다.hue, saturation, brightnesscontrast 각 픽셀에

명명 된 클래스 ColorAdjust 패키지의 javafx.scene.effect 색상 조정 효과를 나타냅니다.

2 색상 입력

색상 입력 효과는 직사각형을 그리고 색상으로 채우는 것과 동일한 출력을 제공합니다. 다른 효과와 달리이 효과를 노드에 적용하면 노드가 아닌 사각형 상자 만 표시됩니다. 이 효과는 주로 다른 효과의 입력으로 전달하는 데 사용됩니다.

명명 된 클래스 ColorInput 패키지의 javafx.scene.effect 색상 입력 효과를 나타냅니다.

이미지 입력

JavaFX의 이미지 입력 ​​효과는 JavaFX 화면에 이미지를 포함합니다.

색상 입력 효과 (지정된 색상 사각형 영역을 다른 효과에 대한 입력으로 전달하는 데 사용됨)와 마찬가지로 이미지 입력 ​​효과는 지정된 이미지를 다른 효과에 대한 입력으로 전달하는 데 사용됩니다.

명명 된 클래스 ImageInput 패키지의 javafx.scene.effect 이미지 입력 ​​효과를 나타냅니다.

4 혼합

일반적으로 블렌드는 둘 이상의 다른 사물이나 물질의 혼합물을 의미합니다. 이 블렌드 효과를 적용하면 동일한 위치에있는 두 개의 서로 다른 입력의 픽셀을 가져 와서blend mode.

명명 된 클래스 Blend 패키지의 javafx.scene.effect 혼합 효과를 나타냅니다.

5

블룸 효과를 적용하면 노드의 일부 부분에있는 픽셀이 빛나게됩니다.

명명 된 클래스 Bloom 패키지의 javafx.scene.effect 블룸 효과를 나타냅니다.

6 불타는 듯한 빛깔

블룸처럼 글로우 효과는 주어진 입력 이미지를 빛나게하고,이 효과는 입력의 밝은 픽셀을 더 밝게 만듭니다.

명명 된 클래스 Glow 패키지의 javafx.scene.effect 글로우 효과를 나타냅니다.

7 박스 블러

이 흐림 효과를 노드에 적용하면 명확하지 않습니다. Box blur는 JavaFX에서 제공하는 일종의 흐림 효과입니다. 이 효과에서 노드에 블러를 적용 할 때 간단한 상자 필터가 사용됩니다.

명명 된 클래스 BoxBlur 패키지의 javafx.scene.effect boxblur 효과를 나타냅니다.

8 가우스 흐림

Box Blur Gaussian이 JavaFX에서 노드를 흐리게하는 효과와 마찬가지로. 유일한 차이점은Gaussian Blur effect 블러 링 효과를 내기 위해 가우스 컨볼 루션 커널이 사용된다는 것입니다.

패키지의 GaussianBlur 클래스 javafx.scene.effect 가우시안 블러 효과를 나타냅니다.

9 MotionBlur

Gaussian Effects와 마찬가지로 Motion Blur는 JavaFX에서 노드를 흐리게하는 효과입니다. 또한 가우시안 컨볼 루션 커널을 사용하여 블러 링 효과를 생성하지만이 효과에서 차이는 가우스 컨볼 루션 커널이 지정된 각도로 사용된다는 것입니다.

명명 된 클래스 MotionBlur 패키지의 javafx.scene.effect 모션 블러 효과를 나타냅니다.

10 반사

JavaFX의 노드에 리플렉션 효과를 적용하면 노드 하단에 리플렉션 효과가 추가됩니다.

명명 된 클래스 Reflection 패키지의 javafx.scene.effect 반사 효과를 나타냅니다.

11 세피아 톤

JavaFX (일반 이미지)의 노드에 세피아 톤 효과를 적용하면 적갈색으로 톤이 표시됩니다.

명명 된 클래스 SepiaTone 패키지의 javafx.scene.effect 세피아 톤 효과를 나타냅니다.

12 그림자

이 효과는 가장자리가 흐릿한 지정된 노드의 복제본을 만듭니다.

명명 된 클래스 Shadow 패키지의 javafx.scene.effect 세피아 톤 효과를 나타냅니다.

13 그림자

이 효과를 노드에 적용하면 지정된 노드 뒤에 그림자가 생성됩니다.

명명 된 클래스 DropShadow 패키지의 javafx.scene.effect 그림자 효과를 나타냅니다.

14 내부 그림자

이 효과를 노드에 적용하면 노드 가장자리 내부에 그림자가 생성됩니다.

명명 된 클래스 InnerShadow 패키지의 javafx.scene.effect 내부 그림자 효과를 나타냅니다.

15 조명

조명 효과는 광원에서 나오는 빛을 시뮬레이션하는 데 사용됩니다. 다른 종류의 광원이 있습니다.point, distantspot.

명명 된 클래스 Lighting 패키지의 javafx.scene.effect 조명 효과를 나타냅니다.

16 빛. 먼

이 효과를 노드에 적용하면 마치 멀리있는 광원에서 생성되는 것처럼 광원이 노드에 시뮬레이션됩니다.

Distant Light Source− 노드에서 멀리 떨어진 소스. 여기에서 빛은 광원에서 한 방향으로 감쇠됩니다.

명명 된 클래스 Light.Distant 패키지의 javafx.scene.effect 먼 광원을 나타냅니다.

17 Light.Spot

이 효과를 노드에 적용하면 스포트 라이트에 의해 생성되는 것처럼 라이트가 시뮬레이션됩니다.

Spot light Source−이 광원의 빛은 모든 방향에서 감쇠됩니다. 빛의 강도는 광원에서 물체까지의 거리에 따라 다릅니다.

명명 된 클래스 Light.Spot 패키지의 javafx.scene.effect 먼 광원을 나타냅니다.

18 Point.Spot

이 효과를 노드에 적용하면 마치 포인트 라이트 소스에서 생성되는 것처럼 라이트가 시뮬레이션됩니다.

Point Light Source−이 광원의 빛은 단일 지점에서 모든 방향으로 감쇠됩니다. 빛의 강도는 광원에서 물체까지의 거리에 따라 다릅니다.

명명 된 클래스 Point.Spot 패키지 javafx.scene.effect는 포인트 라이트를 나타냅니다.

변환은 규칙을 적용하여 일부 그래픽을 다른 것으로 변경하는 것을 의미합니다. 우리는 다음과 같은 다양한 유형의 변형을 가질 수 있습니다.Translation, Scaling Up or Down, Rotation, Shearing, 기타

JavaFX를 사용하여 회전, 크기 조정 및 변환과 같은 변환을 노드에 적용 할 수 있습니다. 이러한 모든 변환은 다양한 클래스로 표현되며 패키지에 속합니다.javafx.scene.transform.

S. 아니 변형 및 설명
1 회전

회전에서 우리는 물체를 특정 각도로 회전시킵니다. θ (theta) 그 기원에서.

2 스케일링

개체의 크기를 변경하려면 크기 조정 변환이 사용됩니다.

번역

개체를 화면의 다른 위치로 이동합니다.

4 전단

물체의 모양을 기울이는 변형을 전단 변형이라고합니다.

여러 변환

JavaFX의 노드에 여러 변환을 적용 할 수도 있습니다. 다음 프로그램은 다음을 수행하는 예입니다.Rotation, ScalingTranslation 동시에 직사각형에 대한 변형.

이 코드를 이름으로 파일에 저장하십시오-

MultipleTransformationsExample.java.

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.paint.Color; 
import javafx.scene.shape.Rectangle; 
import javafx.scene.transform.Rotate; 
import javafx.scene.transform.Scale; 
import javafx.scene.transform.Translate; 
import javafx.stage.Stage; 
         
public class MultipleTransformationsExample extends Application { 
   @Override 
   public void start(Stage stage) { 
      //Drawing a Rectangle
      Rectangle rectangle = new Rectangle(50, 50, 100, 75); 
      
      //Setting the color of the rectangle 
      rectangle.setFill(Color.BURLYWOOD); 
      
      //Setting the stroke color of the rectangle 
      rectangle.setStroke(Color.BLACK); 
       
      //creating the rotation transformation 
      Rotate rotate = new Rotate(); 
      
      //Setting the angle for the rotation 
      rotate.setAngle(20); 
      
      //Setting pivot points for the rotation 
      rotate.setPivotX(150); 
      rotate.setPivotY(225); 
       
      //Creating the scale transformation 
      Scale scale = new Scale(); 
      
      //Setting the dimensions for the transformation 
      scale.setX(1.5); 
      scale.setY(1.5); 
      
      //Setting the pivot point for the transformation 
      scale.setPivotX(300); 
      scale.setPivotY(135); 
       
      //Creating the translation transformation 
      Translate translate = new Translate();       
      
      //Setting the X,Y,Z coordinates to apply the translation 
      translate.setX(250); 
      translate.setY(0); 
      translate.setZ(0); 
       
      //Adding all the transformations to the rectangle 
      rectangle.getTransforms().addAll(rotate, scale, translate); 
        
      //Creating a Group object  
      Group root = new Group(rectangle); 
      
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300);  
      
      //Setting title to the Stage 
      stage.setTitle("Multiple transformations"); 
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   }      
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac MultipleTransformationsExample.java 
java MultipleTransformationsExample

위 프로그램은 실행시 아래와 같이 JavaFX 창을 생성합니다.

3D 개체의 변형

3D 개체에 변형을 적용 할 수도 있습니다. 다음은 3 차원 상자를 회전하고 변환하는 예입니다.

이 코드를 이름으로 파일에 저장하십시오. RotationExample3D.java.

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.shape.Box; 
import javafx.scene.transform.Rotate; 
import javafx.scene.transform.Translate; 
import javafx.stage.Stage; 
         
public class RotationExample3D extends Application { 
   @Override 
   public void start(Stage stage) { 
      //Drawing a Box 
      Box box = new Box();  
      
      //Setting the properties of the Box 
      box.setWidth(150.0); 
      box.setHeight(150.0);   
      box.setDepth(150.0);       
       
      //Creating the translation transformation 
      Translate translate = new Translate();       
      translate.setX(400); 
      translate.setY(150); 
      translate.setZ(25);  
       
      Rotate rxBox = new Rotate(0, 0, 0, 0, Rotate.X_AXIS); 
      Rotate ryBox = new Rotate(0, 0, 0, 0, Rotate.Y_AXIS); 
      Rotate rzBox = new Rotate(0, 0, 0, 0, Rotate.Z_AXIS); 
      rxBox.setAngle(30); 
      ryBox.setAngle(50); 
      rzBox.setAngle(30); 
      box.getTransforms().addAll(translate,rxBox, ryBox, rzBox); 
        
      //Creating a Group object  
      Group root = new Group(box); 
         
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300);  
      
      //Setting title to the Stage 
      stage.setTitle("Drawing a cylinder"); 
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   }      
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac RotationExample3D.java 
java RotationExample3D

위 프로그램은 실행시 아래와 같이 JavaFX 창을 생성합니다.

일반적으로 개체를 애니메이션하는 것은 빠른 표시를 통해 모션의 환상을 만드는 것을 의미합니다. JavaFX에서 노드는 시간이 지남에 따라 속성을 변경하여 애니메이션 할 수 있습니다. JavaFX는javafx.animation. 이 패키지에는 노드를 애니메이션하는 데 사용되는 클래스가 포함되어 있습니다. 애니메이션은 이러한 모든 클래스의 기본 클래스입니다.

JavaFX를 사용하면 다음과 같은 애니메이션 (전환)을 적용 할 수 있습니다. Fade Transition, Fill Transition, Rotate Transition, Scale Transition, Stroke Transition, Translate Transition, Path Transition, Sequential Transition, Pause Transition, Parallel Transition

이러한 모든 전환은 패키지의 개별 클래스로 표시됩니다. javafx.animation.

특정 애니메이션을 노드에 적용하려면 아래 단계를 따라야합니다.

  • 각 클래스를 사용하여 요구 노드를 만듭니다.

  • 적용 할 각 전환 (애니메이션) 클래스를 인스턴스화합니다.

  • 전환 속성을 설정하고

  • 마지막으로 play() 의 방법 Animation 수업.

이 장에서는 기본 전환 (회전, 크기 조정, 변환)의 예를 설명합니다.

회전 전환

다음은 JavaFX에서 Rotate Transition을 보여주는 프로그램입니다. 이 코드를 이름으로 파일에 저장하십시오.RotateTransitionExample.java.

import javafx.animation.RotateTransition; 
import javafx.application.Application; 
import static javafx.application.Application.launch; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.paint.Color; 
import javafx.scene.shape.Polygon; 
import javafx.stage.Stage; 
import javafx.util.Duration; 
         
public class RotateTransitionExample extends Application { 
   @Override 
   public void start(Stage stage) {      
      //Creating a hexagon 
      Polygon hexagon = new Polygon();        
      
      //Adding coordinates to the hexagon 
      hexagon.getPoints().addAll(new Double[]{        
         200.0, 50.0, 
         400.0, 50.0, 
         450.0, 150.0,          
         400.0, 250.0, 
         200.0, 250.0,                   
         150.0, 150.0, 
      }); 
      //Setting the fill color for the hexagon 
      hexagon.setFill(Color.BLUE); 
       
      //Creating a rotate transition    
      RotateTransition rotateTransition = new RotateTransition(); 
      
      //Setting the duration for the transition 
      rotateTransition.setDuration(Duration.millis(1000)); 
      
      //Setting the node for the transition 
      rotateTransition.setNode(hexagon);       
      
      //Setting the angle of the rotation 
      rotateTransition.setByAngle(360); 
      
      //Setting the cycle count for the transition 
      rotateTransition.setCycleCount(50); 
      
      //Setting auto reverse value to false 
      rotateTransition.setAutoReverse(false); 
      
      //Playing the animation 
      rotateTransition.play(); 
         
      //Creating a Group object   
      Group root = new Group(hexagon); 
         
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300);   
      
      //Setting title to the Stage 
      stage.setTitle("Rotate transition example "); 
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   }      
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac RotateTransitionExample.java 
java RotateTransitionExample

위 프로그램은 실행시 아래와 같이 JavaFX 창을 생성합니다.

스케일 전환

다음은 JavaFX에서 Scale Transition을 보여주는 프로그램입니다. 이 코드를 이름으로 파일에 저장하십시오.ScaleTransitionExample.java.

import javafx.animation.ScaleTransition; 
import javafx.application.Application; 
import static javafx.application.Application.launch; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.paint.Color; 
import javafx.scene.shape.Circle; 
import javafx.stage.Stage; 
import javafx.util.Duration; 
         
public class ScaleTransitionExample extends Application {  
   @Override 
   public void start(Stage stage) {      
      //Drawing a Circle 
      Circle circle = new Circle(); 
      
      //Setting the position of the circle 
      circle.setCenterX(300.0f); 
      circle.setCenterY(135.0f); 
      
      //Setting the radius of the circle 
      circle.setRadius(50.0f); 
      
      //Setting the color of the circle 
      circle.setFill(Color.BROWN); 
      
      //Setting the stroke width of the circle 
      circle.setStrokeWidth(20); 
       
      //Creating scale Transition 
      ScaleTransition scaleTransition = new ScaleTransition(); 
      
      //Setting the duration for the transition 
      scaleTransition.setDuration(Duration.millis(1000)); 
      
      //Setting the node for the transition 
      scaleTransition.setNode(circle); 
      
      //Setting the dimensions for scaling 
      scaleTransition.setByY(1.5); 
      scaleTransition.setByX(1.5); 
      
      //Setting the cycle count for the translation 
      scaleTransition.setCycleCount(50); 
      
      //Setting auto reverse value to true 
      scaleTransition.setAutoReverse(false); 
      
      //Playing the animation 
      scaleTransition.play(); 
         
      //Creating a Group object  
      Group root = new Group(circle); 
         
      //Creating a scene object  
      Scene scene = new Scene(root, 600, 300); 
      
      //Setting title to the Stage 
      stage.setTitle("Scale transition example"); 
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   }      
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac ScaleTransitionExample.java 
java ScaleTransitionExample

위 프로그램은 실행시 아래와 같이 JavaFX 창을 생성합니다.

Transition 번역

다음은 JavaFX에서 번역 전환을 보여주는 프로그램입니다. 이 코드를 이름으로 파일에 저장하십시오.TranslateTransitionExample.java.

import javafx.animation.TranslateTransition; 
import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.paint.Color; 
import javafx.scene.shape.Circle; 
import javafx.stage.Stage; 
import javafx.util.Duration; 
         
public class TranslateTransitionExample extends Application { 
   @Override 
   public void start(Stage stage) {  
      //Drawing a Circle 
      Circle circle = new Circle(); 
      
      //Setting the position of the circle 
      circle.setCenterX(150.0f); 
      circle.setCenterY(135.0f); 
      
      //Setting the radius of the circle 
      circle.setRadius(100.0f); 
      
      //Setting the color of the circle 
      circle.setFill(Color.BROWN); 
      
      //Setting the stroke width of the circle 
      circle.setStrokeWidth(20); 
       
      //Creating Translate Transition 
      TranslateTransition translateTransition = new TranslateTransition(); 
      
      //Setting the duration of the transition  
      translateTransition.setDuration(Duration.millis(1000)); 
      
      //Setting the node for the transition 
      translateTransition.setNode(circle); 
      
      //Setting the value of the transition along the x axis. 
      translateTransition.setByX(300); 
      
      //Setting the cycle count for the transition 
      translateTransition.setCycleCount(50); 
      
      //Setting auto reverse value to false 
      translateTransition.setAutoReverse(false); 
      
      //Playing the animation 
      translateTransition.play(); 
         
      //Creating a Group object  
      Group root = new Group(circle); 
         
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300);  
      
      //Setting title to the Stage 
      stage.setTitle("Translate transition example"); 
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   }      
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac TranslateTransitionExample.java 
java TranslateTransitionExample

위 프로그램은 실행시 아래와 같이 JavaFX 창을 생성합니다.

이 외에도 JavaFX는 노드에 더 많은 전환을 적용하는 클래스를 제공합니다. 다음은 JavaFX에서 지원하는 다른 종류의 전환입니다.

  • Fade, Fill, Stroke 노드의 속성에 영향을주는 전환

  • 둘 이상의 기본 전환이 포함 된 전환 Sequential, Parallel, Pause

  • 지정된 경로를 따라 개체를 변환하는 전환 경로 전환

응용 프로그램에 색상을 적용하기 위해 JavaFX는 패키지에 다양한 클래스를 제공합니다. javafx.scene.paint꾸러미. 이 패키지에는 Paint라는 추상 클래스가 포함되어 있으며 색상을 적용하는 데 사용되는 모든 클래스의 기본 클래스입니다.

이 클래스를 사용하면 다음 패턴으로 색상을 적용 할 수 있습니다.

  • Uniform −이 패턴에서는 노드 전체에 균일하게 색상이 적용됩니다.

  • Image Pattern − 이렇게하면 이미지 패턴으로 노드 영역을 채울 수 있습니다.

  • Gradient−이 패턴에서 노드에 적용되는 색상은 점마다 다릅니다. 두 종류의 그라디언트가 있습니다.Linear GradientRadial Gradient.

다음과 같이 색상을 적용 할 수있는 모든 노드 클래스 Shape, Text (장면 포함), 명명 된 메서드 setFill()setStroke(). 이것들은 노드와 획의 색상 값을 각각 설정하는 데 도움이됩니다.

이러한 메서드는 Paint 유형의 개체를 허용합니다. 따라서 이러한 유형의 이미지 중 하나를 만들려면 이러한 클래스를 인스턴스화하고 개체를 이러한 메서드에 매개 변수로 전달해야합니다.

노드에 색상 적용

노드에 균일 한 색상 패턴을 설정하려면 클래스 색상의 객체를 노드에 전달해야합니다. setFill(), setStroke() 다음과 같이 방법-

//Setting color to the text 
Color color = new Color.BEIGE 
text.setFill(color); 

//Setting color to the stroke 
Color color = new Color.DARKSLATEBLUE 
circle.setStroke(color);

위의 코드 블록에서 색상 객체를 생성하기 위해 색상 클래스의 정적 변수를 사용하고 있습니다.

같은 방식으로 RGB 값 또는 HSB 표준 색상 또는 웹 해시 색상 코드를 아래와 같이 사용할 수도 있습니다.

//creating color object by passing RGB values 
Color c = Color.rgb(0,0,255);   

//creating color object by passing HSB values
Color c = Color.hsb(270,1.0,1.0);  

//creating color object by passing the hash code for web 
Color c = Color.web("0x0000FF",1.0);

다음은 JavaFX에서 노드에 색상을 적용하는 방법을 보여주는 예입니다. 여기에서는 원과 텍스트 노드를 만들고 여기에 색상을 적용합니다.

이 코드를 이름으로 파일에 저장하십시오. ColorExample.java.

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.paint.Color; 
import javafx.stage.Stage; 
import javafx.scene.shape.Circle; 
import javafx.scene.text.Font; 
import javafx.scene.text.Text; 
         
public class ColorExample extends Application { 
   @Override 
   public void start(Stage stage) { 
      //Drawing a Circle 
      Circle circle = new Circle();    
      
      //Setting the properties of the circle 
      circle.setCenterX(300.0f); 
      circle.setCenterY(180.0f); 
      circle.setRadius(90.0f); 
       
      //Setting color to the circle 
      circle.setFill(Color.DARKRED);    
      
      //Setting the stroke width 
      circle.setStrokeWidth(3); 
      
      //Setting color to the stroke  
      circle.setStroke(Color.DARKSLATEBLUE);
      
      //Drawing a text 
      Text text = new Text("This is a colored circle"); 
      
      //Setting the font of the text 
      text.setFont(Font.font("Edwardian Script ITC", 50)); 
      
      //Setting the position of the text 
      text.setX(155); 
      text.setY(50); 
       
      //Setting color to the text 
      text.setFill(Color.BEIGE); 
      text.setStrokeWidth(2); 
      text.setStroke(Color.DARKSLATEBLUE); 
         
      //Creating a Group object  
      Group root = new Group(circle, text); 
         
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300);  
      
      //Setting title to the Stage 
      stage.setTitle("Color Example"); 
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   } 
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

Javac ColorExample.java 
java ColorExample

실행시 위의 프로그램은 다음과 같이 JavaFX 창을 생성합니다.

노드에 이미지 패턴 적용

노드에 이미지 패턴을 적용하려면 ImagePattern 클래스에 객체를 전달합니다. setFill(), setStroke() 행동 양식.

이 클래스의 생성자는 6 개의 매개 변수를받습니다.

  • Image − 패턴을 만들려는 이미지의 개체.

  • x and y − 앵커 사각형 원점의 (x, y) 좌표를 나타내는 이중 변수.

  • height and width − 패턴을 만드는 데 사용되는 이미지의 높이와 너비를 나타내는 이중 변수.

  • isProportional− 이것은 부울 변수입니다. 이 속성을 true로 설정하면 시작 위치와 끝 위치가 비례하도록 설정됩니다.

ImagePattern radialGradient = new ImagePattern(dots, 20, 20, 40, 40, false);

다음은 JavaFX의 노드에 이미지 패턴을 적용하는 방법을 보여주는 예입니다. 여기에서는 원과 텍스트 노드를 만들고 여기에 이미지 패턴을 적용합니다.

이 코드를 이름이있는 파일에 저장 ImagePatternExample.java.

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.image.Image; 

import javafx.scene.paint.Color; 
import javafx.scene.paint.ImagePattern; 
import javafx.scene.paint.Stop; 

import javafx.stage.Stage; 
import javafx.scene.shape.Circle; 
import javafx.scene.text.Font; 
import javafx.scene.text.Text; 
         
public class ImagePatternExample extends Application { 
   @Override 
   public void start(Stage stage) {           
      //Drawing a Circle 
      Circle circle = new Circle();    
      
      //Setting the properties of the circle 
      circle.setCenterX(300.0f); 
      circle.setCenterY(180.0f); 
      circle.setRadius(90.0f); 
       
      //Drawing a text 
      Text text = new Text("This is a colored circle"); 
      
      //Setting the font of the text 
      text.setFont(Font.font("Edwardian Script ITC", 50)); 
      
      //Setting the position of the text
      text.setX(155); 
      text.setY(50); 
       
      //Setting the image pattern 
      String link = "https://encrypted-tbn1.gstatic.com" 
         + "/images?q=tbn:ANd9GcRQub4GvEezKMsiIf67U" 
         + "rOxSzQuQ9zl5ysnjRn87VOC8tAdgmAJjcwZ2qM";       
      
      Image image = new Image(link); 
      ImagePattern radialGradient = new ImagePattern(image, 20, 20, 40, 40, false); 
       
      //Setting the linear gradient to the circle and text 
      circle.setFill(radialGradient); 
      text.setFill(radialGradient); 
         
      //Creating a Group object  
      Group root = new Group(circle, text); 
         
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300);  
      
      //Setting title to the Stage 
      stage.setTitle("Image pattern Example"); 
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   } 
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

Javac ImagePatternExample.java 
java ImagePatternExample

실행시 위의 프로그램은 다음과 같이 JavaFX 창을 생성합니다.

선형 그라디언트 패턴 적용

선형 그래디언트 패턴을 노드에 적용하려면 LinearGradient 클래스에 객체를 전달합니다. setFill(), setStroke() 행동 양식.

이 클래스의 생성자는 5 개의 매개 변수를받습니다.

  • startX, startY − 이러한 이중 속성은 그라디언트 시작점의 x 및 y 좌표를 나타냅니다.

  • endX, endY − 이러한 이중 속성은 그라디언트 끝점의 x 및 y 좌표를 나타냅니다.

  • cycleMethod −이 인수는 시작점과 끝점으로 정의 된 색상 그라데이션 경계 밖의 영역을 채우는 방법을 정의합니다.

  • proportional− 이것은 부울 변수입니다. 이 속성을true, 시작 및 끝 위치는 비율로 설정됩니다.

  • Stops −이 인수는 그라디언트 선을 따라 색상 중지 지점을 정의합니다.

//Setting the linear gradient 
Stop[] stops = new Stop[] { 
   new Stop(0, Color.DARKSLATEBLUE),  
   new Stop(1, Color.DARKRED)
};  
LinearGradient linearGradient = 
   new LinearGradient(0, 0, 1, 0, true, CycleMethod.NO_CYCLE, stops);

다음은 JavaFX의 노드에 그라디언트 패턴을 적용하는 방법을 보여주는 예입니다. 여기에서는 원과 텍스트 노드를 만들고 여기에 선형 그래디언트 패턴을 적용합니다.

이 코드를 이름이있는 파일에 저장 LinearGradientExample.java.

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 

import javafx.scene.paint.Color; 
import javafx.scene.paint.CycleMethod; 
import javafx.scene.paint.LinearGradient; 
import javafx.scene.paint.Stop; 

import javafx.stage.Stage; 
import javafx.scene.shape.Circle; 
import javafx.scene.text.Font; 
import javafx.scene.text.Text; 
         
public class LinearGradientExample extends Application { 
   @Override 
   public void start(Stage stage) {           
      //Drawing a Circle 
      Circle circle = new Circle();    
      
      //Setting the properties of the circle 
      circle.setCenterX(300.0f);  
      circle.setCenterY(180.0f); 
      circle.setRadius(90.0f); 
      
      //Drawing a text 
      Text text = new Text("This is a colored circle"); 
      
      //Setting the font of the text 
      text.setFont(Font.font("Edwardian Script ITC", 55)); 
      
      //Setting the position of the text 
      text.setX(140); 
      text.setY(50); 
       
      //Setting the linear gradient 
      Stop[] stops = new Stop[] { 
         new Stop(0, Color.DARKSLATEBLUE),  
         new Stop(1, Color.DARKRED)
      };  
      LinearGradient linearGradient = 
         new LinearGradient(0, 0, 1, 0, true, CycleMethod.NO_CYCLE, stops); 
       
      //Setting the linear gradient to the circle and text 
      circle.setFill(linearGradient); 
      text.setFill(linearGradient); 
         
      //Creating a Group object  
      Group root = new Group(circle, text); 
         
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300);  
      
      //Setting title to the Stage 
      stage.setTitle("Linear Gradient Example"); 
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   }      
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

Javac LinearGradientExample.java 
java LinearGradientExample

실행시 위의 프로그램은 다음과 같이 JavaFX 창을 생성합니다.

방사형 그라데이션 패턴 적용

방사형 그라데이션 패턴을 노드에 적용하려면 GradientPattern 클래스에 객체를 전달합니다. setFill(), setStroke() 행동 양식.

이 클래스의 생성자는 몇 가지 매개 변수를받습니다.

  • startX, startY − 이러한 이중 속성은 그라디언트 시작점의 x 및 y 좌표를 나타냅니다.

  • endX, endY − 이러한 이중 속성은 그라디언트 끝점의 x 및 y 좌표를 나타냅니다.

  • cycleMethod −이 인수는 시작점과 끝점에 의해 색상 그라데이션 경계 밖의 영역이 정의되는 방식과 채워야하는 방법을 정의합니다.

  • proportional− 이것은 부울 변수입니다. 이 속성을true 시작 및 끝 위치는 비율로 설정됩니다.

  • Stops −이 인수는 그라디언트 선을 따라 색상 중지 지점을 정의합니다.

//Setting the radial gradient 
Stop[] stops = new Stop[] { 
   new Stop(0.0, Color.WHITE),  
   new Stop(0.3, Color.RED), 
   new Stop(1.0, Color.DARKRED) 
};        

RadialGradient radialGradient = 
   new RadialGradient(0, 0, 300, 178, 60, false, CycleMethod.NO_CYCLE, stops);

다음은 JavaFX의 노드에 방사형 그래디언트 패턴을 적용하는 방법을 보여주는 예입니다. 여기에서는 원과 텍스트 노드를 만들고 여기에 그라디언트 패턴을 적용합니다.

이 코드를 이름으로 파일에 저장하십시오. RadialGradientExample.java.

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 

import javafx.scene.paint.Color; 
import javafx.scene.paint.CycleMethod; 
import javafx.scene.paint.RadialGradient;  
import javafx.scene.paint.Stop; 

import javafx.stage.Stage; 
import javafx.scene.shape.Circle; 
import javafx.scene.text.Font; 
import javafx.scene.text.Text;   

public class RadialGradientExample extends Application {  
   @Override 
   public void start(Stage stage) { 
      //Drawing a Circle 
      Circle circle = new Circle(); 
      
      //Setting the properties of the circle 
      circle.setCenterX(300.0f); 
      circle.setCenterY(180.0f); 
      circle.setRadius(90.0f);  
      
      //Drawing a text 
      Text text = new Text("This is a colored circle"); 
      
      //Setting the font of the text 
      text.setFont(Font.font("Edwardian Script ITC", 50)); 
      
      //Setting the position of the text 
      text.setX(155); 
      text.setY(50);  
      
      //Setting the radial gradient 
      Stop[] stops = new Stop[] { 
         new Stop(0.0, Color.WHITE),  
         new Stop(0.3, Color.RED), 
         new Stop(1.0, Color.DARKRED) 
      };        
      RadialGradient radialGradient = 
         new RadialGradient(0, 0, 300, 178, 60, false, CycleMethod.NO_CYCLE, stops);  
      
      //Setting the radial gradient to the circle and text 
      circle.setFill(radialGradient); 
      text.setFill(radialGradient);  
      
      //Creating a Group object  
      Group root = new Group(circle, text);  
      
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300); 
      
      //Setting title to the Stage 
      stage.setTitle("Radial Gradient Example");  
      
      //Adding scene to the stage 
      stage.setScene(scene);  
      
      //Displaying the contents of the stage 
      stage.show(); 
   }
   public static void main(String args[]) { 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

Javac RadialGradientExample.java 
java RadialGradientExample

실행시 위의 프로그램은 다음과 같이 JavaFX 창을 생성합니다.

패키지의 JavaFX에서 제공하는 클래스를 사용하여 이미지를로드하고 수정할 수 있습니다. javafx.scene.image. JavaFX는 다음과 같은 이미지 형식을 지원합니다.Bmp, Gif, Jpeg, Png.

이 장에서는 JavaFX로 이미지를로드하는 방법, 여러보기에서 이미지를 투영하는 방법 및 이미지의 픽셀을 변경하는 방법을 설명합니다.

이미지로드

다음과 같은 클래스를 인스턴스화하여 JavaFX에서 이미지를로드 할 수 있습니다. Image 패키지의 javafx.scene.image.

클래스 생성자에게 다음 중 하나를 전달해야합니다.

  • InputStream 로드 할 이미지의 객체 또는,

  • 이미지의 URL을 포함하는 문자열 변수입니다.

//Passing FileInputStream object as a parameter 
FileInputStream inputstream = new FileInputStream("C:\\images\\image.jpg"); 
Image image = new Image(inputstream); 
         
//Loading image from URL 
//Image image = new Image(new FileInputStream("url for the image));

이미지를로드 한 후 인스턴스화하여 이미지보기를 설정할 수 있습니다. ImageView 클래스와 다음과 같이 이미지를 생성자에 전달-

ImageView imageView = new ImageView(image);

다음은 JavaFX에서 이미지를로드하고보기를 설정하는 방법을 보여주는 예입니다.

이 코드를 이름으로 파일에 저장하십시오. ImageExample.java.

import java.io.FileInputStream; 
import java.io.FileNotFoundException; 
import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.image.Image;
import javafx.scene.image.ImageView;  
import javafx.stage.Stage;  

public class ImageExample extends Application {  
   @Override 
   public void start(Stage stage) throws FileNotFoundException {         
      //Creating an image 
      Image image = new Image(new FileInputStream("path of the image"));  
      
      //Setting the image view 
      ImageView imageView = new ImageView(image); 
      
      //Setting the position of the image 
      imageView.setX(50); 
      imageView.setY(25); 
      
      //setting the fit height and width of the image view 
      imageView.setFitHeight(455); 
      imageView.setFitWidth(500); 
      
      //Setting the preserve ratio of the image view 
      imageView.setPreserveRatio(true);  
      
      //Creating a Group object  
      Group root = new Group(imageView);  
      
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 500);  
      
      //Setting title to the Stage 
      stage.setTitle("Loading an image");  
      
      //Adding scene to the stage 
      stage.setScene(scene);
      
      //Displaying the contents of the stage 
      stage.show(); 
   }  
   public static void main(String args[]) { 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

Javac ImageExample.java 
java ImageExample

실행시 위의 프로그램은 다음과 같이 JavaFX 창을 생성합니다.

이미지의 다중보기

동일한 장면의 이미지에 대해 여러보기를 설정할 수도 있습니다. 다음 프로그램은 JavaFX에서 장면의 이미지에 대한 다양한보기를 설정하는 방법을 보여주는 예제입니다.

이 코드를 이름으로 파일에 저장하십시오. MultipleViews.java.

import java.io.FileInputStream; 
import java.io.FileNotFoundException; 
import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.image.Image;  
import javafx.scene.image.ImageView; 
import javafx.stage.Stage;  

public class MultipleViews extends Application {  
   @Override 
   public void start(Stage stage) throws FileNotFoundException {         
      //Creating an image 
      Image image = new Image(new FileInputStream("file path"));  
      
      //Setting the image view 1 
      ImageView imageView1 = new ImageView(image); 
      
      //Setting the position of the image 
      imageView1.setX(50); 
      imageView1.setY(25); 
      
      //setting the fit height and width of the image view 
      imageView1.setFitHeight(300); 
      imageView1.setFitWidth(250);         
      
      //Setting the preserve ratio of the image view 
      imageView1.setPreserveRatio(true); 
         
      //Setting the image view 2 
      ImageView imageView2 = new ImageView(image);
      
      //Setting the position of the image 
      imageView2.setX(350); 
      imageView2.setY(25); 
      
      //setting the fit height and width of the image view 
      imageView2.setFitHeight(150); 
      imageView2.setFitWidth(250);          
      
      //Setting the preserve ratio of the image view 
      imageView2.setPreserveRatio(true); 
         
      //Setting the image view 3 
      ImageView imageView3 = new ImageView(image);  
      
      //Setting the position of the image 
      imageView3.setX(350); 
      imageView3.setY(200); 
      
      //setting the fit height and width of the image view 
      imageView3.setFitHeight(100); 
      imageView3.setFitWidth(100);         
      
      //Setting the preserve ratio of the image view 
      imageView3.setPreserveRatio(true);  
      
      //Creating a Group object  
      Group root = new Group(imageView1, imageView2, imageView3);  
      
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 400);  
      
      //Setting title to the Stage 
      stage.setTitle("Multiple views of an image");  
      
      //Adding scene to the stage 
      stage.setScene(scene);  
      
      //Displaying the contents of the stage
      stage.show(); 
   }  
   public static void main(String args[]) { 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

Javac MultipleViews.java 
java MultipleViews

실행시 위의 프로그램은 다음과 같이 JavaFX 창을 생성합니다.

픽셀 쓰기

JavaFX는 PixelReaderPixelWriter이미지의 픽셀을 읽고 쓰는 클래스. 그만큼WritableImage 클래스는 쓰기 가능한 이미지를 만드는 데 사용됩니다.

다음은 이미지의 픽셀을 읽고 쓰는 방법을 보여주는 예입니다. 여기에서는 이미지의 색상 값을 읽고 더 어둡게 만듭니다.

이 코드를 이름으로 파일에 저장하십시오. WritingPixelsExample.java.

import java.io.FileInputStream; 
import java.io.FileNotFoundException;  
import javafx.application.Application; 

import javafx.scene.Group;  
import javafx.scene.Scene; 

import javafx.scene.image.Image; 
import javafx.scene.image.ImageView; 
import javafx.scene.image.PixelReader; 
import javafx.scene.image.PixelWriter; 
import javafx.scene.image.WritableImage; 

import javafx.scene.paint.Color; 
import javafx.stage.Stage;  

public class WritingPixelsExample extends Application {  
   @Override 
   public void start(Stage stage) throws FileNotFoundException {         
      //Creating an image 
      Image image = new Image(new FileInputStream("C:\\images\\logo.jpg")); 
      int width = (int)image.getWidth(); 
      int height = (int)image.getHeight(); 
         
      //Creating a writable image 
      WritableImage wImage = new WritableImage(width, height); 
         
      //Reading color from the loaded image 
      PixelReader pixelReader = image.getPixelReader(); 
      
      //getting the pixel writer 
      PixelWriter writer = wImage.getPixelWriter();           
      
      //Reading the color of the image 
      for(int y = 0; y < height; y++) { 
         for(int x = 0; x < width; x++) { 
            //Retrieving the color of the pixel of the loaded image   
            Color color = pixelReader.getColor(x, y); 
              
            //Setting the color to the writable image 
            writer.setColor(x, y, color.darker());              
         }     
      }      
      //Setting the view for the writable image 
      ImageView imageView = new ImageView(wImage); 
              
      //Creating a Group object  
      Group root = new Group(imageView);  
            
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 500);  
            
      //Setting title to the Stage 
      stage.setTitle("Writing pixels ");  
            
      //Adding scene to the stage 
      stage.setScene(scene);  
            
      //Displaying the contents of the stage 
      stage.show();  
   }
   public static void main(String args[]) { 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

Javac WritingPixelsExample.java 
java WritingPixelsExample

실행시 위의 프로그램은 다음과 같이 JavaFX 창을 생성합니다.

이전 장에서 우리는 XY 평면에 2D 모양을 그리는 방법을 보았습니다. 이러한 2D 모양 외에도 JavaFX를 사용하여 여러 다른 3D 모양을 그릴 수 있습니다.

3D 모양

일반적으로 3D 도형은 XYZ 평면에 그릴 수있는 기하학적 도형입니다. 여기에는Cylinder, Sphere 그리고 Box.

위에서 언급 한 각 3D 모양은 클래스로 표시되며 이러한 모든 클래스는 패키지에 속합니다. javafx.scene.shape. 명명 된 클래스Shape3D JavaFX의 모든 3 차원 도형의 기본 클래스입니다.

3D 모양 만들기

3 차원 모양을 만들려면 다음을 수행해야합니다.

  • 필요한 3D 모양의 각 클래스를 인스턴스화합니다.

  • 3D 도형의 속성을 설정합니다.

  • 그룹에 3D 모양 개체를 추가합니다.

각 클래스 인스턴스화

3 차원 모양을 만들려면 먼저 해당 클래스를 인스턴스화해야합니다. 예를 들어 3D 상자를 만들려면 다음과 같이 Box라는 클래스를 인스턴스화해야합니다.

Box box = new Box();

모양의 속성 설정

클래스를 인스턴스화 한 후 setter 메서드를 사용하여 셰이프의 속성을 설정해야합니다.

예를 들어 3D 상자를 그리려면 너비, 높이, 깊이를 전달해야합니다. 다음과 같이 각각의 setter 메서드를 사용하여 이러한 값을 지정할 수 있습니다.

//Setting the properties of the Box 
box.setWidth(200.0); 
box.setHeight(400.0);   
box.setDepth(200.0);

그룹에 모양 개체 추가

마지막으로 아래와 같이 생성자의 매개 변수로 전달하여 모양의 객체를 그룹에 추가해야합니다.

//Creating a Group object  
Group root = new Group(box);

다음 표는 JavaFX에서 제공하는 다양한 3D 모양 목록을 제공합니다.

S. 아니 모양 및 설명
1 상자

입방체는 length (깊이), width, 및 height.

JavaFX에서 3 차원 상자는 다음과 같은 클래스로 표시됩니다. Box. 이 클래스는 패키지에 속합니다.javafx.scene.shape.

이 클래스를 인스턴스화하여 JavaFX에서 Box 노드를 만들 수 있습니다.

이 클래스는 즉 이중 데이터 유형의 3 가지 속성을 가지고 있습니다-

  • width − 상자의 너비.

  • height − 상자의 높이.

  • depth − 상자의 깊이.

2 실린더

원통은 곡면으로 연결된 두 개의 평행 (대부분 원형)베이스가있는 닫힌 솔리드입니다.

이는 두 개의 매개 변수, 즉 radius 원형베이스와 height 실린더의.

JavaFX에서 실린더는 다음과 같은 클래스로 표시됩니다. Cylinder. 이 클래스는 패키지에 속합니다.javafx.scene.shape.

이 클래스를 인스턴스화하여 JavaFX에서 실린더 노드를 만들 수 있습니다. 이 클래스는 즉, 이중 데이터 유형의 두 가지 속성이 있습니다-

  • height − 실린더의 높이.

  • radius − 원통의 반경.

구체

구는 3D 공간에서 주어진 점에서 모두 동일한 거리 r에있는 점 집합으로 정의됩니다. 이 거리 r은 구의 반경이고 주어진 점은 구의 중심입니다.

JavaFX에서 구는 다음과 같은 클래스로 표시됩니다. Sphere. 이 클래스는 패키지에 속합니다.javafx.scene.shape.

이 클래스를 인스턴스화하면 JavaFX에서 구 노드를 만들 수 있습니다.

이 클래스에는 radius이중 데이터 유형의. 구의 반경을 나타냅니다.

3D 개체의 속성

3 차원 개체 모두에 대해 Cull Face, Drawing Mode, Material과 같은 다양한 속성을 설정할 수 있습니다.

다음 섹션에서는 3D 개체의 속성에 대해 설명합니다.

컬 페이스

일반적으로 컬링은 모양의 방향이 잘못된 부분 (뷰 영역에 표시되지 않음)을 제거하는 것입니다.

Cull Face 속성은 CullFace3D 모양의 Cull Face를 나타냅니다. 방법을 사용하여 모양의 Cull Face를 설정할 수 있습니다.setCullFace() 아래와 같이-

box.setCullFace(CullFace.NONE);

모양의 획 유형은 다음과 같습니다.

  • None − 컬링이 수행되지 않습니다 (CullFace.NONE).

  • Front-전면을 향한 모든 다각형이 컬링됩니다. (CullFace.FRONT).

  • Back-뒷면을 향한 모든 다각형이 컬링됩니다. (StrokeType.BACK).

기본적으로 3 차원 모양의 컬면은 뒤로입니다.

다음 프로그램은 구의 다양한 컬면을 보여주는 예제입니다. 이 코드를 이름으로 파일에 저장하십시오.SphereCullFace.java.

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.shape.CullFace; 
import javafx.stage.Stage; 
import javafx.scene.shape.Sphere; 
         
public class SphereCullFace extends Application { 
   @Override 
   public void start(Stage stage) { 
      //Drawing Sphere1 
      Sphere sphere1 = new Sphere();
      
      //Setting the radius of the Sphere 
      sphere1.setRadius(50.0);   
      
      //Setting the position of the sphere 
      sphere1.setTranslateX(100); 
      sphere1.setTranslateY(150); 
      
      //setting the cull face of the sphere to front 
      sphere1.setCullFace(CullFace.FRONT); 
       
      //Drawing Sphere2 
      Sphere sphere2 = new Sphere(); 
      
      //Setting the radius of the Sphere 
      sphere2.setRadius(50.0);   
      
      //Setting the position of the sphere 
      sphere2.setTranslateX(300);  
      sphere2.setTranslateY(150); 
      
      //Setting the cull face of the sphere to back 
      sphere2.setCullFace(CullFace.BACK); 
             
      //Drawing Sphere3 
      Sphere sphere3 = new Sphere(); 
      
      //Setting the radius of the Sphere 
      sphere3.setRadius(50.0);   
      
      //Setting the position of the sphere 
      sphere3.setTranslateX(500); 
      sphere3.setTranslateY(150); 
      
      //Setting the cull face of the sphere to none 
      sphere2.setCullFace(CullFace.NONE);          
       
      //Creating a Group object  
      Group root = new Group(sphere1, sphere2, sphere3); 
         
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300);  
      
      //Setting title to the Stage
      stage.setTitle("Drawing a Sphere"); 
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   } 
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac SphereCullFace.java 
java SphereCullFace

실행시 위 프로그램은 컬 페이스 값이있는 세 개의 구를 표시하는 JavaFX 창을 생성합니다 FRONT, BACKNONE 각각 다음과 같이-

그리기 모드

속성이 유형입니다. DrawMode현재 3D 도형을 그리는 데 사용되는 그리기 모드를 나타냅니다. 다음과 같이 setDrawMode () 메서드를 사용하여 3D 모양을 그리는 그리기 모드를 선택할 수 있습니다.

box.setDrawMode(DrawMode.FILL);

JavaFX에서는 두 가지 그리기 모드를 선택하여 3D 모양을 그릴 수 있습니다.

  • Fill −이 모드는 2D 도형 (DrawMode.FILL)을 그리고 채 웁니다.

  • Line −이 모드는 선 (DrawMode.LINE)을 사용하여 3D 도형을 그립니다.

기본적으로 3 차원 도형의 그리기 모드는 채우기입니다.

다음 프로그램은 3D 상자의 다양한 그리기 모드를 보여주는 예제입니다. 이 코드를 이름으로 파일에 저장하십시오.BoxDrawMode.java.

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.PerspectiveCamera; 
import javafx.scene.Scene;  
import javafx.scene.shape.Box; 
import javafx.scene.shape.DrawMode; 
import javafx.stage.Stage; 
         
public class BoxDrawMode extends Application { 
   @Override 
   public void start(Stage stage) { 
      //Drawing a Box 
      Box box1 = new Box(); 
      
      //Setting the properties of the Box 
      box1.setWidth(100.0); 
      box1.setHeight(100.0);   
      box1.setDepth(100.0); 
      
      //Setting the position of the box 
      box1.setTranslateX(200); 
      box1.setTranslateY(150); 
      box1.setTranslateZ(0);
      
      //Setting the drawing mode of the box 
      box1.setDrawMode(DrawMode.LINE); 
       
      //Drawing a Box 
      Box box2 = new Box(); 
      
      //Setting the properties of the Box 
      box2.setWidth(100.0); 
      box2.setHeight(100.0);   
      box2.setDepth(100.0); 
      
      //Setting the position of the box 
      box2.setTranslateX(450); //450 
      box2.setTranslateY(150);//150 
      box2.setTranslateZ(300); 
  
      //Setting the drawing mode of the box 
      box2.setDrawMode(DrawMode.FILL);     
         
      //Creating a Group object   
      Group root = new Group(box1, box2); 
         
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300); 
       
      //Setting camera 
      PerspectiveCamera camera = new PerspectiveCamera(false); 
      camera.setTranslateX(0); 
      camera.setTranslateY(0); 
      camera.setTranslateZ(0); 
      scene.setCamera(camera);  
      
      //Setting title to the Stage 
      stage.setTitle("Drawing a Box"); 
         
      //Adding scene to the stage 
      stage.setScene(scene);
      
      //Displaying the contents of the stage 
      stage.show(); 
   }      
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac BoxDrawMode.java 
java BoxDrawMode

실행시 위의 프로그램은 다음과 같이 그리기 모드 값이 LINE 및 FILL 인 두 개의 상자를 표시하는 JavaFX 창을 생성합니다.

재료

cull Face 속성은 Material3D 모양의 재질 표면을 선택하는 데 사용됩니다. 방법을 사용하여 3D 모양의 재질을 설정할 수 있습니다.setCullFace() 다음과 같이-

cylinder.setMaterial(material);

이 메서드에 대해 위에서 언급했듯이 Material 유형의 개체를 전달해야합니다. 그만큼PhongMaterial 패키지 클래스 javafx.scene.paint는이 클래스의 하위 클래스이며 Phong 음영 재질을 나타내는 7 개의 속성을 제공합니다. 이러한 속성의 setter 메서드를 사용하여 이러한 모든 유형의 재료를 3D 모양의 표면에 적용 할 수 있습니다.

다음은 JavaFX에서 사용할 수있는 자료 유형입니다.

  • bumpMap − 이것은 RGB 이미지로 저장된 노멀 맵을 나타냅니다.

  • diffuseMap − 이것은 확산 맵을 나타냅니다.

  • selfIlluminationMap − 이것은이 PhongMaterial의 자체 조명 맵을 나타냅니다.

  • specularMap − 이것은이 PhongMaterial의 반사 맵을 나타냅니다.

  • diffuseColor − 이것은이 PhongMaterial의 확산 색상을 나타냅니다.

  • specularColor − 이것은이 PhongMaterial의 반 사색을 나타냅니다.

  • specularPower − 이것은이 PhongMaterial의 반사광을 나타냅니다.

기본적으로 3 차원 모양의 재질은 확산 색상이 밝은 회색 인 PhongMaterial입니다.

다음은 원통에 다양한 재질을 표시하는 예입니다. 이 코드를 이름으로 파일에 저장하십시오.CylinderMaterials.java.

import javafx.application.Application; 
import javafx.scene.Group; 
import javafx.scene.PerspectiveCamera; 
import javafx.scene.Scene; 
import javafx.scene.image.Image; 
import javafx.scene.paint.Color; 
import javafx.scene.paint.PhongMaterial; 
import javafx.scene.shape.Cylinder; 
import javafx.stage.Stage;

public class CylinderMaterials extends Application {  
   @Override 
   public void start(Stage stage) { 
      //Drawing Cylinder1 
      Cylinder cylinder1 = new Cylinder();         
   
      //Setting the properties of the Cylinder 
      cylinder1.setHeight(130.0f); 
      cylinder1.setRadius(30.0f);   
     
      //Setting the position of the Cylinder 
      cylinder1.setTranslateX(100); 
      cylinder1.setTranslateY(75); 
        
      //Preparing the phong material of type bump map  
      PhongMaterial material1 = new PhongMaterial();  
      material1.setBumpMap(new Image
         ("http://www.tutorialspoint.com/images/tplogo.gif"));   
      
      //Setting the bump map material to Cylinder1 
      cylinder1.setMaterial(material1);    
       
      //Drawing Cylinder2 
      Cylinder cylinder2 = new Cylinder();         
      
      //Setting the properties of the Cylinder 
      cylinder2.setHeight(130.0f); 
      cylinder2.setRadius(30.0f);   
      
      //Setting the position of the Cylinder 
      cylinder2.setTranslateX(200); 
      cylinder2.setTranslateY(75); 
       
      //Preparing the phong material of type diffuse map 
      PhongMaterial material2 = new PhongMaterial();
      material2.setDiffuseMap(new Image
         ("http://www.tutorialspoint.com/images/tp-logo.gif")); 
      
      //Setting the diffuse map material to Cylinder2 
      cylinder2.setMaterial(material2);         
       
      //Drawing Cylinder3 
      Cylinder cylinder3 = new Cylinder();         
      
      //Setting the properties of the Cylinder 
      cylinder3.setHeight(130.0f); 
      cylinder3.setRadius(30.0f);   
  
      //Setting the position of the Cylinder 
      cylinder3.setTranslateX(300); 
      cylinder3.setTranslateY(75); 
       
      //Preparing the phong material of type Self Illumination Map 
      PhongMaterial material3 = new PhongMaterial();  
      material3.setSelfIlluminationMap(new Image
         ("http://www.tutorialspoint.com/images/tp-logo.gif"));  
      
      //Setting the Self Illumination Map material to Cylinder3 
      cylinder3.setMaterial(material3);  
       
      //Drawing Cylinder4 
      Cylinder cylinder4 = new Cylinder();         
      
      //Setting the properties of the Cylinder 
      cylinder4.setHeight(130.0f); 
      cylinder4.setRadius(30.0f);   
      
      //Setting the position of the Cylinder 
      cylinder4.setTranslateX(400); 
      cylinder4.setTranslateY(75); 
       
      //Preparing the phong material of type Specular Map  
      PhongMaterial material4 = new PhongMaterial();  
      material4.setSpecularMap(new Image
         ("http://www.tutorialspoint.com/images/tp-logo.gif")); 
      
      //Setting the Specular Map material to Cylinder4 
      cylinder4.setMaterial(material4);  
       
      //Drawing Cylinder5 
      Cylinder cylinder5 = new Cylinder();         
      
      //Setting the properties of the Cylinder 
      cylinder5.setHeight(130.0f); 
      cylinder5.setRadius(30.0f);   
      
      //Setting the position of the Cylinder 
      cylinder5.setTranslateX(100); 
      cylinder5.setTranslateY(300); 
       
      //Preparing the phong material of type diffuse color 
      PhongMaterial material5 = new PhongMaterial();  
      material5.setDiffuseColor(Color.BLANCHEDALMOND); 
      
      //Setting the diffuse color material to Cylinder5 
      cylinder5.setMaterial(material5);   
       
      //Drawing Cylinder6  
      Cylinder cylinder6 = new Cylinder();         
      
      //Setting the properties of the Cylinder 
      cylinder6.setHeight(130.0f); 
      cylinder6.setRadius(30.0f);   
      
      //Setting the position of the Cylinder 
      cylinder6.setTranslateX(200); 
      cylinder6.setTranslateY(300); 
       
      //Preparing the phong material of type specular color 
      PhongMaterial material6 = new PhongMaterial();  
      
      //setting the specular color map to the material 
      material6.setSpecularColor(Color.BLANCHEDALMOND); 
      
      //Setting the specular color material to Cylinder6 
      cylinder6.setMaterial(material6);    
       
      //Drawing Cylinder7 
      Cylinder cylinder7 = new Cylinder();
      
      //Setting the properties of the Cylinder 
      cylinder7.setHeight(130.0f); 
      cylinder7.setRadius(30.0f);   
      
      //Setting the position of the Cylinder 
      cylinder7.setTranslateX(300); 
      cylinder7.setTranslateY(300); 
       
      //Preparing the phong material of type Specular Power 
      PhongMaterial material7 = new PhongMaterial();  
      material7.setSpecularPower(0.1); 
      
      //Setting the Specular Power material to the Cylinder 
      cylinder7.setMaterial(material7);         
      
      //Creating a Group object  
      Group root = new Group(cylinder1 ,cylinder2, cylinder3, 
      cylinder4, cylinder5, cylinder6, cylinder7); 
          
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 400); 
       
      //Setting camera 
      PerspectiveCamera camera = new PerspectiveCamera(false); 
      camera.setTranslateX(0); 
      camera.setTranslateY(0); 
      camera.setTranslateZ(-10); 
      scene.setCamera(camera); 
       
      //Setting title to the Stage 
      stage.setTitle("Drawing a cylinder"); 
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   }      
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

Javac CylinderMaterials.java 
java CylinderMaterials

실행시 위의 프로그램은 다음 스크린 샷과 같이 각각 Materials, Bump Map, Diffuse Map, Self-Illumination Map, Specular Map, Diffuse Color, Specular Color, (BLANCHEDALMOND) Specular Power가있는 7 개의 실린더를 표시하는 JavaFX 창을 생성합니다. −

JavaFX에서는 GUI 응용 프로그램, 웹 응용 프로그램 및 그래픽 응용 프로그램을 개발할 수 있습니다. 이러한 응용 프로그램에서는 사용자가 응용 프로그램 (노드)과 상호 작용할 때마다 이벤트가 발생했다고합니다.

예를 들어, 버튼 클릭, 마우스 이동, 키보드를 통한 문자 입력, 목록에서 항목 선택, 페이지 스크롤 등이 이벤트를 발생시키는 활동입니다.

이벤트 유형

이벤트는 크게 다음 두 가지 범주로 분류 할 수 있습니다.

  • Foreground Events− 사용자의 직접적인 상호 작용이 필요한 이벤트. 그래픽 사용자 인터페이스에서 그래픽 구성 요소와 상호 작용하는 사람의 결과로 생성됩니다. 예를 들어 버튼 클릭, 마우스 이동, 키보드를 통한 문자 입력, 목록에서 항목 선택, 페이지 스크롤 등이 있습니다.

  • Background Events− 최종 사용자의 상호 작용이 필요한 이벤트를 백그라운드 이벤트라고합니다. 운영 체제 중단, 하드웨어 또는 소프트웨어 오류, 타이머 만료, 작업 완료는 백그라운드 이벤트의 예입니다.

JavaFX의 이벤트

JavaFX는 다양한 이벤트 처리를 지원합니다. 명명 된 클래스Event 패키지의 javafx.event 이벤트의 기본 클래스입니다.

하위 클래스의 인스턴스는 이벤트입니다. JavaFX는 다양한 이벤트를 제공합니다. 그들 중 일부는 아래에 나열되어 있습니다.

  • Mouse Event− 마우스 클릭시 발생하는 입력 이벤트입니다. 이름이 지정된 클래스로 표시됩니다.MouseEvent. 여기에는 마우스 클릭, 마우스 누름, 마우스 놓기, 마우스 이동, 마우스 입력 대상, 마우스 종료 대상 등과 같은 동작이 포함됩니다.

  • Key Event− 노드에서 발생한 키 입력을 나타내는 입력 이벤트입니다. 이름이 지정된 클래스로 표시됩니다.KeyEvent. 이 이벤트에는 키 누름, 키 놓기 및 키 입력과 같은 작업이 포함됩니다.

  • Drag Event− 마우스를 드래그 할 때 발생하는 입력 이벤트입니다. 이름이 지정된 클래스로 표시됩니다.DragEvent. 여기에는 입력 된 드래그, 드롭 된 드래그, 입력 된 대상 드래그, 종료 된 대상 드래그, 위로 드래그 등과 같은 작업이 포함됩니다.

  • Window Event− 윈도우 표시 / 숨기기와 관련된 이벤트입니다. 이름이 지정된 클래스로 표시됩니다.WindowEvent. 여기에는 창 숨기기, 창 표시, 창 숨김, 창 표시 등과 같은 작업이 포함됩니다.

이벤트 처리

이벤트 처리는 이벤트를 제어하고 이벤트가 발생하는 경우 발생해야하는 작업을 결정하는 메커니즘입니다. 이 메커니즘에는 이벤트가 발생할 때 실행되는 이벤트 처리기로 알려진 코드가 있습니다.

JavaFX는 이벤트를 처리하기위한 핸들러와 필터를 제공합니다. JavaFX에서 모든 이벤트는-

  • Target− 이벤트가 발생한 노드. 대상은 창, 장면 및 노드 일 수 있습니다.

  • Source− 이벤트가 생성 된 소스가 이벤트의 소스가됩니다. 위의 시나리오에서 마우스는 이벤트의 소스입니다.

  • Type− 발생한 이벤트의 유형 마우스 이벤트의 경우 – 마우스를 눌렀을 때, 마우스를 놓는 것이 이벤트 유형입니다.

다음과 같이 그룹 개체를 사용하여 삽입 된 원, 중지 및 재생 버튼이있는 응용 프로그램이 있다고 가정합니다.

재생 버튼을 클릭하면 소스는 마우스가되고 대상 노드는 재생 버튼이되고 생성되는 이벤트 유형은 마우스 클릭입니다.

JavaFX의 이벤트 처리 단계

이벤트가 생성 될 때마다 JavaFX는 다음 단계를 거칩니다.

루트 건설

이벤트가 생성 될 때마다 이벤트의 기본 / 초기 경로는 Event Dispatch chain. 스테이지에서 소스 노드까지의 경로입니다.

다음은 위 시나리오에서 재생 버튼을 클릭했을 때 생성 된 이벤트에 대한 이벤트 디스패치 체인입니다.

이벤트 캡처 단계

이벤트 전달 체인이 생성 된 후 응용 프로그램의 루트 노드가 이벤트를 전달합니다. 이 이벤트는 디스패치 체인의 모든 노드로 이동합니다 (위에서 아래로). 이러한 노드 중 하나에filter생성 된 이벤트에 등록되면 실행됩니다. 디스패치 체인의 노드 중 생성 된 이벤트에 대한 필터가없는 경우 대상 노드로 전달되고 마지막으로 대상 노드가 이벤트를 처리합니다.

이벤트 버블 링 단계

이벤트 버블 링 단계에서는 이벤트가 대상 노드에서 스테이지 노드로 이동합니다 (아래에서 위로). 이벤트 디스패치 체인의 노드 중 하나에handler생성 된 이벤트에 등록되면 실행됩니다. 이러한 노드에 이벤트를 처리 할 핸들러가 없으면 이벤트가 루트 노드에 도달하고 마지막으로 프로세스가 완료됩니다.

이벤트 처리기 및 필터

이벤트 필터 및 핸들러는 이벤트를 처리하기위한 애플리케이션 로직을 포함하는 것입니다. 노드는 둘 이상의 핸들러 / 필터에 등록 할 수 있습니다. 부모-자식 노드의 경우 모든 자식 노드에 대해 기본값으로 처리되는 공통 필터 / 핸들러를 부모에게 제공 할 수 있습니다.

위에서 언급했듯이 이벤트 동안 처리는 실행되는 필터이며 이벤트 버블 링 단계에서 핸들러가 실행됩니다. 모든 핸들러와 필터는 인터페이스를 구현합니다.EventHandler 패키지의 javafx.event.

이벤트 필터 추가 및 제거

이벤트 필터를 노드에 추가하려면 방법을 사용하여이 필터를 등록해야합니다. addEventFilter()Node 수업.

//Creating the mouse event handler 
EventHandler<MouseEvent> eventHandler = new EventHandler<MouseEvent>() { 
   @Override 
   public void handle(MouseEvent e) { 
      System.out.println("Hello World"); 
      circle.setFill(Color.DARKSLATEBLUE);  
   } 
};   
//Adding event Filter 
Circle.addEventFilter(MouseEvent.MOUSE_CLICKED, eventHandler);

같은 방법으로 아래와 같이 removeEventFilter () 메서드를 사용하여 필터를 제거 할 수 있습니다.

circle.removeEventFilter(MouseEvent.MOUSE_CLICKED, eventHandler);

이벤트 처리 예

다음은 이벤트 필터를 사용하여 JavaFX에서 이벤트 처리를 보여주는 예입니다. 이 코드를 이름이있는 파일에 저장EventFiltersExample.java.

import javafx.application.Application; 
import static javafx.application.Application.launch; 
import javafx.event.EventHandler; 

import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.input.MouseEvent; 
import javafx.scene.paint.Color; 
import javafx.scene.shape.Circle; 

import javafx.scene.text.Font; 
import javafx.scene.text.FontWeight;
import javafx.scene.text.Text; 
import javafx.stage.Stage; 
         
public class EventFiltersExample extends Application { 
   @Override 
   public void start(Stage stage) {      
      //Drawing a Circle 
      Circle circle = new Circle(); 
      
      //Setting the position of the circle 
      circle.setCenterX(300.0f); 
      circle.setCenterY(135.0f); 
      
      //Setting the radius of the circle 
      circle.setRadius(25.0f); 
      
      //Setting the color of the circle 
      circle.setFill(Color.BROWN); 
      
      //Setting the stroke width of the circle 
      circle.setStrokeWidth(20);      
       
      //Setting the text 
      Text text = new Text("Click on the circle to change its color"); 
      
      //Setting the font of the text 
      text.setFont(Font.font(null, FontWeight.BOLD, 15));     
      
      //Setting the color of the text 
      text.setFill(Color.CRIMSON); 
  
      //setting the position of the text 
      text.setX(150); 
      text.setY(50); 
       
      //Creating the mouse event handler 
      EventHandler<MouseEvent> eventHandler = new EventHandler<MouseEvent>() { 
         @Override 
         public void handle(MouseEvent e) { 
            System.out.println("Hello World"); 
            circle.setFill(Color.DARKSLATEBLUE);
         } 
      };  
      //Registering the event filter 
      circle.addEventFilter(MouseEvent.MOUSE_CLICKED, eventHandler);   
       
      //Creating a Group object  
      Group root = new Group(circle, text); 
         
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300); 
       
      //Setting the fill color to the scene 
      scene.setFill(Color.LAVENDER);  
      
      //Setting title to the Stage 
      stage.setTitle("Event Filters Example");       
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   } 
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac EventFiltersExample.java 
java EventFiltersExample

위 프로그램은 실행시 아래와 같이 JavaFX 창을 생성합니다.

이벤트 처리기 추가 및 제거

이벤트 핸들러를 노드에 추가하려면 메소드를 사용하여이 핸들러를 등록해야합니다. addEventHandler()Node 아래와 같이 클래스.

//Creating the mouse event handler 
EventHandler<javafx.scene.input.MouseEvent> eventHandler = 
   new EventHandler<javafx.scene.input.MouseEvent>() { 
   
   @Override 
   public void handle(javafx.scene.input.MouseEvent e) { 
      System.out.println("Hello World"); 
      circle.setFill(Color.DARKSLATEBLUE);             
   } 
};    
//Adding the event handler 
circle.addEventHandler(javafx.scene.input.MouseEvent.MOUSE_CLICKED, eventHandler);

같은 방법으로 아래와 같이 removeEventHandler () 메소드를 사용하여 이벤트 핸들러를 제거 할 수 있습니다.

circle.removeEventHandler(MouseEvent.MOUSE_CLICKED, eventHandler);

다음 프로그램은 이벤트 핸들러를 사용하여 JavaFX에서 이벤트 처리를 보여주는 예제입니다.

이 코드를 이름이있는 파일에 저장 EventHandlersExample.java.

import javafx.animation.RotateTransition; 
import javafx.application.Application; 
import javafx.event.EventHandler; 

import javafx.scene.Group; 
import javafx.scene.PerspectiveCamera; 
import javafx.scene.Scene; 
import javafx.scene.control.TextField; 
import javafx.scene.input.KeyEvent; 
import javafx.scene.paint.Color; 
import javafx.scene.paint.PhongMaterial; 

import javafx.scene.shape.Box; 
import javafx.scene.text.Font; 
import javafx.scene.text.FontWeight; 
import javafx.scene.text.Text;  
import javafx.scene.transform.Rotate; 
import javafx.stage.Stage; 
import javafx.util.Duration; 
         
public class EventHandlersExample extends Application { 
   
   @Override 
   public void start(Stage stage) {
      //Drawing a Box 
      Box box = new Box(); 
      
      //Setting the properties of the Box 
      box.setWidth(150.0); 
      box.setHeight(150.0);   
      box.setDepth(100.0); 
       
      //Setting the position of the box 
      box.setTranslateX(350);  
      box.setTranslateY(150); 
      box.setTranslateZ(50); 
       
      //Setting the text 
      Text text = new Text("Type any letter to rotate the box, 
         and click on the box to stop the rotation"); 
      
      //Setting the font of the text 
      text.setFont(Font.font(null, FontWeight.BOLD, 15));     
      
      //Setting the color of the text 
      text.setFill(Color.CRIMSON); 
      
      //setting the position of the text 
      text.setX(20); 
      text.setY(50); 
       
      //Setting the material of the box 
      PhongMaterial material = new PhongMaterial();  
      material.setDiffuseColor(Color.DARKSLATEBLUE);  
      
      //Setting the diffuse color material to box 
      box.setMaterial(material);       
       
      //Setting the rotation animation to the box    
      RotateTransition rotateTransition = new RotateTransition(); 
      
      //Setting the duration for the transition 
      rotateTransition.setDuration(Duration.millis(1000)); 
      
      //Setting the node for the transition 
      rotateTransition.setNode(box);       
      
      //Setting the axis of the rotation 
      rotateTransition.setAxis(Rotate.Y_AXIS); 
      
      //Setting the angle of the rotation
      rotateTransition.setByAngle(360); 
      
      //Setting the cycle count for the transition 
      rotateTransition.setCycleCount(50); 
      
      //Setting auto reverse value to false 
      rotateTransition.setAutoReverse(false);  
      
      //Creating a text filed 
      TextField textField = new TextField();   
      
      //Setting the position of the text field 
      textField.setLayoutX(50); 
      textField.setLayoutY(100); 
       
      //Handling the key typed event 
      EventHandler<KeyEvent> eventHandlerTextField = new EventHandler<KeyEvent>() { 
         @Override 
         public void handle(KeyEvent event) { 
            //Playing the animation 
            rotateTransition.play(); 
         }           
      };              
      //Adding an event handler to the text feld 
      textField.addEventHandler(KeyEvent.KEY_TYPED, eventHandlerTextField); 
       
      //Handling the mouse clicked event(on box) 
      EventHandler<javafx.scene.input.MouseEvent> eventHandlerBox = 
         new EventHandler<javafx.scene.input.MouseEvent>() { 
         
         @Override 
         public void handle(javafx.scene.input.MouseEvent e) { 
            rotateTransition.stop();  
         } 
      }; 
      //Adding the event handler to the box  
      box.addEventHandler(javafx.scene.input.MouseEvent.MOUSE_CLICKED, eventHandlerBox);
       
      //Creating a Group object
      Group root = new Group(box, textField, text); 
         
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300);      
      
      //Setting camera 
      PerspectiveCamera camera = new PerspectiveCamera(false); 
      camera.setTranslateX(0); 
      camera.setTranslateY(0); 
      camera.setTranslateZ(0); 
      scene.setCamera(camera);  
      
      //Setting title to the Stage 
      stage.setTitle("Event Handlers Example"); 
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   } 
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac EventHandlersExample.java 
java EventHandlersExample

실행시 위의 프로그램은 아래와 같이 텍스트 필드와 3D 상자를 표시하는 JavaFX 창을 생성합니다.

여기에서 텍스트 필드에 문자를 입력하면 3D 상자가 x 축을 따라 회전하기 시작합니다. 상자를 다시 클릭하면 회전이 중지됩니다.

이벤트 처리를위한 편의 방법 사용

JavaFX의 일부 클래스는 이벤트 처리기 속성을 정의합니다. 각각의 setter 메서드를 사용하여 이러한 속성에 값을 설정하면 이벤트 처리기에 등록 할 수 있습니다. 이러한 방법을 편의 방법이라고합니다.

이러한 메서드의 대부분은 Node, Scene, Window 등과 같은 클래스에 존재하며 모든 하위 클래스에서 사용할 수 있습니다.

예를 들어, 버튼에 마우스 이벤트 리스너를 추가하려면 편리한 방법을 사용할 수 있습니다. setOnMouseClicked() 아래 그림과 같이.

playButton.setOnMouseClicked((new EventHandler<MouseEvent>() { 
   public void handle(MouseEvent event) { 
      System.out.println("Hello World"); 
      pathTransition.play(); 
   } 
}));

다음 프로그램은 편의 메소드를 사용하여 JavaFX에서 이벤트 처리를 보여주는 예제입니다.

이 코드를 이름으로 파일에 저장하십시오. ConvinienceMethodsExample.java.

import javafx.animation.PathTransition; 
import javafx.application.Application; 
import static javafx.application.Application.launch; 
import javafx.event.EventHandler; 

import javafx.scene.Group; 
import javafx.scene.Scene; 
import javafx.scene.control.Button; 
import javafx.scene.input.MouseEvent; 
import javafx.scene.paint.Color; 

import javafx.scene.shape.Circle; 
import javafx.scene.shape.LineTo; 
import javafx.scene.shape.MoveTo; 
import javafx.scene.shape.Path; 
import javafx.stage.Stage; 
import javafx.util.Duration; 
         
public class ConvinienceMethodsExample extends Application { 
   @Override 
   public void start(Stage stage) {      
      //Drawing a Circle 
      Circle circle = new Circle(); 
      
      //Setting the position of the circle 
      circle.setCenterX(300.0f); 
      circle.setCenterY(135.0f); 
      
      //Setting the radius of the circle 
      circle.setRadius(25.0f);  
      
      //Setting the color of the circle 
      circle.setFill(Color.BROWN); 
      
      //Setting the stroke width of the circle 
      circle.setStrokeWidth(20);      
       
      //Creating a Path 
      Path path = new Path(); 
      
      //Moving to the staring point 
      MoveTo moveTo = new MoveTo(208, 71);               
      
      //Creating 1st line 
      LineTo line1 = new LineTo(421, 161);        
      
      //Creating 2nd line 
      LineTo line2 = new LineTo(226,232); 
      
      //Creating 3rd line 
      LineTo line3 = new LineTo(332,52);        
      
      //Creating 4th line 
      LineTo line4 = new LineTo(369, 250);        
      
      //Creating 5th line 
      LineTo line5 = new LineTo(208, 71);       
      
      //Adding all the elements to the path 
      path.getElements().add(moveTo); 
      path.getElements().addAll(line1, line2, line3, line4, line5);     
      
      //Creating the path transition 
      PathTransition pathTransition = new PathTransition(); 
      
      //Setting the duration of the transition 
      pathTransition.setDuration(Duration.millis(1000));       
      
      //Setting the node for the transition 
      pathTransition.setNode(circle); 
      
      //Setting the path for the transition 
      pathTransition.setPath(path); 
      
      //Setting the orientation of the path 
      pathTransition.setOrientation(
         PathTransition.OrientationType.ORTHOGONAL_TO_TAN GENT);
      
      //Setting the cycle count for the transition 
      pathTransition.setCycleCount(50); 
      
      //Setting auto reverse value to true 
      pathTransition.setAutoReverse(false);
      
      //Creating play button 
      Button playButton = new Button("Play"); 
      playButton.setLayoutX(300); 
      playButton.setLayoutY(250); 
       
      circle.setOnMouseClicked (new EventHandler<javafx.scene.input.MouseEvent>() { 
         @Override 
         public void handle(javafx.scene.input.MouseEvent e) { 
            System.out.println("Hello World"); 
            circle.setFill(Color.DARKSLATEBLUE);             
         } 
      });   
      playButton.setOnMouseClicked((new EventHandler<MouseEvent>() { 
         public void handle(MouseEvent event) { 
            System.out.println("Hello World");  
            pathTransition.play(); 
         } 
      })); 
       
      //Creating stop button 
      Button stopButton = new Button("stop"); 
      stopButton.setLayoutX(250); 
      stopButton.setLayoutY(250); 
      
      stopButton.setOnMouseClicked((new EventHandler<MouseEvent>() { 
         public void handle(MouseEvent event) { 
            System.out.println("Hello World"); 
            pathTransition.stop(); 
         } 
      }));
      //Creating a Group object  
      Group root = new Group(circle, playButton, stopButton); 
         
      //Creating a scene object 
      Scene scene = new Scene(root, 600, 300); 
      scene.setFill(Color.LAVENDER);  
      
      //Setting title to the Stage 
      stage.setTitle("Convenience Methods Example");  
         
      //Adding scene to the stage 
      stage.setScene(scene); 
         
      //Displaying the contents of the stage 
      stage.show(); 
   } 
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac ConvinienceMethodsExample.java 
java ConvinienceMethodsExample

위 프로그램은 실행시 아래와 같이 JavaFX 창을 생성합니다. 여기에서 재생 버튼을 클릭하여 애니메이션을 시작하고 중지 버튼을 클릭하여 애니메이션을 중지합니다.

모든 사용자 인터페이스는 다음 세 가지 주요 측면을 고려합니다.

  • UI elements− 사용자가 궁극적으로보고 상호 작용하는 핵심 시각적 요소입니다. JavaFX는 기본에서 복잡한 요소까지 광범위하게 사용되는 일반적인 요소 목록을 제공하며이 자습서에서 다룰 것입니다.

  • Layouts− UI 요소가 화면에서 구성되는 방식을 정의하고 GUI (그래픽 사용자 인터페이스)에 최종 모양과 느낌을 제공합니다. 이 부분은 레이아웃 장에서 다룰 것입니다.

  • Behavior− 사용자가 UI 요소와 상호 작용할 때 발생하는 이벤트입니다. 이 부분은 이벤트 처리 장에서 다룹니다.

JavaFX는 패키지에 여러 클래스를 제공합니다. javafx.scene.control. 다양한 GUI 구성 요소 (컨트롤)를 생성하기 위해 JavaFX는 날짜 선택기, 버튼 텍스트 필드 등과 같은 여러 컨트롤을 지원합니다.

각 컨트롤은 클래스로 표시됩니다. 각각의 클래스를 인스턴스화하여 컨트롤을 만들 수 있습니다.

다음은 GUI가 JavaFX를 사용하여 설계되는 동안 일반적으로 사용되는 컨트롤 목록입니다.

S. 아니 제어 및 설명
1

Label

Label 개체는 텍스트를 배치하기위한 구성 요소입니다.

2

Button

이 클래스는 레이블이 지정된 버튼을 만듭니다.

ColorPicker

ColorPicker는 사용자가 색상을 조작하고 선택할 수 있도록 설계된 컨트롤 창을 제공합니다.

4

CheckBox

CheckBox는 on (true) 또는 off (false) 상태 일 수있는 그래픽 구성 요소입니다.

5

RadioButton

RadioButton 클래스는 그룹에서 ON (true) 또는 OFF (false) 상태 일 수있는 그래픽 구성 요소입니다.

6

ListView

ListView 구성 요소는 텍스트 항목의 스크롤 목록을 사용자에게 제공합니다.

7

TextField

TextField 객체는 한 줄의 텍스트를 편집 할 수있는 텍스트 구성 요소입니다.

8

PasswordField

PasswordField 개체는 암호 입력에 특화된 텍스트 구성 요소입니다.

9

Scrollbar

Scrollbar 컨트롤은 사용자가 값 범위에서 선택할 수 있도록 스크롤 막대 구성 요소를 나타냅니다.

10

FileChooser

FileChooser 컨트롤은 사용자가 파일을 선택할 수있는 대화 창을 나타냅니다.

11

ProgressBar

작업이 완료 될 때까지 진행하면 진행률 표시 줄에 작업의 완료율이 표시됩니다.

12

Slider

Slider를 사용하면 제한된 간격 내에서 노브를 밀어 값을 그래픽으로 선택할 수 있습니다.

다음 프로그램은 JavaFX에서 로그인 페이지를 표시하는 예제입니다. 여기에서는 컨트롤을 사용합니다.label, text field, password fieldbutton.

이 코드를 이름으로 파일에 저장하십시오. LoginPage.java.

import javafx.application.Application; 
import static javafx.application.Application.launch; 
import javafx.geometry.Insets; 
import javafx.geometry.Pos; 

import javafx.scene.Scene; 
import javafx.scene.control.Button; 
import javafx.scene.control.PasswordField; 
import javafx.scene.layout.GridPane; 
import javafx.scene.text.Text; 
import javafx.scene.control.TextField; 
import javafx.stage.Stage;  
         
public class LoginPage extends Application { 
   @Override 
   public void start(Stage stage) {      
      //creating label email 
      Text text1 = new Text("Email");       
      
      //creating label password 
      Text text2 = new Text("Password"); 
       
      //Creating Text Filed for email        
      TextField textField1 = new TextField();       
      
      //Creating Text Filed for password        
      PasswordField textField2 = new PasswordField();  
       
      //Creating Buttons 
      Button button1 = new Button("Submit"); 
      Button button2 = new Button("Clear");  
      
      //Creating a Grid Pane 
      GridPane gridPane = new GridPane();    
      
      //Setting size for the pane 
      gridPane.setMinSize(400, 200); 
      
      //Setting the padding  
      gridPane.setPadding(new Insets(10, 10, 10, 10)); 
      
      //Setting the vertical and horizontal gaps between the columns 
      gridPane.setVgap(5); 
      gridPane.setHgap(5);       
      
      //Setting the Grid alignment 
      gridPane.setAlignment(Pos.CENTER); 
       
      //Arranging all the nodes in the grid 
      gridPane.add(text1, 0, 0); 
      gridPane.add(textField1, 1, 0); 
      gridPane.add(text2, 0, 1);       
      gridPane.add(textField2, 1, 1); 
      gridPane.add(button1, 0, 2); 
      gridPane.add(button2, 1, 2); 
       
      //Styling nodes  
      button1.setStyle("-fx-background-color: darkslateblue; -fx-text-fill: white;"); 
      button2.setStyle("-fx-background-color: darkslateblue; -fx-text-fill: white;"); 
       
      text1.setStyle("-fx-font: normal bold 20px 'serif' "); 
      text2.setStyle("-fx-font: normal bold 20px 'serif' ");  
      gridPane.setStyle("-fx-background-color: BEIGE;"); 
       
      //Creating a scene object 
      Scene scene = new Scene(gridPane); 
       
      //Setting title to the Stage 
      stage.setTitle("CSS Example"); 
         
      //Adding scene to the stage 
      stage.setScene(scene);
      
      //Displaying the contents of the stage 
      stage.show(); 
   }      
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac LoginPage.java 
java LoginPage

위 프로그램은 실행시 아래와 같이 JavaFX 창을 생성합니다.

다음 프로그램은 다음과 같은 JavaFX의 컨트롤을 보여주는 등록 양식의 예입니다. Date Picker, Radio Button, Toggle Button, Check Box, List View, Choice List, 기타

이 코드를 이름으로 파일에 저장하십시오. Registration.java.

import javafx.application.Application; 
import javafx.collections.FXCollections; 
import javafx.collections.ObservableList; 

import javafx.geometry.Insets; 
import javafx.geometry.Pos; 

import javafx.scene.Scene; 
import javafx.scene.control.Button; 
import javafx.scene.control.CheckBox; 
import javafx.scene.control.ChoiceBox; 
import javafx.scene.control.DatePicker; 
import javafx.scene.control.ListView; 
import javafx.scene.control.RadioButton; 
import javafx.scene.layout.GridPane; 
import javafx.scene.text.Text; 
import javafx.scene.control.TextField; 
import javafx.scene.control.ToggleGroup;  
import javafx.scene.control.ToggleButton; 
import javafx.stage.Stage; 
         
public class Registration extends Application { 
   @Override 
   public void start(Stage stage) {    
      //Label for name 
      Text nameLabel = new Text("Name"); 
      
      //Text field for name 
      TextField nameText = new TextField(); 
       
      //Label for date of birth 
      Text dobLabel = new Text("Date of birth"); 
      
      //date picker to choose date 
      DatePicker datePicker = new DatePicker(); 
       
      //Label for gender
      Text genderLabel = new Text("gender"); 
      
      //Toggle group of radio buttons       
      ToggleGroup groupGender = new ToggleGroup(); 
      RadioButton maleRadio = new RadioButton("male"); 
      maleRadio.setToggleGroup(groupGender); 
      RadioButton femaleRadio = new RadioButton("female"); 
      femaleRadio.setToggleGroup(groupGender); 
       
      //Label for reservation 
      Text reservationLabel = new Text("Reservation"); 
      
      //Toggle button for reservation 
      ToggleButton Reservation = new ToggleButton(); 
      ToggleButton yes = new ToggleButton("Yes"); 
      ToggleButton no = new ToggleButton("No"); 
      ToggleGroup groupReservation = new ToggleGroup(); 
      yes.setToggleGroup(groupReservation);   
      no.setToggleGroup(groupReservation); 
       
      //Label for technologies known 
      Text technologiesLabel = new Text("Technologies Known"); 
      
      //check box for education 
      CheckBox javaCheckBox = new CheckBox("Java"); 
      javaCheckBox.setIndeterminate(false); 
      
      //check box for education 
      CheckBox dotnetCheckBox = new CheckBox("DotNet"); 
      javaCheckBox.setIndeterminate(false); 
       
      //Label for education 
      Text educationLabel = new Text("Educational qualification"); 
      
      //list View for educational qualification 
      ObservableList<String> names = FXCollections.observableArrayList( 
         "Engineering", "MCA", "MBA", "Graduation", "MTECH", "Mphil", "Phd"); 
      ListView<String> educationListView = new ListView<String>(names); 
      
      //Label for location 
      Text locationLabel = new Text("location"); 
      
      //Choice box for location 
      ChoiceBox locationchoiceBox = new ChoiceBox(); 
      locationchoiceBox.getItems().addAll
         ("Hyderabad", "Chennai", "Delhi", "Mumbai", "Vishakhapatnam"); 
       
      //Label for register 
      Button buttonRegister = new Button("Register");  
      
      //Creating a Grid Pane 
      GridPane gridPane = new GridPane();    
      
      //Setting size for the pane 
      gridPane.setMinSize(500, 500); 
       
      //Setting the padding    
      gridPane.setPadding(new Insets(10, 10, 10, 10));  
      
      //Setting the vertical and horizontal gaps between the columns 
      gridPane.setVgap(5); 
      gridPane.setHgap(5);       
      
      //Setting the Grid alignment 
      gridPane.setAlignment(Pos.CENTER); 
       
      //Arranging all the nodes in the grid 
      gridPane.add(nameLabel, 0, 0); 
      gridPane.add(nameText, 1, 0); 
       
      gridPane.add(dobLabel, 0, 1);       
      gridPane.add(datePicker, 1, 1); 
      
      gridPane.add(genderLabel, 0, 2); 
      gridPane.add(maleRadio, 1, 2);       
      gridPane.add(femaleRadio, 2, 2); 
      gridPane.add(reservationLabel, 0, 3); 
      gridPane.add(yes, 1, 3);       
      gridPane.add(no, 2, 3);  
       
      gridPane.add(technologiesLabel, 0, 4); 
      gridPane.add(javaCheckBox, 1, 4);       
      gridPane.add(dotnetCheckBox, 2, 4);  
       
      gridPane.add(educationLabel, 0, 5); 
      gridPane.add(educationListView, 1, 5);      
       
      gridPane.add(locationLabel, 0, 6); 
      gridPane.add(locationchoiceBox, 1, 6);    
       
      gridPane.add(buttonRegister, 2, 8);      
      
      //Styling nodes   
      buttonRegister.setStyle(
         "-fx-background-color: darkslateblue; -fx-textfill: white;"); 
       
      nameLabel.setStyle("-fx-font: normal bold 15px 'serif' "); 
      dobLabel.setStyle("-fx-font: normal bold 15px 'serif' "); 
      genderLabel.setStyle("-fx-font: normal bold 15px 'serif' "); 
      reservationLabel.setStyle("-fx-font: normal bold 15px 'serif' "); 
      technologiesLabel.setStyle("-fx-font: normal bold 15px 'serif' "); 
      educationLabel.setStyle("-fx-font: normal bold 15px 'serif' "); 
      locationLabel.setStyle("-fx-font: normal bold 15px 'serif' "); 
       
      //Setting the back ground color 
      gridPane.setStyle("-fx-background-color: BEIGE;");       
       
      //Creating a scene object 
      Scene scene = new Scene(gridPane); 
      
      //Setting title to the Stage 
      stage.setTitle("Registration Form"); 
         
      //Adding scene to the stage 
      stage.setScene(scene);  
      
      //Displaying the contents of the stage 
      stage.show(); 
   }      
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac Registration.java 
java Registration

위 프로그램은 실행시 아래와 같이 JavaFX 창을 생성합니다.

일반적으로 차트는 데이터를 그래픽으로 표현한 것입니다. 다음과 같은 데이터를 나타내는 다양한 종류의 차트가 있습니다.Bar Chart, Pie Chart, Line Chart, Scatter Chart, 기타

JavaFX는 다양한 Pie ChartsXY Charts. XY 평면에 표시되는 차트는 다음과 같습니다.AreaChart, BarChart, BubbleChart, LineChart, ScatterChart, StackedAreaChart, StackedBarChart, 기타

각 차트는 클래스로 표시되며 이러한 모든 차트는 패키지에 속합니다. javafx.scene.chart. 명명 된 클래스Chart JavaFX의 모든 차트의 기본 클래스이며 XYChart XY 평면에 그려진 모든 차트의 기본 클래스입니다.

차트 만들기

차트를 만들려면 다음을 수행해야합니다.

  • 차트의 축 정의
  • 각 클래스 인스턴스화
  • 데이터를 준비하고 차트에 전달

각 클래스 인스턴스화

차트를 만들려면 해당 클래스를 인스턴스화하십시오. 예를 들어, 꺾은 선형 차트를 만들려면 다음과 같은 클래스를 인스턴스화해야합니다.Line 다음과 같이-

LineChart linechart = new LineChart(xAxis, yAxis);

위의 코드에서 볼 수 있듯이 인스턴스화하는 동안 차트의 X 및 Y 축을 각각 나타내는 두 개의 개체를 전달해야합니다.

축 정의

일반적으로 차트의 축은 다음과 같이 나타낼 수 있습니다.

  • 인구, 연령 및
  • 요일, 국가와 같은 범주.

JavaFX에서 축은 X 또는 Y 축을 나타내는 추상 클래스입니다. 각 축 유형을 정의하는 두 개의 하위 클래스가 있습니다.CategoryAxisNumberAxis 다음 다이어그램과 같이-

Category Axis−이 클래스를 인스턴스화하여 각 값이 범주를 나타내는 X 또는 Y 축을 정의 (생성) 할 수 있습니다. 아래와 같이이 클래스를 인스턴스화하여 카테고리 축을 정의 할 수 있습니다.

CategoryAxis xAxis = new CategoryAxis();

이 축에는 아래와 같이 범주 및 레이블 목록을 축에 설정해야합니다.

//setting the list of categories.  
xAxis.setCategories(FXCollections.<String>observableArrayList
   (Arrays.asList("n ame1", "name2"….)));  

//Setting label to the axis  
xAxis.setLabel("name of the axis ");

NumberAxis−이 클래스를 인스턴스화하여 각 값이 숫자 값을 나타내는 X 또는 Y 축을 정의 (생성) 할 수 있습니다. 이것과 함께 모든 숫자 유형을 사용할 수 있습니다Axis, Long, Double, BigDecimal등. 다음과 같이이 클래스를 인스턴스화하여 숫자 축을 정의 할 수 있습니다.

//Defining the axis 
NumberAxis yAxis = new NumberAxis();  

//Setting labelto the axis 
yAxis.setLabel("name of the axis");

XY 차트에 데이터 전달

모든 XY 차트는 XY 평면을 따라 표시됩니다. 차트에 점 집합을 그리려면 일련의 XY 좌표를 지정해야합니다.

그만큼 <X,Y> 클래스 javafx.scene.chartpackage는 데이터를 차트로 보낼 수있는 클래스입니다. 이 클래스는 명명 된 시리즈의 관찰 가능한 목록을 보유합니다. 이 목록은getData() 의 방법 XYChart.Series 아래와 같이 클래스-

ObservableList list = series.getData();

어디, series 의 목적입니다 XYChart.Series수업. 다음을 사용하여이 목록에 데이터를 추가 할 수 있습니다.add() 다음과 같이 방법-

list.add(new XYChart.Data(x-axis data, y-axis data));

이 두 줄은 아래와 같이 함께 쓸 수 있습니다.

series.getData().add(new XYChart.Data(x-axis data, y-axis data));

다음 표는 JavaFX에서 제공하는 다양한 차트 (클래스)에 대한 설명을 제공합니다.

S. 아니 차트 및 설명
1 파이 차트

원형 차트는 값을 다른 색상의 원 조각으로 표현한 것입니다. 이러한 조각에는 레이블이 지정되고 각 조각에 해당하는 값이 차트에 표시됩니다.

JavaFX에서 원형 차트는 PieChart. 이 클래스는 패키지에 속합니다.javafx.scene.chart.

2 라인 차트

라인 차트 또는 라인 그래프는 정보를 직선 세그먼트로 연결된 일련의 데이터 포인트 (마커)로 표시합니다. 꺾은 선형 차트는 동일한 시간 빈도에서 데이터가 어떻게 변경되는지 보여줍니다.

JavaFX에서 선형 차트는 다음과 같은 클래스로 표시됩니다. LineChart. 이 클래스는 패키지에 속합니다.javafx.scene.chart. 이 클래스를 인스턴스화하여 JavaFX에서 LineChart 노드를 만들 수 있습니다.

영역 차트

영역 차트는 영역 기반 차트를 그리는 데 사용됩니다. 주어진 일련의 점과 축 사이의 영역을 표시합니다. 일반적으로이 차트는 두 수량을 비교하는 데 사용됩니다.

JavaFX에서 영역 차트는 다음과 같은 클래스로 표시됩니다. AreaChart. 이 클래스는 패키지에 속합니다.javafx.scene.chart. 이 클래스를 인스턴스화하여 JavaFX에서 AreaChart 노드를 만들 수 있습니다.

4 막대 차트

막대 차트는 직사각형 막대를 사용하여 그룹화 된 데이터를 나타내는 데 사용됩니다. 이 막대의 길이는 값을 나타냅니다. 막대 차트의 막대는 세로 또는 가로로 그릴 수 있습니다.

JavaFX에서 막대 차트는 다음과 같은 클래스로 표시됩니다. BarChart. 이 클래스는 패키지에 속합니다.javafx.scene.chart. 이 클래스를 인스턴스화하여 JavaFX에서 BarChart 노드를 만들 수 있습니다.

5 버블 차트

거품 형 차트는 3 차원 데이터를 플래 팅하는 데 사용됩니다. 세 번째 치수는 거품의 크기 (반지름)로 표시됩니다.

JavaFX에서 거품 형 차트는 다음과 같은 클래스로 표시됩니다. BubbleChart. 이 클래스는 패키지에 속합니다.javafx.scene.chart. 이 클래스를 인스턴스화하여 JavaFX에서 BubbleChart 노드를 만들 수 있습니다.

6 분산 형 차트

산점도는 데카르트 평면에 그려진 두 변수의 값을 사용하는 그래프 유형입니다. 일반적으로 두 변수 간의 관계를 찾는 데 사용됩니다.

JavaFX에서 분산 형 차트는 다음과 같은 클래스로 표시됩니다. ScatterChart. 이 클래스는 패키지에 속합니다.javafx.scene.chart. 이 클래스를 인스턴스화하여 JavaFX에서 ScatterChart 노드를 만들 수 있습니다.

7 누적 영역 차트

JavaFX에서 스택 영역 차트는 다음과 같은 클래스로 표시됩니다. StackedAreaChart.

이 클래스는 패키지에 속합니다. javafx.scene.chart. 이 클래스를 인스턴스화하여 JavaFX에서 StackedAreaChart 노드를 만들 수 있습니다.

8 누적 막대 차트

JavaFX에서 누적 막대 차트는 다음과 같은 클래스로 표시됩니다. StackedBarChart.

이 클래스는 패키지에 속합니다. javafx.scene.chart. 이 클래스를 인스턴스화하여 JavaFX에서 StackedBarChart 노드를 만들 수 있습니다.

장면에 필요한 모든 노드를 구성한 후 일반적으로 순서대로 정렬합니다.

컨테이너 내 구성 요소의 이러한 배열을 컨테이너의 레이아웃이라고합니다. 컨테이너 내의 특정 위치에 모든 구성 요소를 배치하는 것을 포함하므로 레이아웃을 따랐다 고 말할 수도 있습니다.

JavaFX는 다음과 같은 미리 정의 된 여러 레이아웃을 제공합니다. HBox, VBox, Border Pane, Stack Pane, Text Flow, Anchor Pane, Title Pane, Grid Pane, Flow Panel

위에서 언급 한 각 레이아웃은 클래스로 표현되며 이러한 모든 클래스는 패키지에 속합니다. javafx.layout. 명명 된 클래스Pane JavaFX의 모든 레이아웃의 기본 클래스입니다.

레이아웃 생성

레이아웃을 생성하려면 다음을 수행해야합니다.

  • 노드를 만듭니다.
  • 필요한 레이아웃의 각 클래스를 인스턴스화합니다.
  • 레이아웃의 속성을 설정합니다.
  • 생성 된 모든 노드를 레이아웃에 추가합니다.

노드 생성

우선, 각각의 클래스를 인스턴스화하여 JavaFX 응용 프로그램의 필수 노드를 만듭니다.

예를 들어, 텍스트 필드와 두 개의 버튼 즉, HBox 레이아웃에서 재생하고 중지하려면 다음 코드 블록에 표시된대로 해당 노드를 먼저 만들어야합니다.

//Creating a text field 
TextField textField = new TextField();       

//Creating the play button 
Button playButton = new Button("Play");       

//Creating the stop button 
Button stopButton = new Button("stop");

각 클래스 인스턴스화

노드를 만들고 노드에 대한 모든 작업을 완료 한 후 필요한 레이아웃의 클래스를 인스턴스화합니다.

예를 들어 Hbox 레이아웃을 생성하려면 다음과 같이이 클래스를 인스턴스화해야합니다.

HBox hbox = new HBox();

레이아웃 속성 설정

클래스를 인스턴스화 한 후 각각의 setter 메서드를 사용하여 레이아웃의 속성을 설정해야합니다.

예 : HBox 레이아웃에서 생성 된 노드 사이에 공간을 설정하려면 spacing이라는 속성에 값을 설정해야합니다. 이것은 setter 메서드를 사용하여 수행 할 수 있습니다.setSpacing() 아래와 같이-

hbox.setSpacing(10);

그룹에 모양 개체 추가

마지막으로 아래와 같이 생성자의 매개 변수로 전달하여 모양의 객체를 그룹에 추가해야합니다.

//Creating a Group object  
Group root = new Group(line);

레이아웃 창

다음은 JavaFX에서 제공하는 다양한 레이아웃 창 (클래스)입니다. 이러한 클래스는 패키지에 있습니다.javafx.scene.layout.

S. 아니 모양 및 설명
1 HBox

HBox 레이아웃은 애플리케이션의 모든 노드를 단일 가로 행으로 정렬합니다.

명명 된 클래스 HBox 패키지의 javafx.scene.layout 텍스트 가로 상자 레이아웃을 나타냅니다.

2 VBox

VBox 레이아웃은 애플리케이션의 모든 노드를 하나의 세로 열에 정렬합니다.

명명 된 클래스 VBox 패키지의 javafx.scene.layout 텍스트 세로 상자 레이아웃을 나타냅니다.

BorderPane

Border Pane 레이아웃은 애플리케이션의 노드를 위쪽, 왼쪽, 오른쪽, 아래쪽 및 가운데 위치로 정렬합니다.

명명 된 클래스 BorderPane 패키지의 javafx.scene.layout 테두리 창 레이아웃을 나타냅니다.

4 StackPane

스택 창 레이아웃은 스택에서와 마찬가지로 애플리케이션의 노드를 다른 노드 위에 정렬합니다. 먼저 추가 된 노드는 스택 맨 아래에 배치되고 다음 노드는 스택 맨 위에 배치됩니다.

명명 된 클래스 StackPane 패키지의 javafx.scene.layout 스택 창 레이아웃을 나타냅니다.

5 TextFlow

텍스트 흐름 레이아웃은 단일 흐름에서 여러 텍스트 노드를 정렬합니다.

명명 된 클래스 TextFlow 패키지의 javafx.scene.layout 텍스트 흐름 레이아웃을 나타냅니다.

6 AnchorPane

앵커 창 레이아웃은 창에서 특정 거리에 애플리케이션의 노드를 고정합니다.

명명 된 클래스 AnchorPane 패키지의 javafx.scene.layout 앵커 창 레이아웃을 나타냅니다.

7 TilePane

Tile Pane 레이아웃은 균일 한 크기의 타일 형태로 애플리케이션의 모든 노드를 추가합니다.

명명 된 클래스 TilePane 패키지의 javafx.scene.layout TilePane 레이아웃을 나타냅니다.

8 GridPane

Grid Pane 레이아웃은 애플리케이션의 노드를 행과 열의 그리드로 정렬합니다. 이 레이아웃은 JavaFX를 사용하여 양식을 만드는 동안 편리합니다.

명명 된 클래스 GridPane 패키지의 javafx.scene.layout GridPane 레이아웃을 나타냅니다.

9 FlowPane

흐름 패널 레이아웃은 흐름의 모든 노드를 래핑합니다. 수평 흐름 창은 창의 요소를 높이로 감싸고 수직 흐름 창은 요소를 너비로 감 쌉니다.

명명 된 클래스 FlowPane 패키지의 javafx.scene.layout 흐름 창 레이아웃을 나타냅니다.

Cascading Style SheetsCSS라고도하는은 웹 페이지를 표시 가능하게 만드는 프로세스를 단순화하기위한 단순한 디자인 언어입니다.

CSS는 웹 페이지의 룩앤필 부분을 처리합니다. CSS를 사용하여 텍스트 색상, 글꼴 스타일, 단락 간격, 열 크기 및 레이아웃을 제어 할 수 있습니다. 이 외에도 사용되는 배경 이미지 또는 색상, 레이아웃 디자인, 다양한 장치 및 화면 크기에 대한 디스플레이의 변형 및 기타 다양한 효과를 제어 할 수도 있습니다.

JavaFX의 CSS

JavaFX는 CSS를 사용하여 응용 프로그램의 모양과 느낌을 향상시키는 기능을 제공합니다. 패키지javafx.css JavaFX 응용 프로그램에 CSS를 적용하는 데 사용되는 클래스가 포함되어 있습니다.

CSS는 브라우저에서 해석 한 다음 문서의 해당 요소에 적용되는 스타일 규칙으로 구성됩니다.

스타일 규칙은 세 부분으로 구성됩니다.

  • Selector− 선택기는 스타일이 적용될 HTML 태그입니다. 다음과 같은 태그가 될 수 있습니다.<h1> 또는 <table>

  • Property− 속성은 HTML 태그의 속성 유형입니다. 간단히 말해서 모든 HTML 속성은 CSS 속성으로 변환됩니다. 색깔 일 수도 있고border

  • Value− 속성에 값이 할당됩니다. 예를 들어 색상 속성은 다음 중 하나의 값을 가질 수 있습니다.red 또는 #F1F1F1

다음과 같이 CSS 스타일 규칙 구문을 넣을 수 있습니다-

selector { property: value }

JavaFX에서 사용하는 기본 스타일 시트는 다음과 같습니다. modena.css. JavaFX 런타임 jar에 있습니다.

자신 만의 스타일 시트 추가

다음과 같이 JavaFX의 장면에 자신 만의 스타일 시트를 추가 할 수 있습니다.

Scene scene = new Scene(new Group(), 500, 400); 
scene.getStylesheets().add("path/stylesheet.css");

인라인 스타일 시트 추가

다음을 사용하여 인라인 스타일을 추가 할 수도 있습니다. setStyle()방법. 이러한 스타일은 키-값 쌍으로 만 구성되며 설정된 노드에 적용 할 수 있습니다. 다음은 인라인 스타일 시트를 버튼으로 설정하는 샘플 코드입니다.

.button { 
   -fx-background-color: red; 
   -fx-text-fill: white; 
}

텍스트 필드, 암호 필드, 두 개의 버튼이있는 양식을 표시하는 JavaFX 애플리케이션을 개발했다고 가정합니다. 기본적으로이 양식은 다음 스크린 샷과 같이 보입니다.

다음 프로그램은 JavaFX에서 위의 응용 프로그램에 스타일을 추가하는 방법을 보여주는 예제입니다.

이 코드를 이름으로 파일에 저장하십시오. CssExample.java

import javafx.application.Application; 
import static javafx.application.Application.launch; 
import javafx.geometry.Insets; 
import javafx.geometry.Pos; 
import javafx.scene.Scene; 
import javafx.scene.control.Button; 
import javafx.scene.control.PasswordField; 
import javafx.scene.layout.GridPane; 
import javafx.scene.text.Text; 
import javafx.scene.control.TextField; 
import javafx.stage.Stage;  

public class CssExample extends Application { 
   @Override 
   public void start(Stage stage) {      
      //creating label email 
      Text text1 = new Text("Email");       
      
      //creating label password 
      Text text2 = new Text("Password"); 
       
      //Creating Text Filed for email        
      TextField textField1 = new TextField();       
      
      //Creating Text Filed for password        
      PasswordField textField2 = new PasswordField();  
       
      //Creating Buttons 
      Button button1 = new Button("Submit"); 
      Button button2 = new Button("Clear");  
      
      //Creating a Grid Pane 
      GridPane gridPane = new GridPane();    
      
      //Setting size for the pane 
      gridPane.setMinSize(400, 200);
      
      //Setting the padding  
      gridPane.setPadding(new Insets(10, 10, 10, 10)); 
      
      //Setting the vertical and horizontal gaps between the columns 
      gridPane.setVgap(5); 
      gridPane.setHgap(5);       
      
      //Setting the Grid alignment 
      gridPane.setAlignment(Pos.CENTER); 
       
      //Arranging all the nodes in the grid 
      gridPane.add(text1, 0, 0); 
      gridPane.add(textField1, 1, 0); 
      gridPane.add(text2, 0, 1);       
      gridPane.add(textField2, 1, 1); 
      gridPane.add(button1, 0, 2); 
      gridPane.add(button2, 1, 2); 
       
      //Styling nodes  
      button1.setStyle("-fx-background-color: darkslateblue; -fx-text-fill: white;"); 
      button2.setStyle("-fx-background-color: darkslateblue; -fx-text-fill: white;"); 
       
      text1.setStyle("-fx-font: normal bold 20px 'serif' "); 
      text2.setStyle("-fx-font: normal bold 20px 'serif' ");  
      gridPane.setStyle("-fx-background-color: BEIGE;"); 
       
      // Creating a scene object 
      Scene scene = new Scene(gridPane); 
       
      // Setting title to the Stage   
      stage.setTitle("CSS Example"); 
         
      // Adding scene to the stage 
      stage.setScene(scene);
      
      //Displaying the contents of the stage 
      stage.show(); 
   } 
   public static void main(String args[]){ 
      launch(args); 
   } 
}

다음 명령을 사용하여 명령 프롬프트에서 저장된 Java 파일을 컴파일하고 실행합니다.

javac CssExample.java 
java CssExample

위 프로그램은 실행시 아래와 같이 JavaFX 창을 생성합니다.