2016-06-19 18:23:36 +00:00
|
|
|
# Frameless 윈도우
|
2015-06-25 17:32:51 +00:00
|
|
|
|
2016-04-30 16:53:21 +00:00
|
|
|
> 툴바, 테두리, 시각적인 "chrome" 없이 윈도우를 엽니다.
|
|
|
|
|
2016-06-19 18:23:36 +00:00
|
|
|
Frameless 윈도우는 [창 테두리](https://developer.mozilla.org/ko/docs/Glossary/Chrome)가
|
2016-01-23 17:33:45 +00:00
|
|
|
없는 윈도우를 말합니다. 이 기능은 윈도우의 일부분인 툴바와 같이 웹 페이지의 일부분이
|
2015-11-19 19:46:05 +00:00
|
|
|
아닌 부분을 보이지 않도록 합니다. [`BrowserWindow`](browser-window.md) 클래스의
|
|
|
|
옵션에서 설정할 수 있습니다.
|
2015-06-25 17:32:51 +00:00
|
|
|
|
2016-06-19 18:23:36 +00:00
|
|
|
## Frameless 윈도우 만들기
|
2015-06-25 17:32:51 +00:00
|
|
|
|
2016-06-19 18:23:36 +00:00
|
|
|
Frameless 윈도우를 만드려면 [BrowserWindow](browser-window.md) 객체의
|
2015-11-19 19:46:05 +00:00
|
|
|
`options` 객체에서 `frame` 옵션을 `false`로 지정하면 됩니다:
|
2015-06-25 17:32:51 +00:00
|
|
|
|
|
|
|
```javascript
|
2016-06-12 18:28:11 +00:00
|
|
|
const {BrowserWindow} = require('electron')
|
|
|
|
let win = new BrowserWindow({width: 800, height: 600, frame: false})
|
2015-06-25 17:32:51 +00:00
|
|
|
```
|
|
|
|
|
2016-06-18 13:26:26 +00:00
|
|
|
### 최신 macOS에서 사용할 수 있는 대안
|
2015-09-15 00:50:28 +00:00
|
|
|
|
2016-09-15 16:27:10 +00:00
|
|
|
macOS 10.9 Mavericks 이후의 최신 버전부터는 테두리가 없는 창을 만들 때 새로운 방법을
|
2015-11-19 19:46:05 +00:00
|
|
|
사용할 수 있습니다. `frame` 옵션을 `false`로 지정하여 제목과 창 구성 요소를 모두
|
2016-01-21 17:39:37 +00:00
|
|
|
비활성화하는 대신 새로운 `titleBarStyle` 옵션을 통해 제목만 숨기고 창 구성 요소
|
2016-05-10 18:14:06 +00:00
|
|
|
("신호등 버튼")의 기능과 창 크기를 그대로 유지할 수 있습니다:
|
2015-09-15 00:50:28 +00:00
|
|
|
|
2016-10-28 08:42:57 +00:00
|
|
|
#### `hidden`
|
|
|
|
|
|
|
|
제목 표시줄을 숨기고 컨텐츠 창을 전체 크기로 합니다. 제목 표시줄은 여전히 왼쪽
|
|
|
|
상단에 표준 창 컨트롤 (“신호등”) 을 가지고 있습니다.
|
|
|
|
|
2015-09-15 00:50:28 +00:00
|
|
|
```javascript
|
2016-10-28 08:42:57 +00:00
|
|
|
const {BrowserWindow} = require('electron')
|
2016-06-12 18:28:11 +00:00
|
|
|
let win = new BrowserWindow({titleBarStyle: 'hidden'})
|
2016-10-28 08:42:57 +00:00
|
|
|
win.show()
|
|
|
|
```
|
|
|
|
|
|
|
|
#### `hidden-inset`
|
|
|
|
|
|
|
|
제목 표시줄을 숨기고 창 가장자리에 약간 더 들어간 신호등 버튼 모양으로
|
|
|
|
대체합니다.
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
const {BrowserWindow} = require('electron')
|
|
|
|
let win = new BrowserWindow({titleBarStyle: 'hidden-inset'})
|
|
|
|
win.show()
|
2015-11-16 03:15:21 +00:00
|
|
|
```
|
2015-09-15 00:50:28 +00:00
|
|
|
|
2015-07-12 04:23:54 +00:00
|
|
|
## 투명한 창 만들기
|
2015-06-25 17:32:51 +00:00
|
|
|
|
2016-06-19 18:23:36 +00:00
|
|
|
Frameless 윈도우 창의 배경을 투명하게 만들고 싶다면 `transparent` 옵션을 `true`로
|
2015-11-19 19:46:05 +00:00
|
|
|
바꿔주기만 하면됩니다:
|
2015-06-25 17:32:51 +00:00
|
|
|
|
|
|
|
```javascript
|
2016-06-12 18:28:11 +00:00
|
|
|
let win = new BrowserWindow({transparent: true, frame: false})
|
2015-06-25 17:32:51 +00:00
|
|
|
```
|
|
|
|
|
2015-07-08 03:33:23 +00:00
|
|
|
### API의 한계
|
2015-06-25 17:32:51 +00:00
|
|
|
|
2015-11-19 19:46:05 +00:00
|
|
|
* 투명한 영역을 통과하여 클릭할 수 없습니다. 우리는 이 문제를 해결하기 위해 API를
|
2016-01-11 04:11:10 +00:00
|
|
|
제공할 예정이며 자세한 내용은
|
2016-03-31 23:49:59 +00:00
|
|
|
[이슈](https://github.com/electron/electron/issues/1335)를 참고하세요.
|
2015-11-19 19:46:05 +00:00
|
|
|
* 투명한 창은 크기를 조절할 수 없습니다. `resizable` 속성을 `true`로 할 경우 몇몇
|
|
|
|
플랫폼에선 크래시가 일어납니다.
|
2016-04-30 16:11:21 +00:00
|
|
|
* `blur` 필터는 웹 페이지에서만 적용됩니다. 윈도우 아래 콘텐츠에는 블러 효과를 적용할
|
2016-06-12 17:51:35 +00:00
|
|
|
방법이 없습니다. (예시: 유저의 시스템에 열린 다른 애플리케이션)
|
2015-11-19 19:46:05 +00:00
|
|
|
* Windows에선 DWM(데스크톱 창 관리자)가 비활성화되어 있을 경우 투명한 창이 작동하지
|
|
|
|
않습니다.
|
2015-08-31 05:48:47 +00:00
|
|
|
* Linux를 사용할 경우 [alpha channel doesn't work on some NVidia drivers](https://code.google.com/p/chromium/issues/detail?id=369209)
|
2015-11-19 19:46:05 +00:00
|
|
|
upstream 버그가 있는 관계로 투명한 창 기능을 사용하려면 CLI 옵션에
|
|
|
|
`--enable-transparent-visuals --disable-gpu`을 추가해야 합니다. 이 옵션은 GPU의
|
|
|
|
사용을 중단하고 윈도우를 생성하는데 ARGB를 사용할 수 있도록 해줍니다.
|
2016-06-18 13:26:26 +00:00
|
|
|
* macOS(Mac)에선 네이티브 창에서 보여지는 그림자가 투명한 창에선 보이지 않습니다.
|
2015-06-25 17:32:51 +00:00
|
|
|
|
2016-06-12 18:28:11 +00:00
|
|
|
## 클릭이 통과될 수 있는 윈도우
|
|
|
|
|
|
|
|
클릭이 통과될 수 있는 윈도우를 만드려면, i.e. 모든 마우스 이벤트를 무시하는 윈도우를
|
|
|
|
만드려면, [win.setIgnoreMouseEvents(ignore)][ignore-mouse-events] API를 사용하여
|
|
|
|
구현할 수 있습니다:
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
win.setIgnoreMouseEvents(true)
|
|
|
|
```
|
|
|
|
|
2015-07-08 03:33:23 +00:00
|
|
|
## 드래그 가능 위치 지정
|
2015-06-25 17:32:51 +00:00
|
|
|
|
2016-06-19 18:23:36 +00:00
|
|
|
기본적으로 Frameless 윈도우는 드래그 할 수 없습니다. 애플리케이션의 CSS에서 특정
|
2015-11-19 19:46:05 +00:00
|
|
|
범위를 `-webkit-app-region: drag`로 지정하면 OS의 기본 타이틀 바 처럼 드래그 되도록
|
|
|
|
할 수 있습니다. 그리고 `-webkit-app-region: no-drag`를 지정해서 드래그 불가능 영역을
|
|
|
|
만들 수도 있습니다. 현재 사각형 형태의 범위만 지원합니다.
|
2015-06-25 17:32:51 +00:00
|
|
|
|
2015-11-19 19:46:05 +00:00
|
|
|
창 전체를 드래그 가능하게 만드려면 `-webkit-app-region: drag`을 `body`의 스타일에
|
|
|
|
지정하면 됩니다:
|
2015-06-25 17:32:51 +00:00
|
|
|
|
|
|
|
```html
|
|
|
|
<body style="-webkit-app-region: drag">
|
|
|
|
</body>
|
|
|
|
```
|
|
|
|
|
2015-11-19 19:46:05 +00:00
|
|
|
참고로 창 전체를 드래그 영역으로 지정할 경우 사용자가 버튼을 클릭할 수 없게 되므로
|
|
|
|
버튼은 드래그 불가능 영역으로 지정해야 합니다:
|
2015-06-25 17:32:51 +00:00
|
|
|
|
|
|
|
```css
|
|
|
|
button {
|
|
|
|
-webkit-app-region: no-drag;
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2015-11-19 19:46:05 +00:00
|
|
|
따로 커스텀 타이틀 바를 만들어 사용할 때는 타이틀 바 내부의 모든 버튼을 드래그 불가
|
|
|
|
영역으로 지정해야 합니다.
|
2015-06-25 17:32:51 +00:00
|
|
|
|
2015-07-08 03:33:23 +00:00
|
|
|
## 텍스트 선택
|
2015-06-25 17:32:51 +00:00
|
|
|
|
2016-06-19 18:23:36 +00:00
|
|
|
Frameless 윈도우에서 텍스트가 선택되는 드래그 동작은 혼란을 야기할 수 있습니다. 예를
|
2015-11-19 19:46:05 +00:00
|
|
|
들어 타이틀 바를 드래그 할 때 타이틀 바의 텍스트를 실수로 선택할 수 있습니다. 이를
|
|
|
|
방지하기 위해 다음과 같이 드래그 영역의 텍스트 선택 기능을 비활성화해야 할 필요가
|
|
|
|
있습니다:
|
2015-06-25 17:32:51 +00:00
|
|
|
|
|
|
|
```css
|
|
|
|
.titlebar {
|
|
|
|
-webkit-user-select: none;
|
|
|
|
-webkit-app-region: drag;
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2015-07-08 03:33:23 +00:00
|
|
|
## 컨텍스트 메뉴
|
2015-06-25 17:32:51 +00:00
|
|
|
|
2015-11-19 19:46:05 +00:00
|
|
|
몇몇 플랫폼에선 드래그 가능 영역이 non-client 프레임으로 처리됩니다. 이러한 플랫폼에선
|
|
|
|
드래그 가능 영역에서 오른쪽 클릭 할 경우 시스템 메뉴가 팝업 됩니다. 이러한 이유로
|
|
|
|
컨텍스트 메뉴 지정 시 모든 플랫폼에서 정상적으로 작동하게 하려면 커스텀 컨텍스트 메뉴를
|
|
|
|
드래그 영역 내에 만들어선 안됩니다.
|
2016-06-12 18:28:11 +00:00
|
|
|
|
|
|
|
[ignore-mouse-events]: browser-window.md#winsetignoremouseeventsignore
|