教程六 在Go中使用Energy創(chuàng)建跨平臺GUI - 瀏覽器下載事件


介紹

Energy應用下載文件時觸發(fā)的下載事件和使用

我們在頁面上下載文件時隅忿,可以對文件下載時的處理心剥,例如:保存路徑,下載取消背桐,開始优烧、暫停。

下面將用代碼和注釋链峭,和簡要的說明來演示


Go代碼示例

想要運行此示例畦娄,需要安裝好Go和Energy開發(fā)環(huán)境

  • 主窗口初始化回調(diào)函數(shù)里設置事件
cef.BrowserWindow.SetBrowserInit(func(event *cef.BrowserEvent, browserWindow cef.IBrowserWindow){})

下載事件注冊

下載之前事件

  • 在頁面中下載時觸發(fā)該函數(shù)OnBeforeDownload,例如點擊某下載鏈接
  • OnBeforeDownload事件弊仪,可以設置保存路徑熙卡,顯示保存提示框和不顯示保存提示框
  • Linux下由于上游原因,需要自定義保存提示框励饵,否則無法顯示驳癌。
  • Windows和MacOSX保存提示框都正常
  • 值得注意的是 cef.QueueSyncCall 函數(shù),其作用是將UI相關的操作移至到UI線程中執(zhí)行役听,該函數(shù)是異步的颓鲜。詳情參考源碼注釋
  • 這里針對linux系統(tǒng)自定義了保存提示框

lcl.NewSaveDialog

