[請益] 寫作繪圖軟體碰到的一些問題@@

看板Programming作者 (meow)時間11年前 (2012/08/03 01:09), 編輯推噓5(5046)
留言51則, 7人參與, 最新討論串1/1
最近自己在寫一個繪圖軟體 被一些問題卡住了 想跟大家討論看看 我想要寫一個類似 Photoshop 的圖層系統 這個系統要可以同時容納 1. 可切換各種混色模式的繪圖圖層 以及 2. 其他一些具有調整效果的參數圖層 我以 C++ 將它實做為類似 Link List 的資料結構 也就是將每個圖層設計為一個物件 此物件含有圖層本身的資訊(圖像或調整參數)以及一個指向下一圖層的指標 實際混色時是使用遞迴方式 也就是每個圖層都先呼叫下一圖層的混色函數 然後再將自己這一層的資訊疊加到 Buffer 上去 遞迴到碰到最底層為止 從行為上來說這個設計是沒有問題的 但是我發現當圖層增多到一個程度之後 時間和空間上的開銷都會有點不合理 以空間而言 假設一張圖是 3000*2000px 的 RGBA 格式 那麼不壓縮的大小就是 24M bytes 由於任何一個圖層有改變時 都必須將混色結果即時顯示到螢幕上 因此所有圖層資訊都要同時載入記憶體 這種情況下 只要開20 個繪圖圖層 就已經用掉 480M 的記憶體了 但我用 Photoshop 作實測 它用的記憶體連我所預估的一半都遠遠不到 如何做到這點讓我頗為好奇...... 我想過幾種改善的可能 例如將「目前工作圖層」以下的所有圖層都存進硬碟 只將這些「以下圖層」混色過後的結果載入記憶體 但這方法得要燒香拜佛 祈禱使用者多編輯上方圖層 少編輯下方圖層..... 我還想過是否可以用這種預計算的方法對付「所有以上圖層的結合」 但由於圖層的某些混色模式和某些調整顏色的演算法 都必須先決定下層圖層的顏色才能計算 所以這想法似乎也行不太通 不曉得在這方面各位有沒有什麼高見? 另外一個問題則是時間上的: 假設使用者開了100個圖層而且都沒關掉 (一般修圖情況下調整圖層比繪圖圖層多出數倍是正常的) 又將視窗畫面縮放到可以看到全圖的話 那麼必須做的即時運算 竟然有 3000*2000*100 = 100M 次混色之多!! 即使我已經對混色演算法做了 bitwise 的優化 但每次混色畢竟還是包含多次的是否判斷式、加法、乘法、位移......等等 從現實情況上來說跟本不可能來得及 (流暢動畫的最低標準是 24fps,也就是最慢0.04秒內要完成全部混色動作) 我想過一個改善方式 就是對每個像素偵測「是否已經掩蓋下層圖層」 換句話說 如果有某個像素在某一層的 Alpha 值已經是 FF 那就可以不用管他下面是三小了 但後來發現這方法會快速地在不同圖層間切換 造成 Cache 效率極差 反而不如整張一起算 老老實實的算到底XD 總之 我實在是想破頭也想不出好方法 關於這兩個問題 如果有人能給我一點方向 我會非常感激 ^^” -- 直接閱讀《琴劍六記》 http://gs.cathargraph.com/p/list.html   《琴劍六記》Facebook專頁 https://www.facebook.com/GSannals -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 61.62.253.66

08/03 01:26, , 1F
若圖層只存有色彩的矩型,而不是整張畫布呢?
08/03 01:26, 1F

08/03 01:34, , 2F
這也是要燒香拜佛啊XD 使用者有可能會把
08/03 01:34, 2F

08/03 01:35, , 3F
十幾張照片各自載入為圖層 那就整張畫布
08/03 01:35, 3F

08/03 01:35, , 4F
都有資訊了
08/03 01:35, 4F

08/03 01:37, , 5F
photoshop之所以為photoshop就是因為他
08/03 01:37, 5F

08/03 01:37, , 6F
能掌握每一layer最多需要多少空間
08/03 01:37, 6F

08/03 01:38, , 7F
不是用「原子彈爆炸」的做法
08/03 01:38, 7F

08/03 01:40, , 8F
如果姑且不論儲存空間 關於效能的問題呢?
08/03 01:40, 8F

08/03 01:41, , 9F
我想到的效能改善都是跟使用者行為有關的
08/03 01:41, 9F

08/03 01:41, , 10F
還沒想到什麼通用的方法
08/03 01:41, 10F

08/03 01:46, , 11F
如果真的沒辦法 可能就得探到更下面了
08/03 01:46, 11F

