Electron-Windows 任務(wù)欄

Electron有API來配置Windows任務(wù)欄中的應(yīng)用程序圖標(biāo)。 支持的有 創(chuàng)建一個(gè) 彈出列表, 自定義縮略圖和工具欄, 圖標(biāo)疊加, 和所謂的 "閃爍框" 效果, 而且 Electron 還使用應(yīng)用程序的 dock 圖標(biāo)來實(shí)現(xiàn)跨平臺(tái)功能 比如 最近文檔 和 應(yīng)用進(jìn)程.

彈出列表

Windows 允許應(yīng)用程序定義一個(gè)自定義上下文菜單椰棘,用戶可以看到該菜單 右鍵單擊任務(wù)欄中的應(yīng)用圖標(biāo)悲酷。 該上下文菜單被成為 彈出列表. 您可以在彈出列表的 Tasks 類別中指定自定義操作, 來自 MSDN 的引用:

應(yīng)用程序的tasks應(yīng)該是基于程序的功能和用戶能用它做一些的關(guān)鍵性事情來制定的慢洋。 任務(wù)應(yīng)當(dāng)是上下文無關(guān)的干花,因?yàn)樗恍枰绦蜻\(yùn)行就可以工作 而且他們應(yīng)該是統(tǒng)計(jì)上用戶在這個(gè)應(yīng)用上最多的行為例如: 撰寫一封郵件或者在郵件程序里打開日歷扣典,word處理程序新建一個(gè)文檔懂傀,以某一種模式啟動(dòng)應(yīng)用程序,或者是啟動(dòng)應(yīng)用程序的某些子命令犀呼。 一個(gè)應(yīng)用程序不應(yīng)當(dāng)把菜單用一些用戶不需要的高級(jí)功能的或者只會(huì)使用一次的動(dòng)作例如注冊(cè)給弄得雜亂無章幸撕。 不要將tasks功能用于廣告項(xiàng)目例如升級(jí)或者特價(jià)產(chǎn)品之類。

強(qiáng)烈推薦task列表內(nèi)容是靜態(tài)的外臂。 不管應(yīng)用程序是什么狀態(tài)或情形坐儿,它都應(yīng)該是保持不變的宋光。 盡管這個(gè)列表是動(dòng)態(tài)可變的,你應(yīng)該考慮到?jīng)]想過這個(gè)列表會(huì)變的用戶會(huì)被這個(gè)行為搞糊涂逛漫。

Internet Explorer 的 任務(wù):

20191114001.png

不同于 macOS 的dock菜單,Windows 上的用戶任務(wù)表現(xiàn)得更像一個(gè)快捷方式赘艳,比如當(dāng)用戶點(diǎn)擊一個(gè)任務(wù),一個(gè)程序?qū)?huì)被傳入特定的參數(shù)并且運(yùn)行阔馋。

你可以使用 app.setUserTasks API 來設(shè)置你的應(yīng)用中的用戶任務(wù):

const { app } = require('electron')
app.setUserTasks([
  {
    program: process.execPath,
    arguments: '--new-window',
    iconPath: process.execPath,
    iconIndex: 0,
    title: 'New Window',
    description: 'Create a new window'
  }
])

調(diào)用 app.setUserTasks 并傳入空數(shù)組就可以清除你的任務(wù)列表:

const { app } = require('electron')
app.setUserTasks([])

縮略圖工具欄

在 Windows,你可以在任務(wù)欄上添加一個(gè)按鈕來當(dāng)作應(yīng)用的縮略圖工具欄娇掏。 它為用戶提供了一種訪問特定窗口命令的方式, 而無需還原或激活該窗口呕寝。

在 MSDN下梢,它的說明如下:

此工具欄只是常見的標(biāo)準(zhǔn)工具欄控件塞蹭。 它最多擁有七個(gè)按鈕番电。 每個(gè)按鈕的 ID这刷、圖像暇屋、工具提示和狀態(tài)都定義在結(jié)構(gòu)中, 然后傳遞給任務(wù)欄洞辣。 應(yīng)用程序可以根據(jù)其當(dāng)前狀態(tài)的要求, 顯示、啟用定鸟、禁用或隱藏縮略圖工具欄中的按鈕仔粥。

例如, Windows 媒體播放機(jī)可能提供標(biāo)準(zhǔn)的媒體傳輸控制, 如播放、暫停谭羔、靜音和停止麦向。

Windows Media Player 的縮略圖工具欄:

20191114002.png

你可以使用 BrowserWindow.setThumbarButtons 來設(shè)置你的應(yīng)用的縮略圖工具欄话告。

const { BrowserWindow } = require('electron')
const path = require('path')

const win = new BrowserWindow()

win.setThumbarButtons([
  {
    tooltip: 'button1',
    icon: path.join(__dirname, 'button1.png'),
    click () { console.log('button1 clicked') }
  }, {
    tooltip: 'button2',
    icon: path.join(__dirname, 'button2.png'),
    flags: ['enabled', 'dismissonclick'],
    click () { console.log('button2 clicked.') }
  }
])

調(diào)用 BrowserWindow.setThumbarButtons 并傳入空數(shù)組即可清空縮略圖工具欄:

const { BrowserWindow } = require('electron')

const win = new BrowserWindow()
win.setThumbarButtons([])

任務(wù)欄中的圖標(biāo)疊加

在 Windows沙郭,任務(wù)欄按鈕可以使用小型疊加層顯示應(yīng)用程序 狀態(tài)裳朋,引用 MSDN 的文檔:

圖標(biāo)疊加作為狀態(tài)的上下文通知, 旨在否定需要一個(gè)單獨(dú)的通知區(qū)域狀態(tài)圖標(biāo)來將該信息傳達(dá)給用戶。 例如, 當(dāng)前在通知區(qū)域中顯示的 Microsoft Outlook 中的新郵件狀態(tài)現(xiàn)在可以通過任務(wù)欄按鈕上的疊加來表示鲤嫡。 同樣, 您必須在開發(fā)周期中決定哪個(gè)方法最適合您的應(yīng)用程序。 疊加圖標(biāo)用于提供重要的惕耕、長(zhǎng)期的狀態(tài)或通知, 如網(wǎng)絡(luò)狀態(tài)诫肠、messenger 狀態(tài)或新郵件区赵。 不應(yīng)向用戶顯示不斷變化的疊加或動(dòng)畫。

任務(wù)欄按鈕的疊加:

20191114003.png

要設(shè)置窗口的疊加層圖標(biāo),可以使用 BrowserWindow.setOverlayIcon API:

const { BrowserWindow } = require('electron')
let win = new BrowserWindow()
win.setOverlayIcon('path/to/overlay.png', 'Description for overlay')

閃爍框

在Windows上骡送,你可以突出顯示任務(wù)欄按鈕以獲得用戶的關(guān)注摔踱。 這與在macOS上彈跳停靠欄圖標(biāo)相似蛹批。 來自 MSDN 參考文檔:

通常, 會(huì)閃現(xiàn)一個(gè)窗口, 通知用戶該窗口需要注意, 但是該窗口當(dāng)前沒有鍵盤焦點(diǎn)篮愉。

要在 BrowserWindow 的任務(wù)欄按鈕突出顯示试躏,可以使用 BrowserWindow.flashFrame API:

const { BrowserWindow } = require('electron')
let win = new BrowserWindow()
win.once('focus', () => win.flashFrame(false))
win.flashFrame(true)

不要忘記調(diào)用 flashFrame 方法參數(shù)為 false 來關(guān)閉突出顯示。 在上面的示例中, 當(dāng)窗口進(jìn)入焦點(diǎn)時(shí)會(huì)調(diào)用它, 但您可能會(huì)使用超時(shí)或其他一些事件來禁用它泣刹。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末椅您,一起剝皮案震驚了整個(gè)濱河市襟沮,隨后出現(xiàn)的幾起案子昌腰,更是在濱河造成了極大的恐慌遭商,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,589評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件巫玻,死亡現(xiàn)場(chǎng)離奇詭異仍秤,居然都是意外死亡可很,警方通過查閱死者的電腦和手機(jī)我抠,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,615評(píng)論 3 396
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來笛厦,“玉大人俺夕,你說我怎么就攤上這事∫坦龋” “怎么了菠秒?”我有些...
    開封第一講書人閱讀 165,933評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵践叠,是天一觀的道長(zhǎng)嚼蚀。 經(jīng)常有香客問我,道長(zhǎng)弄捕,這世上最難降的妖魔是什么守谓? 我笑而不...
    開封第一講書人閱讀 58,976評(píng)論 1 295
  • 正文 為了忘掉前任斋荞,我火速辦了婚禮虐秦,結(jié)果婚禮上悦陋,老公的妹妹穿的比我還像新娘。我一直安慰自己幸逆,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,999評(píng)論 6 393
  • 文/花漫 我一把揭開白布送矩。 她就那樣靜靜地躺著,像睡著了一般菇怀。 火紅的嫁衣襯著肌膚如雪晌块。 梳的紋絲不亂的頭發(fā)上匆背,一...
    開封第一講書人閱讀 51,775評(píng)論 1 307
  • 那天钝尸,我揣著相機(jī)與錄音,去河邊找鬼铃辖。 笑死猪叙,一個(gè)胖子當(dāng)著我的面吹牛穴翩,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播歉嗓,決...
    沈念sama閱讀 40,474評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼遥椿,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼淆储!你這毒婦竟也來了本砰?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,359評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤舔株,失蹤者是張志新(化名)和其女友劉穎载慈,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體辞做,經(jīng)...
    沈念sama閱讀 45,854評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡秤茅,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,007評(píng)論 3 338
  • 正文 我和宋清朗相戀三年框喳,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了五垮。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片粪般。...
    茶點(diǎn)故事閱讀 40,146評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡亩歹,死狀恐怖小作,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情达罗,我是刑警寧澤静秆,帶...
    沈念sama閱讀 35,826評(píng)論 5 346
  • 正文 年R本政府宣布抚笔,位于F島的核電站,受9級(jí)特大地震影響辐宾,放射性物質(zhì)發(fā)生泄漏叠纹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,484評(píng)論 3 331
  • 文/蒙蒙 一与涡、第九天 我趴在偏房一處隱蔽的房頂上張望递沪。 院中可真熱鬧综液,春花似錦儒飒、人聲如沸桩了。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,029評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽喳钟。三九已至在岂,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間易茬,已是汗流浹背抽莱。 一陣腳步聲響...
    開封第一講書人閱讀 33,153評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工食铐, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留叠蝇,地道東北人年缎。 一個(gè)月前我還...
    沈念sama閱讀 48,420評(píng)論 3 373
  • 正文 我出身青樓单芜,卻偏偏與公主長(zhǎng)得像洲鸠,于是被迫代替她去往敵國(guó)和親馋缅。 傳聞我的和親對(duì)象是個(gè)殘疾皇子萤悴,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,107評(píng)論 2 356

推薦閱讀更多精彩內(nèi)容