티스토리 뷰

snapshot 메소드를 이용해 Node 이미지 파일로 캡쳐하기



 이번시간에는 JavaFX에서 특정 영역을 캡쳐 하고 싶거나 어떤 Node를 이미지 파일로 저장하고 싶을 때가 있습니다. 이럴때 간단하게 해결할 수 있는 방법을 소개할까 합니다. 


 바로 snapshot 메소드를 이용하는 방법입니다. snapshot 메소드는 Node 클래스에서 제공을 하는 메소드 입니다. Node는 모든 컨트롤의 먼 조상이죠. 그래서 snapshot은 Node 별로 따로 캡쳐가 가능합니다. 사용법을 보시죠.


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
 private Pane chartContainer;
 
 private void doSave(){
    FileChooser fileChooser = new FileChooser();
    File file = fileChooser.showSaveDialog(context.getScene().getWindow());
    if (file != null) {
       saveFile(file);
    }
  }
 
 private void saveFile(File file){
    WritableImage image = new WritableImage(920440);
    chartContainer.snapshot(null, image);
    File imageFile = file;
    try{
      ImageIO.write(SwingFXUtils.fromFXImage(image, null), "png",  imageFile);
    } catch (IOException e) {
      e.printStackTrace();
    }
  }
cs


 원리를 보자면 WritableImage 객체를 생성하고 사이즈를 조정합니다. 그리고 snapshot 메소드를 부를때 인자로 넘겨주게 되면 캡쳐된 이미지가 쓰여지게 됩니다. 그럼 이제 새로 생성한 File 객체에다가 png 포맷인 이미지 파일로 저장을 할 수 있게 되는 형식입니다. 간단하죠?


 chartContainer는 Chart가 들어있는 Pane입니다. Chart 부분은 넣지 않았습니다.






■ 결과 화면




 봐주셔서 감사합니다.

반응형
댓글