08/03 01:46, , 12F
例如用 Cuda 做平行運算之類的@@
08/03 01:46, 12F

08/03 07:28, , 13F
cuda不錯阿 shader 本來就是為這設計的
08/03 07:28, 13F

08/03 11:06, , 14F
其實有考慮用 cuda 但一直沒用的原因是不
08/03 11:06, 14F

08/03 11:06, , 15F
太想寫需要特定顯示卡支持的程式 唉
08/03 11:06, 15F

08/03 13:01, , 16F
PS對於這種極端case也這麼厲害嘛?像是20層
08/03 13:01, 16F

08/03 13:02, , 17F
都是複雜照片一樣只消耗預估的50%-?
08/03 13:02, 17F

08/03 17:52, , 18F
那不可能吧,他只會開始用硬碟當scratch
08/03 17:52, 18F

08/03 17:52, , 19F
disk而已,接著就開始變得很慢
08/03 17:52, 19F

08/03 18:34, , 20F
那就應該是只存最小面積/色彩index吧
08/03 18:34, 20F

08/03 18:42, , 21F
我也很懷疑對於3Kx2Kx100L這種東西PS真的能
08/03 18:42, 21F

08/03 18:43, , 22F
辦到很流暢的混圖層嘛XD
08/03 18:43, 22F

08/04 00:04, , 23F
100 Layers 是不少見啦 但現實情況中
08/04 00:04, 23F

08/04 00:05, , 24F
很少會將100層同時打開
08/04 00:05, 24F

08/04 00:06, , 25F
我可能要對 PS 作更詳細的測試了@@
08/04 00:06, 25F

08/04 21:27, , 26F
把各layer scale成螢幕大小(dpi)再放記
08/04 21:27, 26F

08/04 21:28, , 27F
憶體, 只有在zoom in/out的時候才重算
08/04 21:28, 27F

08/05 00:26, , 28F
不用 cuda 可以考慮看看 OpenCL @@"
08/05 00:26, 28F

08/05 03:50, , 29F
a兄的方法很好 不過那樣就不能做滾輪縮放
08/05 03:50, 29F

08/05 03:50, , 30F
了吧我想 變成縮放成本很高
08/05 03:50, 30F

08/05 08:30, , 31F
開另一個threads專職作scaling,每個laye
08/05 08:30, 31F

08/05 08:33, , 32F
只要完成就丟給主thread,互動性應該不差
08/05 08:33, 32F

08/06 09:40, , 33F
感謝指點 我再試試看^^
08/06 09:40, 33F

08/07 21:01, , 34F
我確定ps只有保存有像素的區塊
08/07 21:01, 34F

08/07 21:02, , 35F
超出那個矩形的地方根本不吃記憶體
08/07 21:02, 35F

08/07 21:03, , 36F
但相對的,如果那個圖層被移動到超出邊緣
08/07 21:03, 36F

08/07 21:03, , 37F
即使已經超出畫紙,也依然會吃記憶體
08/07 21:03, 37F

08/07 21:03, , 38F
這個設計很合理,也省記憶體,move的實作
08/07 21:03, 38F

08/07 21:04, , 39F
也很快速,缺點就是blending的時候比較貴
08/07 21:04, 39F

08/07 21:05, , 40F
另外,你要求的流暢度可能有點太超規格了
08/07 21:05, 40F

08/07 21:05, , 41F
即使是adobe的千里馬,在多層的時候,即使在
08/07 21:05, 41F

08/07 21:06, , 42F
高級電腦上也是卡卡的,除非使用GPU加速
08/07 21:06, 42F

08/07 21:06, , 43F
這是我上次去參加conference的時候,CUDA給
08/07 21:06, 43F

08/07 21:07, , 44F
的其中一個展示... 人家也要GPU才能作到:(
08/07 21:07, 44F

08/11 17:31, , 45F
多謝y兄 我再次測試的結果 正如y兄所述
08/11 17:31, 45F

08/11 17:32, , 46F
此外 先scale的方法似乎行不通 即使只做
08/11 17:32, 46F

08/11 17:33, , 47F
Bilinear 多次縮放的成本也太高了 不會
08/11 17:33, 47F

08/11 17:33, , 48F
低於Blending本身 先Blending 然後用顯
08/11 17:33, 48F

08/11 17:34, , 49F
卡縮放(我用openGL)還是比較節省
08/11 17:34, 49F

08/11 17:35, , 50F
經過一番討論 目前我已經比較有方向了
08/11 17:35, 50F

08/11 17:36, , 51F
正在努力coding中XD
08/11 17:36, 51F
文章代碼(AID): #1G6hHNyj (Programming)
文章代碼(AID): #1G6hHNyj (Programming)