Electron 문서1.4.1

Docs / API / BrowserWindow

BrowserWindow

브라우저 윈도우를 생성하고 제어합니다.

// 메인 프로세스에서
const {BrowserWindow} = require('electron')

// 또는 렌더러 프로세스에서
// const {BrowserWindow} = require('electron').remote

let win = new BrowserWindow({width: 800, height: 600})
win.on('closed', () => {
  win = null
})

// 원격 URL 로드
win.loadURL('https://github.com')

// 또는 로컬 HTML 로드
win.loadURL(`file://${__dirname}/app/index.html`)

Frameless 윈도우

Frameless 윈도우를 만들거나 일정한 모양의 투명한 윈도우를 만드려면, Frameless 윈도우 API를 사용할 수 있습니다.

우아하게 윈도우 표시하기

윈도우에서 페이지를 로딩할 때, 사용자는 페이지가 로드되는 모습을 볼 것입니다. 네이티브 어플리케이션으로써 좋지 않은 경험입니다. 윈도우가 시각적인 깜빡임 없이 표시되도록 만드려면, 서로 다른 상황을 위해 두 ���지 방법이 있습니다.

ready-to-show 이벤트 사용하기

페이지가 로딩되는 동안, ready-to-show 이벤트가 랜더러 프로세스가 랜더링이 완료되었을 때 처음으로 발생합니다. 이 이벤트 이후로 윈도우를 표시하면 시각적인 깜빡임 없이 표시할 수 있습니다.

const {BrowserWindow} = require('electron')
let win = new BrowserWindow({show: false})
win.once('ready-to-show', () => {
  win.show()
})

이 이벤트는 보통 did-finish-load 이벤트 이후에 발생하지만, 페이지가 너무 많은 외부 리소스를 가지고 있다면, did-finish-load 이벤트가 발생하기 이전에 발생할 수도 있습니다.

backgroundColor 설정하기

복잡한 어플리케이션에선, ready-to-show 이벤트가 너무 늦게 발생할 수 있습니다. 이는 사용자가 어플리케이션이 느리다고 생각할 수 있습니다. 이러한 경우 어플리케이션 윈도우를 바로 보이도록 하고 어플리케이션의 배경과 가까운 배경색을 backgroundColor을 통해 설정합니다:

const {BrowserWindow} = require('electron')

let win = new BrowserWindow({backgroundColor: '#2e2c29'})
win.loadURL('https://github.com')

참고로 ready-to-show 이벤트를 사용하더라도 어플리케이션을 네이티브 느낌이 나도록 하기 위해 backgroundColor도 같이 설정하는 것을 권장합니다.

부모와 자식 윈도우

parent 옵션을 사용하면 자식 윈도우를 만들 수 있습니다:

const {BrowserWindow} = require('electron')

let top = new BrowserWindow()
let child = new BrowserWindow({parent: top})
child.show()
top.show()

child 윈도우는 언제나 top 윈도우의 상위에 표시됩니다.

모달 윈도우

모달 윈도우는 부모 윈도우를 비활성화 시키는 자식 윈도우입니다. 모달 윈도우를 만드려면 parent, modal 옵션을 동시에 설정해야 합니다:

const {BrowserWindow} = require('electron')

let child = new BrowserWindow({parent: top, modal: true, show: false})
child.loadURL('https://github.com')
child.once('ready-to-show', () => {
  child.show()
})

플랫폼별 특이사항

Class: BrowserWindow

BrowserWindowEventEmitter를 상속받은 클래스 입니다.

BrowserWindowoptions를 통해 네이티브 속성을 포함한 새로운 윈도우를 생성합니다.

new BrowserWindow([options])

options 객체 (optional), 사용할 수 있는 속성들:

minWidth/maxWidth/minHeight/maxHeight를 통해 최소 또는 최대 윈도우 크기를 지정한 경우, 이는 사용자만을 제약하며, setBounds/setSize 또는 BrowserWindow의 생성자에서 크기 제약을 따르지 않는 윈도우 크기를 전달하는 것은 막을 수 없습니다.