event.SetOnBeforeDownload(func(sender lcl.IObject, browser *cef.ICefBrowser, beforeDownloadItem *cef.DownloadItem, suggestedName string, callback *cef.ICefBeforeDownloadCallback) 

下載更新事件

  • 下載更新事件OnDownloadUpdated,該函數(shù)實時更新下載項的進度
  • 在該函數(shù)中可以對每個下載項操作典予,下載取消甜滨,開始、暫停, 恢復下載熙参。
    • 下載項操作需要在函數(shù)執(zhí)行周期內(nèi)操作艳吠,不可在函數(shù)執(zhí)行周期之外。
  • 示例中下載進度使用了事件機制孽椰,把下載信息發(fā)送給web端展示: [Go調(diào)用JS事件]
event.SetOnDownloadUpdated(func(sender lcl.IObject, browser *cef.ICefBrowser, downloadItem *cef.DownloadItem, callback *cef.ICefDownloadItemCallback)
package main

import (
    "embed"
    "fmt"
    "github.com/energye/energy/v2/cef"
    "github.com/energye/energy/v2/cef/ipc"
    "github.com/energye/energy/v2/common"
    "github.com/energye/energy/v2/pkgs/assetserve"
    "github.com/energye/golcl/lcl"
)

//資源目錄昭娩,內(nèi)置到執(zhí)行程序中
//go:embed resources
var resources embed.FS

//這個示例使用了幾個事件來演示下載文件
//在cef.BrowserWindow.SetBrowserInit初始化函數(shù)中設置event.SetOnBeforeDownload,用于設置保存目錄
//并且設置event.SetOnDownloadUpdated獲取下載進度信息
func main() {
    //全局初始化 每個應用都必須調(diào)用的
    cef.GlobalInit(nil, &resources)
    //創(chuàng)建應用
    cefApp := cef.NewApplication()
    //主窗口的配置
    //指定一個URL地址黍匾,或本地html文件目錄
    cef.BrowserWindow.Config.Url = "http://localhost:22022/download.html"
    if common.IsLinux() && cefApp.IsUIGtk3() {
        cef.BrowserWindow.Config.IconFS = "resources/icon.png"
    } else {
        cef.BrowserWindow.Config.IconFS = "resources/icon.ico"
    }
    //在主窗口初始化回調(diào)函數(shù)里設置瀏覽器事件
    cef.BrowserWindow.SetBrowserInit(func(event *cef.BrowserEvent, browserWindow cef.IBrowserWindow) {
        //下載更新事件
        //1. 返回下載進度
        //2. downloadItem 下載項
        //3. callback 下載狀態(tài)的控制, 下載暫停栏渺,開始、取消
        //4. 將下載進度通過事件機制發(fā)送到html中展示
        event.SetOnDownloadUpdated(func(sender lcl.IObject, browser *cef.ICefBrowser, downloadItem *cef.ICefDownloadItem, callback *cef.ICefDownloadItemCallback) {
            //傳遞數(shù)據(jù)參數(shù)到html中
            //這些參數(shù)按下標順序?qū)絡s函數(shù)參數(shù)位置
            //演示只傳遞了幾個參數(shù)
            fmt.Println("DownloadUpdated frameId", browser.MainFrame().Identifier(), "BeforeDownload Id:", downloadItem.Id(), "originalUrl:", downloadItem.OriginalUrl(), "url:", downloadItem.Url())
            fmt.Println("\t", downloadItem.State(), downloadItem.TotalBytes(), "/", downloadItem.ReceivedBytes(), "speed:", downloadItem.CurrentSpeed(), "fullPath", downloadItem.FullPath())
            ipc.Emit("downloadUpdateDemo", downloadItem.Id(), downloadItem.FullPath(), downloadItem.ReceivedBytes(), downloadItem.TotalBytes())
        })
    })
    //在主進程啟動成功之后執(zhí)行
    //在這里啟動內(nèi)置http服務
    //內(nèi)置http服務需要使用 go:embed resources 內(nèi)置資源到執(zhí)行程序中
    cef.SetBrowserProcessStartAfterCallback(func(b bool) {
        fmt.Println("主進程啟動 創(chuàng)建一個內(nèi)置http服務")
        //通過內(nèi)置http服務加載資源
        server := assetserve.NewAssetsHttpServer()
        server.PORT = 22022               //服務端口號
        server.AssetsFSName = "resources" //必須設置目錄名和資源文件夾同名
        server.Assets = &resources
        go server.StartHttpServer()
    })
    //運行應用
    cef.Run(cefApp)
}


html代碼示例

html中寫了幾個下載鏈接

html中定義了事件監(jiān)聽锐涯,ipc.on磕诊,事件名downloadUpdateDemo

downloadUpdateDemo事件接收Go觸發(fā)的事件,Go發(fā)送的消息由此事件函數(shù)接收

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>下載文件示例</title>
    <script>
        console.log("下載文件示例")
        //使用ipc.on監(jiān)聽事件
        ipc.on("downloadUpdateDemo", function (id, suggestedFileName, receivedBytes, totalBytes) {
            console.log(id, suggestedFileName, receivedBytes, totalBytes)
            var downloadMessage = document.getElementById("downloadMessage")
            downloadMessage.innerHTML = downloadMessage.innerHTML + ("id: " + id + "  suggestedFileName: " + suggestedFileName + "  receivedBytes: " + receivedBytes + " / totalBytes: " + totalBytes) + "<br>"
        });
    </script>
</head>
<body style="overflow: hidden;margin: 10px;padding: 10px;">
<h3>download demo:</h3><br>
<a >Windows 32 bits</a>
<br>
<a >Windows 64 bits</a>
<br>
<a >Linux x86 64
    bits</a> <br>
<a >MacOSX x86 64
    bits</a> <br>
<div id="downloadMessage">

</div>
</body>
</html>

運行效果圖 - download

image
最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市霎终,隨后出現(xiàn)的幾起案子滞磺,更是在濱河造成了極大的恐慌,老刑警劉巖莱褒,帶你破解...
    沈念sama閱讀 218,122評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件击困,死亡現(xiàn)場離奇詭異,居然都是意外死亡广凸,警方通過查閱死者的電腦和手機阅茶,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來谅海,“玉大人脸哀,你說我怎么就攤上這事∨び酰” “怎么了撞蜂?”我有些...
    開封第一講書人閱讀 164,491評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長智末。 經(jīng)常有香客問我谅摄,道長,這世上最難降的妖魔是什么系馆? 我笑而不...
    開封第一講書人閱讀 58,636評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮顽照,結果婚禮上由蘑,老公的妹妹穿的比我還像新娘。我一直安慰自己代兵,他們只是感情好尼酿,可當我...
    茶點故事閱讀 67,676評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著植影,像睡著了一般裳擎。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上思币,一...
    開封第一講書人閱讀 51,541評論 1 305
  • 那天鹿响,我揣著相機與錄音,去河邊找鬼谷饿。 笑死惶我,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的博投。 我是一名探鬼主播绸贡,決...
    沈念sama閱讀 40,292評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了听怕?” 一聲冷哼從身側響起捧挺,我...
    開封第一講書人閱讀 39,211評論 0 276
  • 序言:老撾萬榮一對情侶失蹤肪获,失蹤者是張志新(化名)和其女友劉穎碌更,沒想到半個月后甸私,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體身堡,經(jīng)...
    沈念sama閱讀 45,655評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡亚享,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,846評論 3 336
  • 正文 我和宋清朗相戀三年氮发,在試婚紗的時候發(fā)現(xiàn)自己被綠了盆犁。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片肚邢。...
    茶點故事閱讀 39,965評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡酥艳,死狀恐怖摊溶,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情充石,我是刑警寧澤莫换,帶...
    沈念sama閱讀 35,684評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站骤铃,受9級特大地震影響拉岁,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜惰爬,卻給世界環(huán)境...
    茶點故事閱讀 41,295評論 3 329
  • 文/蒙蒙 一喊暖、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧撕瞧,春花似錦陵叽、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至页畦,卻和暖如春胖替,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背豫缨。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評論 1 269
  • 我被黑心中介騙來泰國打工独令, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人州胳。 一個月前我還...
    沈念sama閱讀 48,126評論 3 370
  • 正文 我出身青樓记焊,卻偏偏與公主長得像,于是被迫代替她去往敵國和親栓撞。 傳聞我的和親對象是個殘疾皇子遍膜,可洞房花燭夜當晚...
    茶點故事閱讀 44,914評論 2 355

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