BaseWindow
创建和控制窗口。
Process: Main
注意
BaseWindow
提供了一种在单个窗口中灵活组合多个web视图的方式。 对于只有单个全尺寸web视图的窗口,BrowserWindow
类可能是更简单的选择。
This module cannot be used until the ready
event of the app
module is emitted.
// 在主进程中
const { BaseWindow, WebContentsView } = require('electron')
const win = new BaseWindow({ width: 800, height: 600 })
const leftView = new WebContentsView()
leftView.webContents.loadURL('https://electronjs.org')
win.contentView.addChildView(leftView)
const rightView = new WebContentsView()
rightView.webContents.loadURL('https://github.com/electron/electron')
win.contentView.addChildView(rightView)
leftView.setBounds({ x: 0, y: 0, width: 400, height: 600 })
rightView.setBounds({ x: 400, y: 0, width: 400, height: 600 })
父子窗口
通过使用 parent
选项,可以创建子窗口:
const { BaseWindow } = require('electron')
const parent = new BaseWindow()
const child = new BaseWindow({ parent })
child
子窗口将始终显示在parent
父窗口的顶部。
模态窗口
模态窗口是禁用父窗口的子窗口。 要创建模态窗口,必须同时设置parent
和modal
选项:
const { BaseWindow } = require('electron')
const parent = new BaseWindow()
const child = new BaseWindow({ parent, modal: true })
平台相关的提示
- 在 macOS 上,modal 窗口将显示为附加到父窗口的工作表。
- 在 macOS 上,当父窗口移动时,子窗口将保持相对位置,而在 Windows 和 Linux 上,子窗口将不会移动。
- 在 Linux 上,模态窗口的类型将更改为
dialog
。 - 在Linux上,许多桌面环境不支持隐藏模态窗口。
Class: BaseWindow
创建和控制窗口。
Process: Main
BaseWindow
是一个EventEmitter。
它根据options
设置的本地属性创建一个新的BaseWindow
。
new BaseWindow([options])
When setting minimum or maximum window size with minWidth
/maxWidth
/
minHeight
/maxHeight
, it only constrains the users. It won't prevent you from
passing a size that does not follow size constraints to setBounds
/setSize
or
to the constructor of BrowserWindow
.
The possible values and behaviors of the type
option are platform dependent.
可能的值有
- On Linux, possible types are
desktop
,dock
,toolbar
,splash
,notification
.- The
desktop
type places the window at the desktop background window level (kCGDesktopWindowLevel - 1). However, note that a desktop window will not receive focus, keyboard, or mouse events. You can still use globalShortcut to receive input sparingly. - The
dock
type creates a dock-like window behavior. - The
toolbar
type creates a window with a toolbar appearance. - The
splash
type behaves in a specific way. It is not draggable, even if the CSS styling of the window's body contains -webkit-app-region: drag. This type is commonly used for splash screens. - The
notification
type creates a window that behaves like a system notification.
- The
- On macOS, possible types are
desktop
,textured
,panel
.- The
textured
type adds metal gradient appearance (NSWindowStyleMaskTexturedBackground
). - The
desktop
type places the window at the desktop background window level (kCGDesktopWindowLevel - 1
). Note that desktop window will not receive focus, keyboard or mouse events, but you can useglobalShortcut
to receive input sparingly. - The
panel
type enables the window to float on top of full-screened apps by adding theNSWindowStyleMaskNonactivatingPanel
style mask,normally reserved for NSPanel, at runtime. Also, the window will appear on all spaces (desktops).
- The
- On Windows, possible type is
toolbar
.
实例事件
Objects created with new BaseWindow
emit the following events:
Note: Some events are only available on specific operating systems and are labeled as such.
事件: 'close'
返回:
event
Event
在窗口要关闭的时候触发。 It's emitted before the
beforeunload
and unload
event of the DOM. Calling event.preventDefault()
will cancel the close.
Usually you would want to use the beforeunload
handler to decide whether the
window should be closed, which will also be called when the window is
reloaded. In Electron, returning any value other than undefined
would cancel the
close. 例如:
window.onbeforeunload = (e) => {
console.log('I do not want to be closed')
// Unlike usual browsers that a message box will be prompted to users, returning
// a non-void value will silently cancel the close.
// It is recommended to use the dialog API to let the user confirm closing the
// application.
e.returnValue = false
}
Note: There is a subtle difference between the behaviors of window.onbeforeunload = handler
and window.addEventListener('beforeunload', handler)
. It is recommended to always set the event.returnValue
explicitly, instead of only returning a value, as the former works more consistently within Electron.
事件: 'closed'
在窗口关闭时触发 当你接收到这个事件的时候, 你应当移除相应窗口的引用对象,避免再次使用它.
Event: 'session-end' Windows
因为强制关机或机器重启或会话注销而导致窗口会话结束时触发
事件: 'blur'
当窗口失去焦点时触发
事件: 'focus'
当窗口获得焦点时触发
事件: 'show'
当窗口显示时触发
事件: 'hide'
当窗口隐藏时触发
事件: 'maximize'
窗口最大化时触发
事件: 'unmaximize'
当窗口从最大化状态退出时触发
事件: 'minimize'
窗口最小化时触发
事件: 'restore'
当窗口从最小化状态恢复时触发
Event: 'will-resize' macOS Windows
返回:
event
EventnewBounds
Rectangle - Size the window is being resized to.details
Objectedge
(string) - The edge of the window being dragged for resizing. Can bebottom
,left
,right
,top-left
,top-right
,bottom-left
orbottom-right
.
调整窗口大小前触发。 Calling event.preventDefault()
will prevent the window from being resized.
请注意,该事件仅在手动调整窗口大小时触发。 Resizing the window with setBounds
/setSize
will not emit this event.
The possible values and behaviors of the edge
option are platform dependent. 可能的值有
- On Windows, possible values are
bottom
,top
,left
,right
,top-left
,top-right
,bottom-left
,bottom-right
. - On macOS, possible values are
bottom
andright
.- The value
bottom
is used to denote vertical resizing. - The value
right
is used to denote horizontal resizing.
- The value
事件: 'resize'
调整窗口大小后触发。
Event: 'resized' macOS Windows
当窗口完成调整大小后触发一次。
这通常在手动调整窗口大小后触发。 On macOS, resizing the window with setBounds
/setSize
and setting the animate
parameter to true
will also emit this event once resizing has finished.
Event: 'will-move' macOS Windows
返回:
event
EventnewBounds
Rectangle - Location the window is being moved to.
窗口移动前触发。 On Windows, calling event.preventDefault()
will prevent the window from being moved.
注意:仅当手动移动窗口时才会触发此消息。 Moving the window with setPosition
/setBounds
/center
will not emit this event.
事件: 'move'
窗口移动到新位置时触发
Event: 'moved' macOS Windows
当窗口移动到新位置时触发一次
Note: On macOS this event is an alias of move
.
事件: 'enter-full-screen'
窗口进入全屏状态时触发
事件: 'leave-full-screen'
窗口离开全屏状态时触发
事件: 'always-on-top-changed'
返回:
event
EventisAlwaysOnTop
boolean
设置或取消设置窗口总是在其他窗口的顶部显示时触发。
Event: 'app-command' Windows Linux
返回:
event
Eventcommand
string
Emitted when an App Command is invoked. 典型的是键盘上的媒体键或浏览器命令, 以及在Windows上的一些鼠标中内置的“后退”按钮。
Commands are lowercased, underscores are replaced with hyphens, and the
APPCOMMAND_
prefix is stripped off.
e.g. APPCOMMAND_BROWSER_BACKWARD
is emitted as browser-backward
.
const { BaseWindow } = require('electron')
const win = new BaseWindow()
win.on('app-command', (e, cmd) => {
// Navigate the window back when the user hits their mouse back button
if (cmd === 'browser-backward') {
// Find the appropriate WebContents to navigate.
}
})
以下应用命令在 Linux 上有明确地支持:
browser-backward
browser-forward
Event: 'swipe' macOS
返回:
event
Eventdirection
string
三指滑动时触发。 Possible directions are up
, right
, down
, left
.
此事件的基本方法是用来处理旧的macOS风格的触摸板滑动,屏幕内容不会随着滑动而移动。 Most macOS trackpads are not
configured to allow this kind of swiping anymore, so in order for it to emit properly the
'Swipe between pages' preference in System Preferences > Trackpad > More Gestures
must be
set to 'Swipe with two or three fingers'.
Event: 'rotate-gesture' macOS
返回:
event
Eventrotation
Float
在触控板旋转手势上触发。 持续触发直到旋转手势结束。 The rotation
value on each emission is the angle in degrees rotated since
the last emission. The last emitted event upon a rotation gesture will always be of
value 0
. 逆时针旋转值为正值,顺时针旋转值为负值。
Event: 'sheet-begin' macOS
窗口打开sheet(工作表) 时触发
Event: 'sheet-end' macOS
窗口关闭sheet(工作表) 时触发
Event: 'new-window-for-tab' macOS
当点击了系统的新标签按钮时触发
Event: 'system-context-menu' Windows
返回:
event
Eventpoint
Point - The screen coordinates the context menu was triggered at
当系统上下文菜单在窗口上触发时发出, 通常只在用户右键点击你窗口的非客户端区域时触发。 This is the window titlebar or any area you have declared
as -webkit-app-region: drag
in a frameless window.
Calling event.preventDefault()
will prevent the menu from being displayed.
静态方法
BaseWindow
类具有以下静态方法:
BaseWindow.getAllWindows()
Returns BaseWindow[]
- 全部已打开浏览器窗口构成的数组。
BaseWindow.getFocusedWindow()
Returns BaseWindow | null
- 当前应用中聚焦的窗口,无聚焦则返回 null。
BaseWindow.fromId(id)
id
Integer
Returns BaseWindow | null
- 给定id
的窗口。
实例属性
使用 new BaseWindow
创建的对象具有以下属性:
const { BaseWindow } = require('electron')
// 在这个示例中,`win` 是我们的实例
const win = new BaseWindow({ width: 800, height: 600 })
win.id
Readonly
一个Integer
属性,表示窗口的唯一 ID。 每个 ID 在整个 Electron 应用程序的所有BaseWindow
实例中都是唯一的。
win.contentView
一个View
属性,表示窗口的内容视图。
win.tabbingIdentifier
macOS Readonly
一个string
(可选) 属性,等于传递给BrowserWindow
构造函数的tabbingIdentifier
,如果未设置,则为 undefined
。
win.autoHideMenuBar
一个boolean
属性,决定窗口菜单栏是否应自动隐藏。 设置后,菜单栏将仅在用户按单个Alt
键时显示。
如果菜单栏已经可见,将此属性设置为true
不会立即隐藏它。
win.simpleFullScreen
一个boolean
属性,决定窗口是否处于简单 (Lion 之前的) 全屏模式。
win.fullScreen
一个boolean
属性,决定窗口是否处于全屏模式。
win.focusable
Windows macOS
一个boolean
属性,决定窗口是否可以聚焦。
win.visibleOnAllWorkspaces
macOS Linux
一个boolean
属性,决定窗口是否在所有工作区可见。
注意: 在 Windows 平台始终返回 false。
win.shadow
一个boolean
属性,决定窗口是否有阴影。
win.menuBarVisible
Windows Linux
一个boolean
属性,决定菜单栏是否可见。
注意:如果菜单栏是自动隐藏的,用户仍然可以通过单击Alt
键唤出菜单栏。
win.kiosk
一个boolean
属性,决定窗口是否处于展台模式。
win.documentEdited
macOS
一个boolean
属性,指定窗口的文档是否已被编辑。
设置为true
时,标题栏上的图标将变为灰色。
win.representedFilename
macOS
一个string
属性,决定窗口表示的文件的路径名,文件的图标将显示在窗口的标题栏中。
win.title
一个string
属性,决定原生窗口的标题。
注意:网页的标题可以与原生窗口的标题不同。
win.minimizable
macOS Windows
一个 boolean
属性,决定用户是否可以手动最小化窗口。
在 Linux 上,setter 是无操作的,尽管 getter 返回true
。
win.maximizable
macOS Windows
一个boolean
属性,决定用户是否可以手动最大化窗口。
在 Linux 上,setter 是无操作的,尽管 getter 返回true
。
win.fullScreenable
一个boolean
属性,决定最大化/缩放窗口按钮是否切换全屏模式或最大化窗口。
win.resizable
一个boolean
属性,决定用户是否可以手动调整窗口大小。
win.closable
macOS Windows
一个boolean
属性,决定用户是否可以手动关闭窗口。
在 Linux 上,setter 是无操作的,尽管 getter 返回true
。
win.movable
macOS Windows
一个boolean
属性,决定用户是否可以移动窗口。
在 Linux 上,setter 是无操作的,尽管 getter 返回true
。
win.excludedFromShownWindowsMenu
macOS
一个 boolean属性,决定窗口是否从应用程序的窗口菜单中排除。 默认值为
false`。
const { Menu, BaseWindow } = require('electron')
const win = new BaseWindow({ height: 600, width: 600 })
const template = [
{
role: 'windowmenu'
}
]
win.excludedFromShownWindowsMenu = true
const menu = Menu.buildFromTemplate(template)
Menu.setApplicationMenu(menu)
win.accessibleTitle
一个string
属性,为辅助工具(如屏幕阅读器)提供的替代标题。 此字符串不直接对用户可见。
实例方法
使用new BaseWindow
创建的对象具有以下实例方法:
注意:一些方法仅在特定操作系统上可用,并有相应的标签。
win.setContentView(view)
view
View
设置窗口的内容视图。
win.getContentView()
返回 View - 窗口的内容视图。
win.destroy()
强制关闭窗口,不会为网页触发unload
和beforeunload
事件,也不会为此窗口触发close
事件,但保证会触发closed
事件。
win.close()
尝试关闭窗口。 该方法与用户手动单击窗口的关闭按钮效果相同。 但网页可能会取消这个关闭操作。 参见 close 事件。
win.focus()
聚焦于窗口
win.blur()
取消窗口的聚焦
win.isFocused()
返回boolean
- 窗口是否聚焦。
win.isDestroyed()
返回boolean
- 窗口是否被销毁。
win.show()
显示并聚焦于窗口
win.showInactive()
显示但不聚焦于窗口
win.hide()
隐藏窗口
win.isVisible()
返回boolean
- 窗口是否在应用程序前台对用户可见。
win.isModal()
返回boolean
- 当前窗口是否为模态窗口。
win.maximize()
最大化窗口。 如果窗口尚未显示,该方法也会将其显示 (但不会聚焦)。
win.unmaximize()
取消窗口最大化
win.isMaximized()
返回boolean
- 窗口是否最大化。
win.minimize()
最小化窗口。 在某些平台上, 最小化的窗口将显示在Dock中。
win.restore()
将窗口从最小化状态恢复到以前的状态。
win.isMinimized()
返回boolean
- 窗口是否最小化。
win.setFullScreen(flag)
flag
boolean
设置窗口是否应处于全屏模式。
注意:在 macOS 上,全屏转换是异步进行的。 如果进一步的操作依赖于全屏状态,请使用 'enter-full-screen' 或 'leave-full-screen' 事件。
win.isFullScreen()
返回boolean
- 窗口是否处于全屏模式。
win.setSimpleFullScreen(flag)
macOS
flag
boolean
进入或离开简单的全屏模式。
简单全屏模式模拟了 Lion (10.7) 之前的macOS版本中的原生全屏行为。
win.isSimpleFullScreen()
macOS
返回boolean
- 窗口是否处于简单(Lion 之前的) 全屏模式。
win.isNormal()
返回boolean
- 窗口是否处于正常状态(未最大化,未最小化,未处于全屏模式) 。
win.setAspectRatio(aspectRatio[, extraSize])
aspectRatio
Float - 要保持的内容视图某部分的宽高比。extraSize
Size (可选) macOS - 在保持宽高比计算时不包含的额外大小。
这将使窗口保持长宽比。 额外的大小允许开发人员有空间 (以像素为单位), 不包括在纵横比计算中。 此 API 已经考虑了窗口大小和内容大小之间的差异。
想象一个使用高清视频播放器和相关控件的普通窗口。 假假如左边缘有15px, 右边缘有25px, 在播放器下面有50px. 为了在播放器内部保持 16:9 的宽高比(HD @1920x1080 的标准宽高比) ,我们将此函数的参数设置为 16/9 和 { width: 40, height: 50 }。 第二个参数不管网页中的额外的宽度和高度在什么位置, 只要它们存在就行. 在全部内部窗口中,加上任何额外的宽度和高度 。
当使用win.setSize
等 API 以编程方式调整窗口大小时,不会遵循宽高比。
要重置长宽比,请将aspectRatio
设置为 0:win.setAspectRatio(0)
。
win.setBackgroundColor(backgroundColor)
backgroundColor
string - 颜色格式为 Hex、RGB、RGBA、HSL、HSLA 或命名的 CSS 颜色。 对于 Hex 类型,透明通道为可选的。
有效的backgroundColor
值示例:
- Hex
- #fff (shorthand RGB)
- #ffff (shorthand ARGB)
- #ffffff (RGB)
- #ffffffff (ARGB)
- RGB
rgb\(([\d]+),\s*([\d]+),\s*([\d]+)\)
- e.g. rgb(255, 255, 255)
- RGBA
rgba\(([\d]+),\s*([\d]+),\s*([\d]+),\s*([\d.]+)\)
- e.g. rgba(255, 255, 255, 1.0)
- HSL
hsl\((-?[\d.]+),\s*([\d.]+)%,\s*([\d.]+)%\)
- e.g. hsl(200, 20%, 50%)
- HSLA
hsla\((-?[\d.]+),\s*([\d.]+)%,\s*([\d.]+)%,\s*([\d.]+)\)
- e.g. hsla(200, 20%, 50%, 0.5)
- Color name
- Options are listed in SkParseColor.cpp
- 类似 CSS Color Module Level 3 关键字,但大小写敏感。
- e.g.
blueviolet
orred
- e.g.
设置窗口的背景颜色。 参见 设置backgroundColor
.
win.previewFile(path[, displayName])
macOS
path
string - 要使用 QuickLook 预览的文件的绝对路径。 这很重要,因为 Quick Look 使用路径上的文件名和文件扩展名来确定要打开的文件类型。displayName
string (可选) - 要在 Quick Look 模态视图中显示的文件名称。 这仅是视觉上的,不影响文件的内容类型。 默认为path
.
使用 Quick Look 预览给定路径的文件。
win.closeFilePreview()
macOS
关闭当前打开的 Quick Look 面板。
win.setBounds(bounds[, animate])
bounds
Partial<Rectangle>animate
boolean (可选) macOS
重置窗口,并且移动窗口到指定的位置. 任何未提供的属性将默认为其当前值。
const { BaseWindow } = require('electron')
const win = new BaseWindow()
// 设置所有边界属性
win.setBounds({ x: 440, y: 225, width: 800, height: 600 })
// 设置单个边界属性
win.setBounds({ width: 100 })
// { x: 440, y: 225, width: 100, height: 600 }
console.log(win.getBounds())
注意: 在 macOS 上,y 坐标值不能小于 Tray 的高度。 The tray height has changed over time and depends on the operating system, but is between 20-40px. Passing a value lower than the tray height will result in a window that is flush to the tray.
win.getBounds()
返回Rectangle - 窗口的bounds
对象。
注意:在 macOS 上,返回的 y 坐标值将至少是 Tray 的高度。 例如,使用托盘高度为 38 的情况下调用win.setBounds({ x: 25, y: 20, width: 800, height: 600 })
将导致win.getBounds()
返回{ x: 25, y: 38, width: 800, height: 600 }
。
win.getBackgroundColor()
返回string
- 以 Hex (#RRGGBB
) 格式获取窗口的背景颜色。
注意: Alpha 值不会与红色、绿色和蓝色值一起返回。
win.setContentBounds(bounds[, animate])
bounds
Rectangleanimate
boolean (可选) macOS
调整窗口的工作区 (如网页) 的大小并将其移动到所提供的边界。
win.getContentBounds()
返回 Rectangle - 窗口客户 端区域的bounds
对象。
win.getNormalBounds()
返回 Rectangle - 包含窗口正常状态下的边界。
注意: 无论窗口的当前状态如何:最大化、最小化或全屏,此函数始终返回窗口在正常状态下的位置和大小。 在正常状态下,getBounds 和 getNormalBounds 返回相同的 Rectangle。
win.setEnabled(enable)
enable
boolean
禁用或者启用窗口。
win.isEnabled()
返回 boolean
- 窗口是否启用。
win.setSize(width, height[, animate])
width
Integerheight
Integeranimate
boolean (可选) macOS
调整窗口大小为width
和height
。 如果width
或height
低于任何设定的最小尺寸约束,窗口将对齐到约束的最小尺寸。
win.getSize()
返回 Integer []
- 包含窗口的宽度和高度。
win.setContentSize(width, height[, animate])
width
Integerheight
Integeranimate
boolean (可选) macOS
将窗口的工作区 (如网页) 大小调整为 width
和 height
。
win.getContentSize()
返回 Integer[]
- 包含窗口的宽度和高度。
win.setMinimumSize(width, height)
width
Integerheight
Integer
设置窗口的最小尺寸为width
和height
。
win.getMinimumSize()
返回 Integer[]
- 包含窗口的最 小宽度和高度。
win.setMaximumSize(width, height)
width
Integerheight
Integer
设置窗口的最大尺寸为width
和height
。
win.getMaximumSize()
返回 Integer[]
- 包含窗口的最大宽度和高度。
win.setResizable(resizable)
resizable
boolean
设置用户是否可以手动调整窗口大小。
win.isResizable()
返回 boolean
- 用户是否可以手动调整窗口大小。
win.setMovable(movable)
macOS Windows
movable
boolean
设置用户是否可以移动窗口。 在Linux上不起作用。
win.isMovable()
macOS Windows
返回 boolean
- 窗口是否可以被用户拖动
在 Linux 上总是返回true
。
win.setMinimizable(minimizable)
macOS Windows
minimizable
boolean
设置用户是否可以手动将窗口最小化。 在Linux上不起作用。
win.isMinimizable()
macOS Windows
返回 boolean
- 用户是否可以手动最小化窗口。
在 Linux 上总是返回true
。
win.setMaximizable(maximizable)
macOS Windows
maximizable
boolean
设置用户是否可以手动最大化窗口。 在Linux上不起作用。
win.isMaximizable()
macOS Windows
返回 boolean
- 用户是否可以手动最大化窗口。
在 Linux 上总是返回true
。
win.setFullScreenable(fullscreenable)
fullscreenable
boolean
设置最大化/缩放窗口按钮是切换全屏模式还是最大化窗口。
win.isFullScreenable()
返回 boolean
- 最大化/缩放窗口按钮是切换全屏模式还是最大化窗口。
win.setClosable(closable)
macOS Windows
closable
boolean
设置用户是否可以手动关闭窗口。 在Linux上不起作用。
win.isClosable()
macOS Windows
返回 boolean
- 窗口是否可以被用户手动关闭。
在 Linux 上总是返回true
。
win.setHiddenInMissionControl(hidden)
macOS
hidden
boolean
Sets whether the window will be hidden when the user toggles into mission control.
win.isHiddenInMissionControl()
macOS
返回 boolean
- 当用户切换到任务控制时窗口是否会隐藏。
win.setAlwaysOnTop(flag[, level][, relativeLevel])
flag
booleanlevel
string (可选) macOS Windows - 值包括normal
,floating
,torn-off-menu
,modal-panel
,main-menu
,status
,pop-up-menu
,screen-saver
, 以及(已弃用)。 默认值为dock
floating
(当 flag 为 true 时)。 当flag为false
时,level
会重置为normal
。 请注意,包括从floating
到status
,窗口会被置于 macOS 上的 Dock 下方和 Windows 上的任务栏下方。 从pop-up-menu
到更高级别,窗口显示在 macOS 上的Dock上方和 Windows 上的任务栏上方。 详情请参阅 macOS 文档。relativeLevel
Integer (可选) macOS - 设置此窗口相对于给定level
的层数。 默认值为0
。 请注意, Apple 不鼓励在屏幕保护程序
之上设置高于1的级别。
设置窗口是否应始终显示在其他窗口的前面。 设置后,窗口仍然是一个正常窗口,而不是一个无法获取焦点的工具框窗口。
win.isAlwaysOnTop()
返回 boolean
- 当前窗口是否始终在其它窗口之前。
win.moveAbove(mediaSourceId)
mediaSourceId
string - DesktopCapturerSource格式的窗口 id 。 例如 "window:1869:0"。
将窗口按z轴顺序移动到源窗口前面。 如果mediaSourceId
不是窗口类型或窗口不存 在,则此方法会抛出错误。
win.moveTop()
无论焦点如何, 将窗口移至顶端(z轴上的顺序).
win.center()
将窗口移动到屏幕中央。
win.setPosition(x, y[, animate])
x
Integery
Integeranimate
boolean (可选) macOS
将窗口移动到x
和y
。
win.getPosition()
返回 Integer[]
- 一个包含当前窗口位置的数组。
win.setTitle(title)
title
string
将原生窗口的标题更改为title
。
win.getTitle()
返回 string
- 原生窗口的标题。
注意:网页的标题可以与原生窗口的标题不同。
win.setSheetOffset(offsetY[, offsetX])
macOS
offsetY
FloatoffsetX
Float (optional)
改变macOS上sheet组件的附着点。 默认情况下,sheet贴在窗口边框正下方,但你可能需要在 HTML 渲染工具栏下方显示它们。 例如:
const { BaseWindow } = require('electron')
const win = new BaseWindow()
const toolbarRect = document.getElementById('toolbar').getBoundingClientRect()
win.setSheetOffset(toolbarRect.height)
win.flashFrame(flag)
History
Version(s) | Changes |
---|---|
None |
|
None | API ADDED |
flag
boolean
启动或停止闪烁窗口, 以吸引用户的注意。
win.setSkipTaskbar(skip)
macOS Windows
skip
boolean
使窗口不显示在任务栏中。
win.setKiosk(flag)
flag
boolean
进入或离开 kiosk 模式。
win.isKiosk()
返回 boolean
- 判断窗口是否处于kiosk模式。
win.isTabletMode()
Windows
返回 boolean
- 当前窗口是否处于 Windows 10 平板模式
由于 Windows 10 用户可以 将 PC 用作平板电脑, 在此模式下,应用程序可以选择优化其 UI 以适应平板电脑,如扩展标题栏和隐藏标题栏按钮。
此 API 返回窗口是否在平板电脑模式下,并且 resize
事件可以用于监听对平板模式的更改。
win.getMediaSourceId()
返回 string
- DesktopCapturerSource格式的窗口 id 。 例如 "window:1324:0"。
更确切地说,格式是 window:id:other_id
。在Windows上 id
是 HWND
类型;在macOS上是 CGWindowID
(uint64_t
);在Linux上是 Window
(unsigned long
)。 other_id
用于识别同一顶层窗口内的Web 内容 (选项卡)。
win.getNativeWindowHandle()
返回 Buffer
- 窗口的平台特定句柄。
Windows上句柄类型为 HWND
,macOS 上为 NSView*
,Linux 上为Window
(unsigned long
)。
win.hookWindowMessage(message, callback)
Windows
message
Integercallback
FunctionwParam
Buffer - 提供给WndProc
的wParam
值lParam
Buffer - 提供给WndProc
的lParam
值
钩住窗口消息。 当消息到达 WndProc 时调用callback
。
win.isWindowMessageHooked(message)
Windows
message
Integer
返回 boolean
- true
或false
,具体取决于是否钩挂了消息。
win.unhookWindowMessage(message)
Windows
message
Integer
取消窗口信息的钩子。
win.unhookAllWindowMessages()
Windows
取消所有窗口信息的钩子。
win.setRepresentedFilename(filename)
macOS
filename
string
设置窗口所代表的文件的路径名,并且将这个文件的图标放在窗口标题栏上。
win.getRepresentedFilename()
macOS
返回string
- 获取窗口当前文件路径.