type 속성에서 사용할 수 있는 값과 동작은 다음과 같으며, 플랫폼에 따라 다릅니다:

titleBarStyle의 속성은 다음과 같습니다:

webPreferences 속성은 다음과 같은 속성을 가질 수 있습니다:

Instance Events

new BrowserWindow로 생성된 객체는 다음과 같은 이벤트를 발생시킵니다:

참고: 몇몇 이벤트는 라벨에 특정한 OS에서만 작동합니다.

Event: ‘page-title-updated’

Returns:

문서의 제목이 변경될 때 발생하는 이벤트입니다. event.preventDefault()를 호출하여 네이티브 윈도우의 제목이 변경되는 것을 방지할 수 있습니다.

Event: ‘close’

Returns:

윈도우가 닫히기 시작할 때 발생하는 이벤트입니다. 이 이벤트는 DOM의 beforeunloadunload 이벤트 전에 발생합니다. event.preventDefault()를 호출하여 윈도우 종료를 취소할 수 있습니다.

보통 창을 닫아야 할지 결정하기 위해 beforeunload 이벤트를 사용하려고 할 것입니다. 이 이벤트는 윈도우 콘텐츠를 새로고칠 때도 발생합니다. Electron에선 undefined가 아닌 이외의 값을 전달할 경우 윈도우 종료를 취소합니다. 예시는 다음과 같습니다:

window.onbeforeunload = (e) => {
  console.log('I do not want to be closed')

  // 일반적인 브라우저와는 달리 사용자에게 확인 창을 보여주지 않고, non-void 값을 반환하면
  // 조용히 닫기를 취소합니다.
  // Dialog API를 통해 사용자가 애플리케이션을 종료할지 정할 수 있도록 확인 창을 표시하는 것을
  // 추천합니다.
  e.returnValue = false
}

Event: ‘closed’

윈도우 종료가 완료된 경우 발생하는 이벤트입니다. 이 이벤트가 발생했을 경우 반드시 윈도우의 레퍼런스가 더 이상 사용되지 않도록 제거해야 합니다.

Event: ‘unresponsive’

웹 페이지가 응답하지 않을 때 발생하는 이벤트입니다.

Event: ‘responsive’

응답하지 않는 웹 페이지가 다시 응답하기 시작했을 때 발생하는 이벤트입니다.

Event: ‘blur’

윈도우가 포커스를 잃었을 때 발생하는 이벤트입니다.

Event: ‘focus’

윈도우가 포커스를 가졌을 때 발생하는 이벤트입니다.

Event: ‘show’

윈도우가 보여진 상태일 때 발생하는 이벤트입니다.

Event: ‘hide’

윈도우가 숨겨진 상태일 때 발생하는 이벤트입니다.

Event: ‘ready-to-show’

웹 페이지가 완전히 랜더링되어 윈도우가 시각적인 깜빡임없이 콘텐츠를 보여줄 수 있을 때 발생하는 이벤트입니다.

Event: ‘maximize’

윈도우가 최대화됐을 때 발생하는 이벤트입니다.

Event: ‘unmaximize’

윈도우의 최대화 상태가 해제되었을 때 발생하는 이벤트입니다.

Event: ‘minimize’

윈도우가 최소화됐을 때 발생하는 이벤트입니다.

Event: ‘restore’

윈도우가 최소화 상태에서 복구되었을 때 발생하는 이벤트입니다.

Event: ‘resize’

윈도우의 크기가 재조정될 때 발생하는 이벤트입니다.

Event: ‘move’

윈도우가 새로운 위치로 이동될 때 발생하는 이벤트입니다.

참고: macOS에선 이 이벤트가 그저 moved 이벤트의 별칭(alias)으로 사용됩니다.

Event: ‘moved’ macOS

