Refine: make desktop-capturer as a renderer module.
This commit is contained in:
parent
48fbd47416
commit
1e69ef79de
12 changed files with 237 additions and 74 deletions
22
atom/renderer/api/lib/desktop-capturer.coffee
Normal file
22
atom/renderer/api/lib/desktop-capturer.coffee
Normal file
|
@ -0,0 +1,22 @@
|
|||
ipc = require 'ipc'
|
||||
remote = require 'remote'
|
||||
NativeImage = require 'native-image'
|
||||
|
||||
EventEmitter = require('events').EventEmitter
|
||||
desktopCapturer = new EventEmitter
|
||||
|
||||
# Tells main process the renderer is requiring 'desktop-capture' module.
|
||||
ipc.sendSync 'ATOM_BROWSER_DESKTOP_CAPTURER_REQUIRED'
|
||||
|
||||
desktopCapturer.startUpdating = (args) ->
|
||||
ipc.send 'ATOM_BROWSER_DESKTOP_CAPTURER_START_UPDATING', args
|
||||
|
||||
desktopCapturer.stopUpdating = () ->
|
||||
ipc.send 'ATOM_BROWSER_DESKTOP_CAPTURER_STOP_UPDATING'
|
||||
|
||||
for event_name in ['source-added', 'source-removed', 'source-name-changed', "source-thumbnail-changed"]
|
||||
do (event_name) ->
|
||||
ipc.on event_name, (source) ->
|
||||
desktopCapturer.emit event_name, { id: source.id, name: source.name, thumbnail: NativeImage.createFromDataUrl source.dataUrl }
|
||||
|
||||
module.exports = desktopCapturer
|
Loading…
Add table
Add a link
Reference in a new issue