screen
Retrieve information about screen size, displays, cursor position, etc.
Process: Main
This module cannot be used until the ready event of the app module is emitted.
screen ist ein EventEmitter.
[!NOTE] In the renderer / DevTools,
window.screenis a reserved DOM property, so writinglet { screen } = require('electron')will not work.
An example of creating a window that fills the whole screen:
- main.js
// Retrieve information about screen size, displays, cursor position, etc.
//
// For more info, see:
// https://www.electronjs.org/docs/latest/api/screen
const { app, BrowserWindow, screen } = require('electron/main')
let mainWindow = null
app.whenReady().then(() => {
  // Create a window that fills the screen's available work area.
  const primaryDisplay = screen.getPrimaryDisplay()
  const { width, height } = primaryDisplay.workAreaSize
  mainWindow = new BrowserWindow({ width, height })
  mainWindow.loadURL('https://electronjs.org')
})
Another example of creating a window in the external display:
const { app, BrowserWindow, screen } = require('electron')
let win
app.whenReady().then(() => {
  const displays = screen.getAllDisplays()
  const externalDisplay = displays.find((display) => {
    return display.bounds.x !== 0 || display.bounds.y !== 0
  })
  if (externalDisplay) {
    win = new BrowserWindow({
      x: externalDisplay.bounds.x + 50,
      y: externalDisplay.bounds.y + 50
    })
    win.loadURL('https://github.com')
  }
})
[!NOTE] Screen coordinates used by this module are Point structures. There are two kinds of coordinates available to the process:
- Physical screen points are raw hardware pixels on a display.
- Device-independent pixel (DIP) points are virtualized screen points scaled based on the DPI (dots per inch) of the display.
Ereignisse
Das screen Modul sendet folgende Ereignisse aus:
Event: 'display-added'
Kehrt zurück:
- eventEvent
- newDisplayDisplay
Emitted when newDisplay has been added.
Event: 'display-removed'
Kehrt zurück:
- eventEvent
- oldDisplayDisplay
Emitted when oldDisplay has been removed.
Event: 'display-metrics-changed'
Kehrt zurück:
- eventEvent
- displayDisplay
- changedMetricsstring[]
Emitted when one or more metrics change in a display. The changedMetrics is an array of strings that describe the changes. Possible changes are bounds, workArea, scaleFactor and rotation.
Methoden
Das screen Modul besitzt die folgenden Methoden:
screen.getCursorScreenPoint()
Returns Point
The current absolute position of the mouse pointer.
[!NOTE] The return value is a DIP point, not a screen physical point.
screen.getPrimaryDisplay()
Returns Display - The primary display.
screen.getAllDisplays()
Returns Display[] - An array of displays that are currently available.
screen.getDisplayNearestPoint(point)
- pointPoint
Returns Display - The display nearest the specified point.
screen.getDisplayMatching(rect)
- rectRectangle
Returns Display - The display that most closely intersects the provided bounds.
screen.screenToDipPoint(point) Windows Linux
- pointPoint
Returns Point
Converts a screen physical point to a screen DIP point. The DPI scale is performed relative to the display containing the physical point.
Not currently supported on Wayland - if used there it will return the point passed in with no changes.
screen.dipToScreenPoint(point) Windows Linux
- pointPoint
Returns Point
Converts a screen DIP point to a screen physical point. The DPI scale is performed relative to the display containing the DIP point.
Not currently supported on Wayland.
screen.screenToDipRect(window, rect) Windows
- windowBrowserWindow | null
- rectRectangle
Returns Rectangle
Converts a screen physical rect to a screen DIP rect. The DPI scale is performed relative to the display nearest to window. If window is null, scaling will be performed to the display nearest to rect.
screen.dipToScreenRect(window, rect) Windows
- windowBrowserWindow | null
- rectRectangle
Returns Rectangle
Converts a screen DIP rect to a screen physical rect. The DPI scale is performed relative to the display nearest to window. If window is null, scaling will be performed to the display nearest to rect.