윈도우가 새로운 위치로 이동되었을 때 발생하는 이벤트입니다. (한 번만)

Event: ‘enter-full-screen’

윈도우가 풀 스크린 모드로 진입할 때 발생하는 이벤트입니다.

Event: ‘leave-full-screen’

윈도우가 풀 스크린 모드에서 해제될 때 발생하는 이벤트입니다.

Event: ‘enter-html-full-screen’

윈도우가 HTML API에 의해 풀 스크린 모드로 진입할 때 발생하는 이벤트입니다.

Event: ‘leave-html-full-screen’

윈도우가 HTML API에 의해 풀 스크린 모드에서 해제될 때 발생하는 이벤트입니다.

Event: ‘app-command’ Windows

Returns:

App Command가 호출됐을 때 발생하는 이벤트입니다. 이 이벤트는 일반적으로 키보드 미디어 키 또는 브라우저 커맨드(기본 동작 키)에 관련되어 있습니다. 예를 들어 Windows에서 작동하는 몇몇 마우스는 “뒤로가기” 같은 동작을 포함하고 있습니다.

반환되는 커맨드들은 모두 소문자화되며 언더스코어(_)는 하이픈(-)으로 변경되며 APPCOMMAND_ 접두어는 제거됩니다. e.g. APPCOMMAND_BROWSER_BACKWARDbrowser-backward와 같이 반환됩니다.

const {BrowserWindow} = require('electron')
let win = new BrowserWindow()
win.on('app-command', (e, cmd) => {
  // Navigate the window back when the user hits their mouse back button
  if (cmd === 'browser-backward' && win.webContents.canGoBack()) {
    win.webContents.goBack()
  }
})

Event: ‘scroll-touch-begin’ macOS

스크롤 휠 이벤트가 동작하기 시작했을 때 발생하는 이벤트입니다.

Event: ‘scroll-touch-end’ macOS

스크롤 휠 이벤트가 동작을 멈췄을 때 발생하는 이벤트입니다.

Event: ‘scroll-touch-edge’ macOS

스크롤 휠 이벤트로 요소의 끝에 도달했을 때 발생하는 이벤트입니다.

Event: ‘swipe’ macOS

Returns:

3-손가락 스와이프가 작동할 때 발생하는 이벤트입니다. 방향은 up, right, down, left가 될 수 있습니다.

Static Methods

BrowserWindow 클래스는 다음과 같은 정적 메서드를 가지고 있습니다:

BrowserWindow.getAllWindows()

Returns BrowserWindow[] - 열려있는 모든 브라우저 윈도우의 배열.

BrowserWindow.getFocusedWindow()

Returns BrowserWindow - 애플리케이션에서 포커스된 윈도우. 없을 경우 null.

BrowserWindow.fromWebContents(webContents)

Returns BrowserWindow - webContents 를 소유한 윈도우.

BrowserWindow.fromId(id)

Returns BrowserWindow - id 에 해당하는 윈도우.

BrowserWindow.addDevToolsExtension(path)

path에 있는 개발자 도구 확장 기능을 추가합니다. 그리고 확장 기능의 이름을 반환합니다.

확장 기능은 기억됩니다. 따라서 API는 단 한 번만 호출되어야 합니다. 이 API는 실제 프로그램 작성에 사용할 수 없습니다. 만약 이미 로드된 확장 기능을 추가하려 한다면, 이 메서드는 아무것도 반환하지 않고 콘솔에 경고가 로그됩니다.

참고: 이 API는 app 모듈의 ready 이벤트가 발생하기 전까지 사용할 수 없습니다.

BrowserWindow.removeDevToolsExtension(name)

name에 해당하는 개발자 도구 확장 기능을 제거합니다.

참고: 이 API는 app 모듈의 ready 이벤트가 발생하기 전까지 사용할 수 없습니다.

BrowserWindow.getDevToolsExtensions()

