自從上一篇 利用 PhotoShop 製作 CSS Sprite 發佈後我又改了 JSX 好幾次,現在終於修到讓我自己滿意了,順便來寫一下使用方法。
由於我的 PhotoShop 是 CS2 的,太舊的版本可能會沒有 Script 的功能,在這裡先聲明一下。
檔案連結:css_sprite_ps-script.jsx
2010-09-12 02:12
2010-09-03 03:28
用 Eclipse CDT 編譯 CppSQLite3
工作上為了讓 sqlite 可以在 platform 上執行,所以必須從完整的 source code 開始編譯,對於不怎麼熟悉 Makefile 的我這真是一件麻煩的事,還好以前有玩過 CDT,索性就利用他可以自動建立 Makefile 的功能來做。
不過我是使用 Eclipse 3.2 版的 CDT,Eclipse 3.5 的 CDT 裡的 Makefile 我不太會用,也沒有時間去找文章。
這裡我下載了兩個檔案:
SQLite -> sqlite-source-3_7_2.zip
CppSQLite -> CppSQLite_3_1_demo_and_src.zip
首先建立動態連結庫
再來建立主程式專案
不過我是使用 Eclipse 3.2 版的 CDT,Eclipse 3.5 的 CDT 裡的 Makefile 我不太會用,也沒有時間去找文章。
這裡我下載了兩個檔案:
SQLite -> sqlite-source-3_7_2.zip
CppSQLite -> CppSQLite_3_1_demo_and_src.zip
首先建立動態連結庫
- 新增 "Managed Make C++ Project" 專案 -> 名稱 "cppsqlite"
- 在 Project Type 中選擇 Shared Library
- 在專案下新增 src 資料夾
- 複製 sqlite-source-3_7_2.zip 中所有的 source code 至 src 除了 shell.c 與 tclsqlite.c
- 再複製 CppSQLite_3_1_demo_and_src.zip 中的 CppSQLite3.h 與 CppSQLite3.cpp
- 開啟:專案 -> 內容
- 增加 Defined symbols 變數 -> SQLITE_CORE
- 在 C++ 跟 C 的 Optimization 的參數中增加 -fPIC 最佳化參數
- 按下『確定』後就會開始編譯,檔案有點多要稍微等一下
再來建立主程式專案
- 新增 "Managed Make C++ Project" 專案 -> 名稱 "sqlite-test"
- 在 Project Type 中選擇 Executable
- 在專案下新增 src 資料夾
- 複製 CppSQLite_3_1_demo_and_src.zip 中的 CppSQLite3Demo.cpp 至 src
- 開啟:專案 -> 內容
- 新增 Include paths -> "../../cppsqlite/src"
這個設定是在告知編譯時額外 Include 的進來 Header(*.h) 的路徑。 - 新增連結路徑:
Library search path -> "../../cppsqlite/Debug"
Libraries -> cppsqlite
這個設定是給 gcc 在做連結時需要的搜尋路徑,以及需要連結的對象名稱。 - 按下『確定』後就會開始編譯
- 接著要將 cppsqlite.dll 複製到 sqlite-test/Debug 下
Windows 的 lib 名稱為 "cppsqlite.dll"
Linux 的 lib 名稱為 "libcppsqlite.so" - 然後就可以執行 sqlite-test.exe 了 (一整個就很快樂)
2010-09-01 23:50
利用 PhotoShop 製作 CSS Sprite
原本想用 PhotoShop 的巨集來製作 CSS Sprite 的圖片,但沒想到巨集沒辦法很方便的匯入圖片到圖層上,最後找到一個可行的方法就是寫 PhotoShop 的 Script。
我只有兩個需求:雖然已經寫完了,但是還是有一些小小的 Bug,對於透明底色的 png 會有定位上的偏差,我的解決辦法就是在四個角畫上 1px 透明為 1% 的白色,雖然美中不足但勉強夠用。
這個小 Bug 已經解決了。
這個 Script 的執行方式很簡單
只要將需要合併的圖檔全部開啟
接著『檔案 -> 指令碼 -> 瀏覽』選擇下載後的 css_sprite_ps-script.jsx
執行後會建立一個新圖檔,並且要選擇輸出的 CSS 的檔案名稱
檔案下載:css_sprite_ps-script.jsx
有對這個興趣的朋友可以參考 PhotoShop 安裝目錄下的 "JavaScript Reference Guide.pdf" 的開發文件,雖然裡面全部都是英文的但還不置於看不懂。
我只有兩個需求:
- 處理圖檔組合
- 紀錄每張圖的起始定位
這個小 Bug 已經解決了。
這個 Script 的執行方式很簡單
只要將需要合併的圖檔全部開啟
接著『檔案 -> 指令碼 -> 瀏覽』選擇下載後的 css_sprite_ps-script.jsx
執行後會建立一個新圖檔,並且要選擇輸出的 CSS 的檔案名稱
// css_sprite_ps-script.jsx
#target photoshop
/** 建立參考線
* @param {Int} pixelOffSet 偏移像素
* @param {String} orientation ["Vrtc" => 垂直 ,"Hrzn" => 水平]
*/
function makeGuide(pixelOffSet, orientation) {
var id8 = charIDToTypeID( "Mk " );
var desc4 = new ActionDescriptor();
var id9 = charIDToTypeID( "Nw " );
var desc5 = new ActionDescriptor();
var id10 = charIDToTypeID( "Pstn" );
var id11 = charIDToTypeID( "#Rlt" );
desc5.putUnitDouble( id10, id11, pixelOffSet ); // integer
var id12 = charIDToTypeID( "Ornt" );
var id13 = charIDToTypeID( "Ornt" );
var id14 = charIDToTypeID( orientation ); // "Vrtc", "Hrzn"
desc5.putEnumerated( id12, id13, id14 );
var id15 = charIDToTypeID( "Gd " );
desc4.putObject( id9, id15, desc5 );
executeAction( id8, desc4, DialogModes.NO );
}
function main(){
//判斷是否有開啟圖檔
if (app.documents.length = 0) {return;}
//設定前景色為白色
app.foregroundColor.rgb.hexValue = 'FFFFFF';
var atDoc;
var list = [];
var length = app.documents.length;
//新增目標圖片文件
var newPic = app.documents.add(
1, 1, 72,
"css_sprite",
NewDocumentMode.RGB,
DocumentFill.TRANSPARENT
);
var height=0;
var width = newPic.width;
//複製所有圖檔至新建立的圖檔
for (var i=0; i<length; i++){
atDoc=app.activeDocument=app.documents[i];
//記錄圖層資訊
var newLayer={
name: atDoc.name, //檔名
width: atDoc.width,
height: atDoc.height,
top: height
};
//累計高度
height += app.documents[i].height.value;
//最大寬度
if(width < atDoc.width){ width=atDoc.width;}
//新增圖層
var aLayer = atDoc.activeLayer=atDoc.artLayers.add();
//複製背景底圖
try {
atDoc.backgroundLayer.duplicate(aLayer,ElementPlacement.PLACEAFTER);
atDoc.backgroundLayer.remove();
} catch (e){}
//將新圖層與下一層互換
aLayer.move(atDoc.layers[1],ElementPlacement.PLACEAFTER);
//標註四周的定位點
var w=atDoc.width.value, h=atDoc.height.value;
atDoc.selection.select([[0,0],[1,0],[1,1],[0,1],[0,0]]);
atDoc.selection.fill(app.foregroundColor)
atDoc.selection.select([[0,h-1],[0,h],[1,h],[1,h-1],[0,h-1]]);
atDoc.selection.fill(app.foregroundColor)
atDoc.selection.select([[w-1,0],[w-1,1],[w,1],[w,0],[w-1,0]]);
atDoc.selection.fill(app.foregroundColor)
atDoc.selection.select([[w-1,h-1],[w-1,h],[w,h],[w,h-1],[w-1,h-1]]);
atDoc.selection.fill(app.foregroundColor)
//設定透明度
aLayer.fillOpacity=1;
//合併可見圖層
atDoc.mergeVisibleLayers();
//複製圖層
atDoc.selection.selectAll()
atDoc.selection.copy()
//貼上圖層
atDoc=app.activeDocument=newPic;
newLayer.obj = atDoc.paste();
list.push(newLayer);
};
//變更圖片大小
atDoc=app.activeDocument=newPic;
atDoc.resizeCanvas(width,height,AnchorPosition.TOPLEFT);
//變更圖層定位
for (var i=length-1; i>=0; i--){
//關閉複製過的檔案
app.documents[i].close(SaveOptions.DONOTSAVECHANGES);
//移動圖層
list[i].obj.translate(0,list[i].top);
//建立參考線
if(i>0){ makeGuide(list[i].top,"Hrzn"); }
};
// 輸出 CSS 定位檔
var mySavefile = File.saveDialog("輸出 CSS 定位檔","*.css");
if(!mySavefile){return};
if(mySavefile.exists && !confirm("你確定要覆蓋這個檔案?")){
return false;
}
// 開啟檔案
var fileRef = new File(mySavefile);
if (!fileRef.open("w","","")){
alert("無法開啟檔案!!");
fileRef.close();
return false;
}
// 輸出 CSS 定位設定
for (var i=0; i<list.length; i++){
fileRef.writeln(
list[i].name+'{ background-position: 0 -'+list[i].top+'px; }'
);
};
fileRef.close();
}
//把Photoshop推到最上層
app.bringToFront();
//設定使用的單位為「像素(Pixel)」
app.preferences.rulerUnits = Units.PIXELS;
main();
檔案下載:css_sprite_ps-script.jsx
有對這個興趣的朋友可以參考 PhotoShop 安裝目錄下的 "JavaScript Reference Guide.pdf" 的開發文件,雖然裡面全部都是英文的但還不置於看不懂。
分類:
分享好物,
CSS,
PhotoShop Script (JSX)
0
回應
訂閱:
文章 (Atom)