Electron 打包c(diǎn)anvas總結(jié)

最近有項(xiàng)目需要用到畫布玛荞,且是跨平臺的應(yīng)用,選用了https://github.com/Automattic/node-canvas

打包過程遇到了各種麻煩仁连,開發(fā)電腦沒有問題,未裝開發(fā)環(huán)境的電腦普遍白屏径簿,詳查才知道是動(dòng)態(tài)鏈接庫的問題。

出現(xiàn)問題得解決啊纱扭,于是乎有以下幾種思路牍帚。

  1. 讓canvas靜態(tài)編譯,參考:https://blog.csdn.net/lihangxiaoji/article/details/81297342

無奈條路沒有走通乳蛾。

  1. 將依賴的動(dòng)態(tài)庫打包到.app中暗赶,修正模塊的依賴路徑解決。

用第二種雖然花費(fèi)大量精力肃叶,但至少出來結(jié)果了蹂随。
修改編譯后的canvas.node的依賴路徑:


#!/bin/sh

PRODUCT_PATH=./node_modules
INSTALL_PATH=/usr/local/opt
LOAD_PATH=@rpath/../dylib

PRODUCT_NAME=$PRODUCT_PATH/canvas/build/Release/canvas.node

install_name_tool -change "$INSTALL_PATH/pixman/lib/libpixman-1.0.dylib" "$LOAD_PATH/libpixman-1.0.dylib" "$PRODUCT_NAME"
install_name_tool -change "$INSTALL_PATH/cairo/lib/libcairo.2.dylib" "$LOAD_PATH/libcairo.2.dylib" "$PRODUCT_NAME"

install_name_tool -change "$INSTALL_PATH/glib/lib/libgobject-2.0.0.dylib" "$LOAD_PATH/libgobject-2.0.0.dylib" "$PRODUCT_NAME"
install_name_tool -change "$INSTALL_PATH/libffi/lib/libffi.6.dylib" "$LOAD_PATH/libffi.6.dylib" "$PRODUCT_NAME"

以上參數(shù)根據(jù)實(shí)際情況修改。

還有因惭,子模塊的依賴也是需要修改的岳锁。如:


PRODUCT_NAME=$PRODUCT_PATH/libcroco-0.6.3.dylib
install_name_tool -change "$INSTALL_PATH/glib/lib/libglib-2.0.0.dylib" "$LOAD_PATH/libglib-2.0.0.dylib" "$PRODUCT_NAME" 
install_name_tool -change "$INSTALL_PATH/gettext/lib/libintl.8.dylib" "$LOAD_PATH/libintl.8.dylib" "$PRODUCT_NAME" 

PRODUCT_NAME=$PRODUCT_PATH/libharfbuzz.0.dylib
install_name_tool -change "$INSTALL_PATH/glib/lib/libglib-2.0.0.dylib" "$LOAD_PATH/libglib-2.0.0.dylib" "$PRODUCT_NAME" 
install_name_tool -change "$INSTALL_PATH/gettext/lib/libintl.8.dylib" "$LOAD_PATH/libintl.8.dylib" "$PRODUCT_NAME" 
install_name_tool -change "$INSTALL_PATH/freetype/lib/libfreetype.6.dylib" "$LOAD_PATH/libfreetype.6.dylib" "$PRODUCT_NAME" 
install_name_tool -change "$INSTALL_PATH/graphite2/lib/libgraphite2.3.dylib" "$LOAD_PATH/libgraphite2.3.dylib" "$PRODUCT_NAME" 
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市蹦魔,隨后出現(xiàn)的幾起案子激率,更是在濱河造成了極大的恐慌,老刑警劉巖勿决,帶你破解...
    沈念sama閱讀 221,273評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件乒躺,死亡現(xiàn)場離奇詭異,居然都是意外死亡低缩,警方通過查閱死者的電腦和手機(jī)嘉冒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評論 3 398
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來咆繁,“玉大人讳推,你說我怎么就攤上這事⊥姘悖” “怎么了银觅?”我有些...
    開封第一講書人閱讀 167,709評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長壤短。 經(jīng)常有香客問我设拟,道長,這世上最難降的妖魔是什么久脯? 我笑而不...
    開封第一講書人閱讀 59,520評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮镰吆,結(jié)果婚禮上帘撰,老公的妹妹穿的比我還像新娘。我一直安慰自己万皿,他們只是感情好摧找,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評論 6 397
  • 文/花漫 我一把揭開白布核行。 她就那樣靜靜地躺著,像睡著了一般蹬耘。 火紅的嫁衣襯著肌膚如雪芝雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,158評論 1 308
  • 那天综苔,我揣著相機(jī)與錄音惩系,去河邊找鬼。 笑死如筛,一個(gè)胖子當(dāng)著我的面吹牛堡牡,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播杨刨,決...
    沈念sama閱讀 40,755評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼晤柄,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了妖胀?” 一聲冷哼從身側(cè)響起芥颈,我...
    開封第一講書人閱讀 39,660評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎赚抡,沒想到半個(gè)月后爬坑,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,203評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡怕品,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評論 3 340
  • 正文 我和宋清朗相戀三年妇垢,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片肉康。...
    茶點(diǎn)故事閱讀 40,427評論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡闯估,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出吼和,到底是詐尸還是另有隱情涨薪,我是刑警寧澤,帶...
    沈念sama閱讀 36,122評論 5 349
  • 正文 年R本政府宣布炫乓,位于F島的核電站刚夺,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏末捣。R本人自食惡果不足惜侠姑,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望箩做。 院中可真熱鬧莽红,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至鬼店,卻和暖如春网棍,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背妇智。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評論 1 272
  • 我被黑心中介騙來泰國打工滥玷, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人俘陷。 一個(gè)月前我還...
    沈念sama閱讀 48,808評論 3 376
  • 正文 我出身青樓罗捎,卻偏偏與公主長得像,于是被迫代替她去往敵國和親拉盾。 傳聞我的和親對象是個(gè)殘疾皇子桨菜,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評論 2 359

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

  • 用兩張圖告訴你,為什么你的 App 會(huì)卡頓? - Android - 掘金 Cover 有什么料捉偏? 從這篇文章中你...
    hw1212閱讀 12,744評論 2 59
  • 1 Webpack 1.1 概念簡介 1.1.1 WebPack是什么 1倒得、一個(gè)打包工具 2、一個(gè)模塊加載工具 3...
    Kevin_Junbaozi閱讀 6,674評論 0 16
  • 1夭禽、基本裝配 1.0 屬性注入和構(gòu)造器注入的差異 屬性注入直白易懂霞掺,缺點(diǎn)是對于屬性可選的時(shí)候,很多個(gè)構(gòu)造函數(shù)會(huì)顯得...
    宇宙超人喵學(xué)長閱讀 229評論 0 0
  • 有一天晚上讹躯,我們娘倆邊吃飯邊聊天菩彬,兒子和我說:“媽媽,我們班的M同學(xué)生病住院了潮梯∑睿”我說:“奧,以后你對M同學(xué)可是得...
    靜默心谷閱讀 391評論 3 5
  • 未來總是猝不及防秉馏,即使三十歲已過耙旦,也沒有資格享受從容。我并不是拒絕接受一個(gè)新生命的道來萝究,只是這種突然的感覺免都,和其他...
    麥趣兒閱讀 223評論 0 0