Returns Object - 키는 확장 기능 이름을 값은 nameversion 속성을 포함하는 객체를 가집니다.

개발자 도구 확장 기능이 설치되었는지 확인하려면 다음과 같이 실행할 수 있습니다:

const {BrowserWindow} = require('electron')

let installed = BrowserWindow.getDevToolsExtensions().hasOwnProperty('devtron')
console.log(installed)

참고: 이 API는 app 모듈의 ready 이벤트가 발생하기 전까지 사용할 수 없습니다.

Instance Properties

new BrowserWindow로 생성한 객체는 다음과 같은 속성을 가지고 있습니다:

const {BrowserWindow} = require('electron')
// `win`은 BrowserWindow의 인스턴스입니다
let win = new BrowserWindow({width: 800, height: 600})
win.loadURL('https://github.com')

win.webContents

윈도우의 WebContents 객체입니다. 모든 웹 페이지와 관련된 이벤트와 작업이 이 객체를 통해 수행됩니다.

메서드나 이벤트에 대한 자세한 내용은 webContents 문서를 참고하세요.

win.id

Integer 형식의 윈도우 고유 ID 입니다.

Instance Methods

new BrowserWindow로 생성한 객체는 다음과 같은 메서드들을 가지고 있습니다:

참고: 몇몇 메서드들은 라벨에서 특정한 운영체제 시스템에서만 작동합니다.

win.destroy()

윈도우를 강제로 닫습니다. 웹 페이지의 unloadbeforeunload 이벤트는 일어나지 않습니다. 또한 이 윈도우의 close도 일어나지 않습니다. 하지만 closed 이벤트는 반드시 발생함을 보장합니다.

win.close()

윈도우의 종료를 시도합니다. 이 메서드는 사용자가 윈도우의 닫기 버튼을 클릭했을 때와 같은 효과를 냅니다. 웹 페이지는 로드가 취소되고 종료됩니다. 자세한 내용은 close 이벤트를 참고하세요.

win.focus()

윈도우에 포커스를 맞춥니다.

win.blur()

윈도우의 포커스를 없앱니다.

win.isFocused()

Returns Boolean - 윈도우가 포커스되었는지 여부.

win.isDestroyed()

Returns Boolean - 윈도우가 소멸되었는지 여부.

win.show()

윈도우를 표시하고 포커스합니다.

win.showInactive()

윈도우를 표시만 하고 포커스하지 않습니다.

win.hide()

윈도우를 숨깁니다.

win.isVisible()

Returns Boolean - 윈도우가 사용자에게 표시되고 있는지 여부.

win.isModal()

Returns Boolean - 현재 윈도우가 모달 윈도우인지 여부.

win.maximize()

윈도우를 최대화 시킵니다.

win.unmaximize()

윈도우 최대화를 취소합니다.

win.isMaximized()

Returns Boolean - 윈도우가 최대화 되어있는지 여부.

win.minimize()

윈도우를 최소화 시킵니다. 어떤 플랫폼은 최소화된 윈도우가 Dock에 표시됩니다.

win.restore()

최소화된 윈도우를 이전 상태로 되돌립니다.

win.isMinimized()

Returns Boolean - 윈도우가 최소화되었는지 여부.

win.setFullScreen(flag)

윈도우의 전체화면 상태를 지정합니다.

win.isFullScreen()

Returns Boolean - 윈도우가 전체화면 모드인지 여부.

win.setAspectRatio(aspectRatio[, extraSize]) macOS

이 메서드는 윈도우의 종횡비를 유지하는 기능을 수행합니다. 엑스트라 크기는 개발자가 픽셀로 특정한 공간이 있을 때 종횡비 계산에서 제외됩니다. 이 API는 윈도우의 크기와 콘텐츠 사이즈의 차이를 이미 고려하고 있습니다.

