Electron Windows增加托盤懸浮框功能

来源:https://www.cnblogs.com/lovesong/archive/2020/05/01/12813646.html
-Advertisement-
Play Games

背景 在做Electron Windows 桌面應用時候,做滑鼠懸浮到托盤圖標上時顯示一個懸浮框(例如做消息提醒),但因為Windows沒有提供托盤mouse-enter/mouse-leave事件,無法直接做這個功能,考慮到還有mouse-move事件,弄個間接的方式實現。 實現步驟 1、監聽mo ...


背景

在做Electron Windows 桌面應用時候,做滑鼠懸浮到托盤圖標上時顯示一個懸浮框(例如做消息提醒),但因為Windows沒有提供托盤mouse-enter/mouse-leave事件,無法直接做這個功能,考慮到還有mouse-move事件,弄個間接的方式實現。

實現步驟

1、監聽mouse-move事件,當觸發時,即也相當觸發mouse-enter事件。

2、開始定時(100ms)獲取托盤位置和滑鼠位置,判斷滑鼠是否還在托盤圖標里,當已不在時,觸發mouse-leave事件並停止定時查詢。

//判斷滑鼠是否還在托盤圖標
trayBounds = tray.getBounds(); point = screen.getCursorScreenPoint(); if(!(trayBounds.x < point.x && trayBounds.y < point.y && point.x < (trayBounds.x + trayBounds.width) && point.y < (trayBounds.y + trayBounds.height))){ //已不在托盤,觸發mouse-leave }

3、當mouse-enter時,顯示懸浮視窗到托盤上方,當mouse-enter,隱藏懸浮視窗。

PS:懸浮視窗需要設置置頂屬性,且不顯示在任務欄。

具體代碼

var leaveInter,
    trayBounds,
    point,
    isLeave = true;

function checkTrayLeave(){
    clearInterval(leaveInter)
    leaveInter = setInterval(function(){
        trayBounds = tray.getBounds();
        point = screen.getCursorScreenPoint();
        if(!(trayBounds.x < point.x && trayBounds.y < point.y && point.x < (trayBounds.x + trayBounds.width) && point.y < (trayBounds.y  + trayBounds.height))){
            //觸發mouse-leave
            clearInterval(leaveInter);
            isLeave = true;
        }
    }, 100)
}

tray.on('mouse-move', () => {
    if (isLeave) {
        //觸發mouse-enter
        isLeave = false;
        checkTrayLeave();
    }
})

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、查詢所有列 select *from emp;--*表示所有的,from emp表示從emp表中查詢。 2、查詢指定列 select empno,ename from emp; select 888 from emp;--ok,輸出的行數是emp表的行數,每行只有一個欄位,值是888。 sele ...
  • oracle的安裝,用戶授權,表格操作,數據類型,ddl表格,dml數據。 下一篇:Oracle入門學習二 學習視頻:https://www.bilibili.com/video/BV1tJ411r7EC?p=15 安裝教程附帶百度雲安裝包:https://blog.csdn.net/qq_4077 ...
  • ansbile安裝: # ansible在CentOS7中需要安裝epel倉庫 yum install -y epel-release yum install -y ansible 安裝有好幾種方法,yum安裝是最簡單的,安裝ansible不是重點。 我的版本如下: [root@szwpldb108 ...
  • 表結構 student(StuId,StuName,StuAge,StuSex) 學生表 teacher(TId,Tname) 教師表 course(CId,Cname,C_TId) 課程表 sc(SId,S_CId,Score) 成績表 問題一:查詢“001”課程比“002”課程成績高的所有學生的 ...
  • 本學期正在學習資料庫,前段時間老師讓我們做一下50個經典SQL語句,當時做的比較快,有一些也是百度的,自我感覺理解的不是很透徹。 所以從本篇隨筆開始,我將進行50個經典SQL語句的復盤,加深理解。 答案僅供參考,不一定完全正確,若發現錯誤或有更好的,歡迎評論,互相交流,一起成長!!! 表結構 stu ...
  • 一、資料庫基本概念 數據、資料庫、資料庫管理系統和資料庫系統是資料庫中最常用的四個基本概念: 資料庫:長期存儲在電腦中有組織的、可共用的數據集合; → 資料庫的特點:1、具有較小的冗餘度;2、較高的數據獨立性;3、系統易於擴展(擴展性強);4、共用程度高; 資料庫管理系統(DBMS):專門用於建立 ...
  • 我們通常下載文件的方式無非後端給一個生成文件鏈接, 前端通過a標簽或者iframe的方式去下載,這種方式的弊端是無法監測到文件是否下載完成,無法給用戶友好的提示,以避免用戶短時間內重覆點擊下載. 如果我們能用Ajax從後端拿到PDF的相關數據,再在前端下載成PDF就可以解決這個問題,那麼新的問題是: ...
  • 項目背景:在自己的主頁中添加一個百度搜索框,在裡面輸入要搜索的內容後可以直接跳轉到相關內容搜索結果的界面。搜索框是用form表單實現的,action中為百度的url,將輸入的內容拼接到url中,以實現直接跳轉到搜索結果界面。 1.觀察在百度中搜索內容時的url,打開百度一下,輸入搜索內容,如123 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...