Update as upstream
This commit is contained in:
parent
05def654c3
commit
0f648f4468
5 changed files with 89 additions and 34 deletions
|
@ -27,6 +27,8 @@ window.addEventListener('contextmenu', function (e) {
|
||||||
|
|
||||||
다음 예제는 template API를 활용하여 어플리케이션 메뉴를 만드는 간단한 예제입니다:
|
다음 예제는 template API를 활용하여 어플리케이션 메뉴를 만드는 간단한 예제입니다:
|
||||||
|
|
||||||
|
**Windows 와 Linux 주의:** 각 메뉴 아이템의 `selector` 멤버는 Mac 운영체제 전용입니다. [Accelerator 옵션](https://github.com/atom/electron/blob/master/docs/api/accelerator-ko.md)
|
||||||
|
|
||||||
```html
|
```html
|
||||||
<!-- index.html -->
|
<!-- index.html -->
|
||||||
<script>
|
<script>
|
||||||
|
@ -52,12 +54,12 @@ var template = [
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'Hide Electron',
|
label: 'Hide Electron',
|
||||||
accelerator: 'Command+H',
|
accelerator: 'CmdOrCtrl+H',
|
||||||
selector: 'hide:'
|
selector: 'hide:'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'Hide Others',
|
label: 'Hide Others',
|
||||||
accelerator: 'Command+Shift+H',
|
accelerator: 'CmdOrCtrl+Shift+H',
|
||||||
selector: 'hideOtherApplications:'
|
selector: 'hideOtherApplications:'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -69,7 +71,7 @@ var template = [
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'Quit',
|
label: 'Quit',
|
||||||
accelerator: 'Command+Q',
|
accelerator: 'CmdOrCtrl+Q',
|
||||||
selector: 'terminate:'
|
selector: 'terminate:'
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
|
@ -79,12 +81,12 @@ var template = [
|
||||||
submenu: [
|
submenu: [
|
||||||
{
|
{
|
||||||
label: 'Undo',
|
label: 'Undo',
|
||||||
accelerator: 'Command+Z',
|
accelerator: 'CmdOrCtrl+Z',
|
||||||
selector: 'undo:'
|
selector: 'undo:'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'Redo',
|
label: 'Redo',
|
||||||
accelerator: 'Shift+Command+Z',
|
accelerator: 'Shift+CmdOrCtrl+Z',
|
||||||
selector: 'redo:'
|
selector: 'redo:'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -92,22 +94,22 @@ var template = [
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'Cut',
|
label: 'Cut',
|
||||||
accelerator: 'Command+X',
|
accelerator: 'CmdOrCtrl+X',
|
||||||
selector: 'cut:'
|
selector: 'cut:'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'Copy',
|
label: 'Copy',
|
||||||
accelerator: 'Command+C',
|
accelerator: 'CmdOrCtrl+C',
|
||||||
selector: 'copy:'
|
selector: 'copy:'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'Paste',
|
label: 'Paste',
|
||||||
accelerator: 'Command+V',
|
accelerator: 'CmdOrCtrl+V',
|
||||||
selector: 'paste:'
|
selector: 'paste:'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'Select All',
|
label: 'Select All',
|
||||||
accelerator: 'Command+A',
|
accelerator: 'CmdOrCtrl+A',
|
||||||
selector: 'selectAll:'
|
selector: 'selectAll:'
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
@ -117,12 +119,12 @@ var template = [
|
||||||
submenu: [
|
submenu: [
|
||||||
{
|
{
|
||||||
label: 'Reload',
|
label: 'Reload',
|
||||||
accelerator: 'Command+R',
|
accelerator: 'CmdOrCtrl+R',
|
||||||
click: function() { remote.getCurrentWindow().reload(); }
|
click: function() { remote.getCurrentWindow().reload(); }
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'Toggle DevTools',
|
label: 'Toggle DevTools',
|
||||||
accelerator: 'Alt+Command+I',
|
accelerator: 'Alt+CmdOrCtrl+I',
|
||||||
click: function() { remote.getCurrentWindow().toggleDevTools(); }
|
click: function() { remote.getCurrentWindow().toggleDevTools(); }
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
|
@ -132,12 +134,12 @@ var template = [
|
||||||
submenu: [
|
submenu: [
|
||||||
{
|
{
|
||||||
label: 'Minimize',
|
label: 'Minimize',
|
||||||
accelerator: 'Command+M',
|
accelerator: 'CmdOrCtrl+M',
|
||||||
selector: 'performMiniaturize:'
|
selector: 'performMiniaturize:'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: 'Close',
|
label: 'Close',
|
||||||
accelerator: 'Command+W',
|
accelerator: 'CmdOrCtrl+W',
|
||||||
selector: 'performClose:'
|
selector: 'performClose:'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|
|
@ -124,4 +124,8 @@ var appIcon = new Tray('/Users/somebody/images/icon.png');
|
||||||
|
|
||||||
해당 이미지를 템플릿 이미지로 설정합니다.
|
해당 이미지를 템플릿 이미지로 설정합니다.
|
||||||
|
|
||||||
|
### NativeImage.isTemplateImage()
|
||||||
|
|
||||||
|
이미지가 템플릿 이미지인지 확인합니다.
|
||||||
|
|
||||||
[buffer]: https://iojs.org/api/buffer.html#buffer_class_buffer
|
[buffer]: https://iojs.org/api/buffer.html#buffer_class_buffer
|
||||||
|
|
|
@ -18,16 +18,16 @@ app.on('ready', function() {
|
||||||
|
|
||||||
## Event: suspend
|
## Event: suspend
|
||||||
|
|
||||||
시스템이 절전모드로 진입할 때 호출됩니다.
|
시스템이 절전모드로 진입할 때 발생하는 이벤트입니다.
|
||||||
|
|
||||||
## Event: resume
|
## Event: resume
|
||||||
|
|
||||||
시스템의 절전모드가 해제될 때 호출됩니다.
|
시스템의 절전모드가 해제될 때 발생하는 이벤트입니다.
|
||||||
|
|
||||||
## Event: on-ac
|
## Event: on-ac
|
||||||
|
|
||||||
시스템이 AC 어뎁터 충전기를 사용하기 시작할 때 호출됩니다.
|
시스템이 AC 어뎁터 충전기를 사용하기 시작할 때 발생하는 이벤트입니다.
|
||||||
|
|
||||||
## Event: on-battery
|
## Event: on-battery
|
||||||
|
|
||||||
시스템이 배터리를 사용하기 시작할 때 호출됩니다.
|
시스템이 배터리를 사용하기 시작할 때 발생하는 이벤트입니다.
|
||||||
|
|
|
@ -44,20 +44,28 @@ __플랫폼별 한계:__
|
||||||
|
|
||||||
### Event: 'clicked'
|
### Event: 'clicked'
|
||||||
|
|
||||||
* `event`
|
* `event` Event
|
||||||
|
* `altKey` Boolean
|
||||||
|
* `shiftKey` Boolean
|
||||||
|
* `ctrlKey` Boolean
|
||||||
|
* `metaKey` Boolean
|
||||||
* `bounds` Object - 트레이 아이콘의 범위
|
* `bounds` Object - 트레이 아이콘의 범위
|
||||||
* `x` Integer
|
* `x` Integer
|
||||||
* `y` Integer
|
* `y` Integer
|
||||||
* `width` Integer
|
* `width` Integer
|
||||||
* `height` Integer
|
* `height` Integer
|
||||||
|
|
||||||
트레이 아이콘이 클릭될 때 호출됩니다.
|
트레이 아이콘이 클릭될 때 발생하는 이벤트입니다.
|
||||||
|
|
||||||
__주의:__ `bounds`는 OS X와 Window 7 이후 버전에서만 작동합니다.
|
__주의:__ `bounds`는 OS X 와 Windows 7 이후 버전에서만 작동합니다.
|
||||||
|
|
||||||
### Event: 'right-clicked'
|
### Event: 'right-clicked'
|
||||||
|
|
||||||
* `event`
|
* `event` Event
|
||||||
|
* `altKey` Boolean
|
||||||
|
* `shiftKey` Boolean
|
||||||
|
* `ctrlKey` Boolean
|
||||||
|
* `metaKey` Boolean
|
||||||
* `bounds` Object - 트레이 아이콘의 범위
|
* `bounds` Object - 트레이 아이콘의 범위
|
||||||
* `x` Integer
|
* `x` Integer
|
||||||
* `y` Integer
|
* `y` Integer
|
||||||
|
@ -66,30 +74,40 @@ __주의:__ `bounds`는 OS X와 Window 7 이후 버전에서만 작동합니다.
|
||||||
|
|
||||||
트레이 아이콘을 오른쪽 클릭될 때 호출 됩니다.
|
트레이 아이콘을 오른쪽 클릭될 때 호출 됩니다.
|
||||||
|
|
||||||
__주의:__ 이 기능은 Windows와 OS X에서만 사용할 수 있습니다.
|
__주의:__ 이 기능은 OS X 와 Windows 운영체제에서만 작동합니다.
|
||||||
Windows에서는 이 이벤트가 컨텍스트 메뉴를 가지고 있을 때만 호출됩니다.
|
|
||||||
|
|
||||||
### Event: 'double-clicked'
|
### Event: 'double-clicked'
|
||||||
|
|
||||||
트레이 아이콘이 더블 클릭될 때 호출됩니다.
|
* `event` Event
|
||||||
|
* `altKey` Boolean
|
||||||
|
* `shiftKey` Boolean
|
||||||
|
* `ctrlKey` Boolean
|
||||||
|
* `metaKey` Boolean
|
||||||
|
* `bounds` Object - 트레이 아이콘의 범위
|
||||||
|
* `x` Integer
|
||||||
|
* `y` Integer
|
||||||
|
* `width` Integer
|
||||||
|
* `height` Integer
|
||||||
|
|
||||||
__주의:__ 이 기능은 OS X에서만 작동합니다.
|
트레이 아이콘이 더블 클릭될 때 발생하는 이벤트입니다.
|
||||||
|
|
||||||
|
__주의:__ 이 기능은 OS X 와 Windows 운영체제에서만 작동합니다.
|
||||||
|
|
||||||
### Event: 'balloon-show'
|
### Event: 'balloon-show'
|
||||||
|
|
||||||
알림풍선이 보여질 때 호출됩니다.
|
알림풍선이 보여질 때 발생하는 이벤트입니다.
|
||||||
|
|
||||||
__주의:__ 이 기능은 Windows에서만 작동합니다.
|
__주의:__ 이 기능은 Windows에서만 작동합니다.
|
||||||
|
|
||||||
### Event: 'balloon-clicked'
|
### Event: 'balloon-clicked'
|
||||||
|
|
||||||
알림풍선이 클릭될 때 호출됩니다.
|
알림풍선이 클릭될 때 발생하는 이벤트입니다.
|
||||||
|
|
||||||
__주의:__ 이 기능은 Windows에서만 작동합니다.
|
__주의:__ 이 기능은 Windows에서만 작동합니다.
|
||||||
|
|
||||||
### Event: 'balloon-closed'
|
### Event: 'balloon-closed'
|
||||||
|
|
||||||
알림풍선이 시간이 지나 사라지거나 유저가 클릭하여 닫을 때 호출됩니다.
|
알림풍선이 시간이 지나 사라지거나 유저가 클릭하여 닫을 때 발생하는 이벤트입니다.
|
||||||
|
|
||||||
__주의:__ 이 기능은 Windows에서만 작동합니다.
|
__주의:__ 이 기능은 Windows에서만 작동합니다.
|
||||||
|
|
||||||
|
@ -98,7 +116,7 @@ __주의:__ 이 기능은 Windows에서만 작동합니다.
|
||||||
* `event`
|
* `event`
|
||||||
* `files` Array - 드롭된 파일의 경로
|
* `files` Array - 드롭된 파일의 경로
|
||||||
|
|
||||||
트레이 아이콘에 파일이 드롭되면 호출됩니다.
|
트레이 아이콘에 파일이 드롭되면 발생하는 이벤트입니다.
|
||||||
|
|
||||||
__주의:__ 이 기능은 OS X에서만 작동합니다.
|
__주의:__ 이 기능은 OS X에서만 작동합니다.
|
||||||
|
|
||||||
|
@ -159,9 +177,10 @@ __알림:__ 이 기능은 Windows에서만 작동합니다.
|
||||||
* `x` Integer
|
* `x` Integer
|
||||||
* `y` Integer
|
* `y` Integer
|
||||||
|
|
||||||
__주의:__ 이 기능은 Windows와 OS X에서만 작동합니다.
|
|
||||||
`position`은 Windows에서만 사용할 수 있으며 기본값은 (0, 0)입니다.
|
`position`은 Windows에서만 사용할 수 있으며 기본값은 (0, 0)입니다.
|
||||||
|
|
||||||
|
__주의:__ 이 기능은 Windows 와 OS X에서만 작동합니다.
|
||||||
|
|
||||||
### Tray.setContextMenu(menu)
|
### Tray.setContextMenu(menu)
|
||||||
|
|
||||||
* `menu` Menu
|
* `menu` Menu
|
||||||
|
|
|
@ -37,7 +37,7 @@ Electron 프로세스 내에서 작동하는 웹 페이지는 __랜더러 프로
|
||||||
Electron에는 메인 프로세스와 랜더러 프로세스간에 통신을 할 수 있도록 [ipc](../api/ipc-renderer-ko.md) 모듈을 제공하고 있습니다.
|
Electron에는 메인 프로세스와 랜더러 프로세스간에 통신을 할 수 있도록 [ipc](../api/ipc-renderer-ko.md) 모듈을 제공하고 있습니다.
|
||||||
또한 [remote](../api/remote-ko.md) 모듈을 사용하여 RPC 스타일로 통신할 수도 있습니다.
|
또한 [remote](../api/remote-ko.md) 모듈을 사용하여 RPC 스타일로 통신할 수도 있습니다.
|
||||||
|
|
||||||
## 나의 첫번째 Electron 앱 만들기
|
## 첫번째 Electron 앱 만들기
|
||||||
|
|
||||||
보통 Electron 앱은 다음과 같은 폴더 구조를 가집니다:
|
보통 Electron 앱은 다음과 같은 폴더 구조를 가집니다:
|
||||||
|
|
||||||
|
@ -125,19 +125,45 @@ app.on('ready', function() {
|
||||||
앱을 작성한 후 [어플리케이션 배포](./application-distribution-ko.md) 가이드를 따라 앱을 패키징 하고 패키징한 앱을 실행할 수 있습니다.
|
앱을 작성한 후 [어플리케이션 배포](./application-distribution-ko.md) 가이드를 따라 앱을 패키징 하고 패키징한 앱을 실행할 수 있습니다.
|
||||||
또는 Electron 실행파일을 다운로드 받아 바로 실행해 볼 수도 있습니다.
|
또는 Electron 실행파일을 다운로드 받아 바로 실행해 볼 수도 있습니다.
|
||||||
|
|
||||||
Windows의 경우:
|
### electron-prebuilt
|
||||||
|
|
||||||
|
`npm`을 통해 `electron-prebuilt` 패키지를 전역에 설치하면 간단한 명령으로 앱을 실행해 볼 수 있습니다.
|
||||||
|
|
||||||
|
앱 디렉터리 내에서 이렇게 실행합니다:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
electron .
|
||||||
|
```
|
||||||
|
|
||||||
|
또는 앱 디렉터리 밖에서 앱 디렉터리를 입력해도 됩니다:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
electron app
|
||||||
|
```
|
||||||
|
|
||||||
|
npm 모듈을 로컬에 설치했다면 이렇게 실행할 수 있습니다:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
./node_modules/.bin/electron .
|
||||||
|
```
|
||||||
|
|
||||||
|
### 임의로 다운로드 받은 Electron
|
||||||
|
|
||||||
|
만약 Electron 바이너리를 임의로 다운로드 받았다면 다음과 같이 앱 디렉터리에 놓고 실행하면 됩니다.
|
||||||
|
|
||||||
|
#### Windows
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$ .\electron\electron.exe your-app\
|
$ .\electron\electron.exe your-app\
|
||||||
```
|
```
|
||||||
|
|
||||||
Linux의 경우:
|
#### Linux
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$ ./electron/electron your-app/
|
$ ./electron/electron your-app/
|
||||||
```
|
```
|
||||||
|
|
||||||
OS X의 경우:
|
#### OS X
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$ ./Electron.app/Contents/MacOS/Electron your-app/
|
$ ./Electron.app/Contents/MacOS/Electron your-app/
|
||||||
|
@ -145,3 +171,7 @@ $ ./Electron.app/Contents/MacOS/Electron your-app/
|
||||||
|
|
||||||
앱 실행파일은 `Electron`의 release 패키지에 포함되어 있습니다.
|
앱 실행파일은 `Electron`의 release 패키지에 포함되어 있습니다.
|
||||||
[여기](https://github.com/atom/electron/releases)에서 다운로드 받을 수 있습니다.
|
[여기](https://github.com/atom/electron/releases)에서 다운로드 받을 수 있습니다.
|
||||||
|
|
||||||
|
### 배포용 파일 만들기
|
||||||
|
|
||||||
|
모든 앱 작성이 끝났다면 [어플리케이션 배포](./application-distribution-ko.md) 가이드를 보고 본격적으로 제작한 앱을 배포할 수 있습니다.
|
Loading…
Reference in a new issue