일반 윈도우에서 작동하는 HD 비디오 플레이어와 관련된 컨트롤을 고려합니다. 만약 15 픽셀의 컨트롤이 왼쪽 가장자리에 있고 25 픽셀의 컨트롤이 오른쪽 가장자리에 있으며 50 픽셀의 컨트롤이 플레이어 밑에 있을 때 플레이어 자체가 16:9 종횡비(HD의 표준 종횡비는 @1920x1080)를 유지하기 위해선 이 함수를 16/9, [ 40, 50 ] 인수와 함께 호출해야 합니다. 두번째 인수 엑스트라 크기는 존재하는 크기만 관여하고 콘텐츠 뷰 내의 크기는 관여하지 않습니다. 그저 전체 콘텐츠 뷰 내에 있는 모든 엑스트라 너비, 높이 영역이 합해집니다.

win.setBounds(bounds[, animate])

윈도우를 주어진 영역으로 크기 재조정 및 이동합니다.

win.getBounds()

Returns structures/rectangle

win.setContentBounds(bounds[, animate])

윈도우의 내부 영역 (예. 웹페이지) 을 주어진 영역으로 크기 재조정 및 이동합니다.

win.getContentBounds()

윈도우의 클라이언트 영역 (웹 페이지)의 너비, 높이, x, y 값을 포함하는 객체를 반환합니다.

win.setSize(width, height[, animate])

widthheight 값으로 윈도우 크기를 재조정합니다. (너비, 높이)

win.getSize()

Returns Integer[] - 윈도우의 너비, 높이를 포함.

win.setContentSize(width, height[, animate])

윈도우 클라이언트 영역(웹 페이지)의 크기를 width, height로 재조정합니다.

win.getContentSize()

Returns Integer[] - 윈도우 내부 영역의 너비, 높이를 포함.

win.setMinimumSize(width, height)

윈도우의 최소 width, height 크기를 지정합니다.

win.getMinimumSize()

Returns Integer[] - 윈도우의 최소 너비, 높이를 포함.

win.setMaximumSize(width, height)

윈도우의 최대 width, height 크기를 지정합니다.

win.getMaximumSize()

Returns Integer[] - 윈도우의 최대 너비, 높이를 포함.

win.setResizable(resizable)

사용자에 의해 윈도우의 크기가 재조정될 수 있는지를 지정합니다.

win.isResizable()

Returns Boolean - 사용자에 의해 윈도우의 크기가 재조정될 수 있는지 여부.

win.setMovable(movable) macOS Windows

사용자에 의해 윈도우를 이동시킬 수 있는지 여부를 지정합니다. Linux에선 아무 일도 일어나지 않습니다.

win.isMovable() macOS Windows

Returns Boolean - 사용자에 의해 윈도우를 이동시킬 수 있는지 여부.

Linux에선 항상 true를 반환합니다.

win.setMinimizable(minimizable) macOS Windows

사용자에 의해 윈도우를 최소화시킬 수 있는지 여부를 지정합니다. Linux에선 아무 일도 일어나지 않습니다.

win.isMinimizable() macOS Windows

Returns Boolean - 사용자에 의해 윈도우를 최소화시킬 수 있는지 여부.

Linux에선 항상 true를 반환합니다.

win.setMaximizable(maximizable) macOS Windows

사용자에 의해 윈도우를 최대화시킬 수 있는지 여부를 지정합니다. Linux에선 아무 일도 일어나지 않습니다.

win.isMaximizable() macOS Windows

Returns Boolean - 사용자에 의해 윈도우를 최대화시킬 수 있는지 여부.

Linux에선 항상 true를 반환합니다.

win.setFullScreenable(fullscreenable)

최대화/줌 버튼이 전체화면 모드 또는 윈도우 최대화를 토글할 수 있게 할지 여부를 지정합니다.

win.isFullScreenable()

Returns Boolean - 최대화/줌 버튼이 전체화면 모드 또는 윈도우 최대화를 토글할 수 있는지 여부.

win.setClosable(closable) macOS Windows

사용자에 의해 윈도우가 수동적으로 닫힐 수 있는지 여부를 지정합니다. Linux에선 아무 일도 일어나지 않습니다.

win.isClosable() macOS Windows

Returns Boolean - 사용자에 의해 윈도우가 수동적으로 닫힐 수 있는지 여부.

Linux에선 항상 true를 반환합니다.

win.setAlwaysOnTop(flag[, level])

윈도우가 언제나 다른 윈도우들 위에 표시되는지 여부를 지정합니다. 이 설정을 활성화 하면 윈도우는 포커스 될 수 없는 툴박스 윈도우가 아닌 일반 윈도우로 유지됩니다.

win.isAlwaysOnTop()

윈도우가 언제나 다른 윈도우들 위에 표시되는지 여부를 반환합니다.

win.center()

윈도우를 화면 정 중앙으로 이동합니다.

win.setPosition(x, y[, animate])

윈도우의 위치를 x, y로 이동합니다.

win.getPosition()

Returns Integer[] - 윈도우의 현재 위치.

win.setTitle(title)

title을 네이티브 윈도우의 제목으로 지정합니다.

win.getTitle()

Returns String - 네이티브 윈도우의 제목.

참고: 웹 페이지의 제목과 네이티브 윈도우의 제목은 서로 다를 수 있습니다.

win.setSheetOffset(offsetY[, offsetX]) macOS

macOS에서 시트를 부착할 위치를 지정합니다. 기본적으로 시트는 윈도우의 프레임 바로 아래의 위치에 부착됩니다. 아마도 이 기능은 보통 다음과 같이 HTML 렌더링된 툴바 밑에 표시하기 위해 사용할 것입니다:

const {BrowserWindow} = require('electron')
let win = new BrowserWindow()

let toolbarRect = document.getElementById('toolbar').getBoundingClientRect()
win.setSheetOffset(toolbarRect.height)

win.flashFrame(flag)

사용자가 윈도우에 관심을 가질 수 있도록 창을 깜빡이거나 이를 중지합니다.

win.setSkipTaskbar(skip)

애플리케이션 아이콘을 작업표시줄에 보이지 않도록 설정합니다.

win.setKiosk(flag)

Kiosk(키오스크) 모드를 설정합니다.

win.isKiosk()

Returns `Boolean’ - 현재 윈도우가 kiosk 모드인지 여부.

win.getNativeWindowHandle()

Returns Buffer - 플랫폼 별 윈도우의 핸들.

핸들의 타입에 따라 적절히 캐스팅됩니다. Windows의 HWND, macOS의 NSView*, Linux의 Window (unsigned long)를 예로 들 수 있습니다.

win.hookWindowMessage(message, callback) Windows

Windows 메시지 훅을 등록합니다. callback은 WndProc에서 메시지를 받았을 때 호출됩니다.

win.isWindowMessageHooked(message) Windows

Returns Boolean - 지정한 메시지가 후킹됐는지에 따라 true 또는 false.

win.unhookWindowMessage(message) Windows

지정한 메시지 훅을 등록 해제합니다.

win.unhookAllWindowMessages() Windows

모든 메시지 훅을 등록 해제합니다.

win.setRepresentedFilename(filename) macOS

윈도우 대표 파일의 경로명을 설정합니다. 파일의 아이콘이 윈도우 타이틀 바에 표시됩니다.

win.getRepresentedFilename() macOS

Returns String - 윈도우 대표 파일의 경로.

win.setDocumentEdited(edited) macOS

윈도우의 문서가 변경되었는지 여부를 설정합니다. 그리고 true로 설정했을 때 타이틀 바의 아이콘이 회색으로 표시됩니다.

win.isDocumentEdited() macOS

Returns Boolean - 윈도우의 문서가 변경되었는지 여부.

win.focusOnWebView()

win.blurWebView()

win.capturePage([rect, ]callback)

webContents.capturePage([rect, ]callback)와 같습니다.

win.loadURL(url[, options])

webContents.loadURL(url[, options]) API와 같습니다.

url은 원격 주소 (e.g. http://)가 되거나 file:// 프로토콜을 사용하는 로컬 HTML 경로가 될 수 있습니다.

파일 URL이 올바른 형식으로 지정되었는지 확인하려면 Node의 url.format 메서드를 사용하는 것을 권장합니다.

let url = require('url').format({
  protocol: 'file',
  slashes: true,
  pathname: require('path').join(__dirname, 'index.html')
})

win.loadURL(url)

win.reload()

webContents.reload API와 같습니다.

win.setMenu(menu) Linux Windows

지정한 menu를 윈도우의 메뉴로 설정합니다 null을 설정하면 메뉴를 제거합니다.

win.setProgressBar(progress[, options])

작업표시줄에 표시되고 있는 애플리케이션 아이콘에 진행 상태를 표시합니다. [0, 1.0] 사이의 값을 지정할 수 있습니다.

진행 상태가 < 0 이 되면 진행 상태 표시를 제거합니다. 진행 상태가 > 1 이 되면 불확정 상태 표시로 전환합니다.

Linux 플랫폼에선 Unity 데스크톱 환경만 지원합니다. 그리고 이 기능을 사용하려면 *.desktop 파일을 생성한 후 package.jsondesktopName 필드에 파일 이름을 지정해야 합니다. 기본적으로 app.getName().desktop을 통해 접근합니다.

Windows에선 모드를 전달할 수 있습니다. 사용할 수 있는 값은 none, normal, indeterminate, error, 그리고 paused가 있습니다. 만약 모드 설정 없이 setProgressBar를 호출하면 (올바른 범위의 값을 전달했을 때), normal이 기본적으로 설정됩니다.

win.setOverlayIcon(overlay, description) Windows

현재 작업표시줄 아이콘에 16 x 16 픽셀 크기의 오버레이를 지정합니다. 보통 이 기능은 애플리케이션의 여러 상태를 사용자에게 소극적으로 알리기 위한 방법으로 사용됩니다.

win.setHasShadow(hasShadow) macOS

윈도우가 그림자를 가질지 여부를 지정합니다. Windows와 Linux에선 아무 일도 일어나지 않습니다.

win.hasShadow() macOS

Returns Boolean - 윈도우가 그림자를 가지고 있는지 여부.

Windows와 Linux에선 항상 true를 반환합니다.

win.setThumbarButtons(buttons) Windows

Returns Boolean - 버튼이 성공적으로 추가되었는지 여부

윈도우 작업표시줄 버튼 레이아웃의 미리보기 이미지 영역에 미리보기 툴바와 버튼 세트를 추가합니다. 반환되는 Boolean 값은 미리보기 툴바가 성공적으로 추가됬는지를 알려줍니다.

미리보기 이미지 영역의 제한된 크기로 인해 미리보기 툴바에 추가될 수 있는 최대 버튼의 개수는 7개이며 이 이상 추가될 수 없습니다. 플랫폼의 제약으로 인해 미리보기 툴바는 한 번 설정되면 삭제할 수 없습니다. 하지만 이 API에 빈 배열을 전달하여 버튼들을 제거할 수 있습니다.

buttonsButton 객체의 배열입니다:

flags 는 다음 String 들을 포함할 수 있는 배열입니다: * enabled - 사용자가 사용할 수 있도록 버튼이 활성화 됩니다. * disabled - 버튼이 비활성화 됩니다. 버튼은 표시되지만 시각적인 상태는 사용자의 동작에 응답하지 않는 비활성화 상태로 표시됩니다. * dismissonclick - 버튼이 클릭되면 작업표시줄 버튼의 미리보기(flyout)가 즉시 종료됩니다. * nobackground - 버튼의 테두리를 표시하지 않습니다. 이미지에만 사용할 수 있습니다. * hidden - 버튼을 사용자에게 표시되지 않도록 숨깁니다. * noninteractive - 버튼은 활성화되어 있지만 반응이 제거되며 버튼을 눌러도 눌려지지 않은 상태를 유지합니다. 이 값은 버튼을 알림의 용도로 사용하기 위해 만들어졌습니다.

win.setThumbnailClip(region) Windows

작업 표시줄에 윈도우의 섬네일이 표시될 때 섬네일 이미지로 사용할 윈도우의 영역을 지정합니다. 빈 영역을 지정하는 것으로 전체 윈도우의 섬네일로 초기화할 수 있습니다: {x: 0, y: 0, width: 0, height: 0}.

win.setThumbnailToolTip(toolTip) Windows

작업 표시줄의 윈도우 섬네일 위에 표시될 툴팁을 설정합니다.

win.showDefinitionForSelection() macOS

webContents.showDefinitionForSelection()와 같습니다.

win.setIcon(icon) Windows Linux

윈도우 아이콘을 변경합니다.

win.setAutoHideMenuBar(hide)

메뉴 막대 자동 숨김 기능을 활성화 합니다. 숨겨진 메뉴는 사용자가 Alt 키를 단일 입력했을 때만 표시됩니다.

메뉴 막대가 이미 표시되고 있을 때 setAutoHideMenuBar(true)를 호출한다고 해서 메뉴가 즉시 숨겨지지는 않습니다.

win.isMenuBarAutoHide()

Returns Boolean - 메뉴 막대 자동 숨김 상태 여부.

win.setMenuBarVisibility(visible)

메뉴 막대의 표시 여부를 설정합니다. 만약 메뉴 막대 자동 숨김 상태라면 여전히 사용자가 Alt 키를 입력하여 메뉴 막대를 표시되도록 할 수 있습니다.

역자주: 기본 메뉴 막대를 완전히 없애려면 win.setMenu(null)를 호출해야 합니다. 단순히 이 API를 사용하면 여전히 메뉴에 등록된 핫 키가 작동합니다.

win.isMenuBarVisible()

Returns Boolean - 메뉴 막대가 표시되고 있는지 여부.

win.setVisibleOnAllWorkspaces(visible)

윈도우가 모든 워크스페이스에서 표시될지 여부를 설정합니다.

참고: 이 API는 Windows에서 아무 일도 하지 않습니다.

win.isVisibleOnAllWorkspaces()

Returns Boolean - 윈도우가 모든 워크스페이스에서 표시될지 여부.

참고: 이 API는 Windows에서 언제나 false를 반환합니다.

win.setIgnoreMouseEvents(ignore)

윈도우가 모든 마우스 이벤트를 무시하게 만듭니다.

이 윈도우에서 일어나는 모든 마우스 이벤트가 이 윈도우 밑의 윈도우로 전달됩니다. 하지만 이 윈도우가 포커스되어 있다면, 여전히 키보드 이벤트는 받을 수 있습니다.

win.setContentProtection(enable) macOS Windows

윈도우 콘텐츠가 외부 어플리케이션에 의해 캡쳐되는 것을 막습니다.

macOS에선 NSWindow의 sharingType을 NSWindowSharingNone로 설정합니다. Windows에선 WDA_MONITOR와 함께 SetWindowDisplayAffinity를 호출합니다.

win.setFocusable(focusable) Windows

윈도우가 포커스될 수 있는지 여부를 변경합니다.

win.setParentWindow(parent) Linux macOS

win.getParentWindow()

Returns BrowserWindow - 부모 윈도우.

win.getChildWindows()

Returns BrowserWindow[] - 모든 자식 윈도우.


고쳐야 할 것이 있습니까? 소스에서 변경을 제안할 수 있습니다.
다른 버전의 문서가 필요한가요? 이전 버전 또는 커뮤니티 번역을 보세요.
모든 문서를 한번에 검색하고 싶으신가요? 한 페이지 문서를 보세요.