若需要在上傳圖片的時候,得知圖片的解析度大小,可以透過以下方式:
<input type="file">
$('input').change(function() {
var obj_url = URL.createObjectURL(this.files[0]);
var img = new Image;
img.onload = function() {
alert(img.width)
};
img.src = obj_url ;
});
小小的天 有大大的夢想
You got a dream, you gotta protect it!
2015年8月31日 星期一
2015年8月26日 星期三
2015年8月23日 星期日
動態載入頁面
如何保留導覽列又可以將內容切換至其他頁面?介紹可以使用JQuery的load()來達成。
如果想搭配對應的js檔,可以再加上getScript()來達成:
$("#page_classroom").load("html/classroom.html #page_classroom > *", function(){
$.getScript("js/classroom.js")});
假設想讓原先頁面裡的div區塊(id="page_classroom")取代成另一個classroom.html裡相同id的區塊,使用的語法如下:
$("#page_classroom").load("html/classroom.html #page_classroom > *");
如果想搭配對應的js檔,可以再加上getScript()來達成:
$("#page_classroom").load("html/classroom.html #page_classroom > *", function(){
$.getScript("js/classroom.js")});
2015年8月17日 星期一
[CSS] 水平垂直翻轉
若需要將一張圖片水平翻轉(左右對調),除了使用繪圖軟體去將圖片做轉向外,也可以透過CSS方式來達成。CCS語法如下:
.flipx { -moz-transform:scaleX(-1); -webkit-transform:scaleX(-1); -o-transform:scaleX(-1); transform:scaleX(-1); filter:FlipH; }
垂直翻轉也是一樣
.flipy { -moz-transform:scaleY(-1); -webkit-transform:scaleY(-1); -o-transform:scaleY(-1); transform:scaleY(-1); filter:FlipV; }
2013年8月9日 星期五
驗證子網路遮罩是否合法(NetMask Check)
驗證Netmask方式很簡單,只要判斷從netmask是否為連續1即可。
bool CheckNetMask (char* pszMask)
{
bool bFoundOne = false;
unsigned long lNetMask;
if (pszMask != NULL)
{
lNetMask = inet_addr(pszMask);
if (lNetMask == INADDR_NONE)
{
if (strcmp(pszMask, "255.255.255.255") == 0)
return true;
else
return false;
}
else
{
lNetMask = ntohl(lNetMask);
unsigned long ulMask = 1;
while (ulMask != 0)
{
if (lNetMask & ulMask)
bFoundOne = true;
else if (bFoundOne)
return false;
ulMask << 1;
}
return true;
}
}
else
return false;
}
bool CheckNetMask (char* pszMask)
{
bool bFoundOne = false;
unsigned long lNetMask;
if (pszMask != NULL)
{
lNetMask = inet_addr(pszMask);
if (lNetMask == INADDR_NONE)
{
if (strcmp(pszMask, "255.255.255.255") == 0)
return true;
else
return false;
}
else
{
lNetMask = ntohl(lNetMask);
unsigned long ulMask = 1;
while (ulMask != 0)
{
if (lNetMask & ulMask)
bFoundOne = true;
else if (bFoundOne)
return false;
ulMask << 1;
}
return true;
}
}
else
return false;
}
2013年8月4日 星期日
CoCreateInstance Fail
明明Filter有註冊,但在呼叫 CoCreateInstance時卻回傳「類別未登錄0x8004154」,經過追查之後才發現原來此Filter在Linker的Fixed Base Address的選項設定選擇了/FIXED,才導致呼叫時有機會失敗。修正方法就是將/FIXED改為/FIXED:NO的選項。
我們可以運用dumpbin的工具來驗證,如果沒有出現.reloc區段的話,表示設定的為/FIXED
我們可以運用dumpbin的工具來驗證,如果沒有出現.reloc區段的話,表示設定的為/FIXED
2013年7月13日 星期六
DIP 雙列直插封裝
對硬體不熟,但工作上還是常遇到一些常見的名詞,只好把它記下來。不過查了一下DIP這個詞,這不就是之前大學時上邏輯設計實驗就有用到的東西嗎?
雙列直插封裝(英文DIP, Dual in-line package),說穿了就是把IC封裝起來的方式。他的外型為長方型,然後會有兩排平行的針腳。他可以焊接在印刷電路板上,或是直接插入在DIP插座上。而之前學校使用的方式就是把他插在麵包板上。DIP元件一般會依據針腳的個數簡稱DIPn,下圖即為DIP20積體電路。
雙列直插封裝(英文DIP, Dual in-line package),說穿了就是把IC封裝起來的方式。他的外型為長方型,然後會有兩排平行的針腳。他可以焊接在印刷電路板上,或是直接插入在DIP插座上。而之前學校使用的方式就是把他插在麵包板上。DIP元件一般會依據針腳的個數簡稱DIPn,下圖即為DIP20積體電路。
2013年7月5日 星期五
XML特殊字元處理 (C++)
在使用XML當作資料傳遞時,最常犯的錯就是自己產生的XML內容包含了一些特殊字元,導致無法正常顯示XML。特殊字元包括:
'
"
&
<
>
當遇到以上幾個字元時,必須做以下轉換:
'
"
&
<
>
以C++寫法為例,輸入一個string型態的字串,回傳已經做好特殊字元取代的字串
std::string XmlEscape(const std::string &rstrString)
{
ostringstream ossEscapeString;
unsigned char ch;
for(string::const_iterator iter = rstrString.begin(); iter != rstrString.end(); iter++ )
{
ch = static_cast(*iter);
switch(ch)
{
case '&':
ossEscapeString << "&";
break;
case '<':
ossEscapeString << "<";
break;
case '>':
ossEscapeString << ">";
break;
case '"':
ossEscapeString << """;
break;
case '\'':
ossEscapeString << "'";
break;
default:
ossEscapeString << ch;
break;
}
}
return ossEscapeString.str();
}
'
"
&
<
>
當遇到以上幾個字元時,必須做以下轉換:
'
"
&
<
>
以C++寫法為例,輸入一個string型態的字串,回傳已經做好特殊字元取代的字串
std::string XmlEscape(const std::string &rstrString)
{
ostringstream ossEscapeString;
unsigned char ch;
for(string::const_iterator iter = rstrString.begin(); iter != rstrString.end(); iter++ )
{
ch = static_cast
switch(ch)
{
case '&':
ossEscapeString << "&";
break;
case '<':
ossEscapeString << "<";
break;
case '>':
ossEscapeString << ">";
break;
case '"':
ossEscapeString << """;
break;
case '\'':
ossEscapeString << "'";
break;
default:
ossEscapeString << ch;
break;
}
}
return ossEscapeString.str();
}
2013年6月15日 星期六
2013年1月1日 星期二
Welcome 2013
今年的跨年計劃真的是捉摸不定,從一開始說好要到桃園跨年的,後來又改到社子島,但最終的跨年地點是選在麥帥一橋上,雖說變來變去,但我就是喜歡這樣隨性自在的感覺。
這次跨年的成員有阿佑、小武、阿銓以及我。晚上七點集合在阿佑家,同樣還是沒計劃要吃啥,最後經過一家薑母鴨店,我們就停了下來,冷冷的冬天最適合這個了。
吃飽後,我們還是照原先計劃前往社子島出發,小武果然沒騙人,確實是看的到101,只是有點遠,而且時間還很.......早,所以在社子島待不到幾十分鐘,我們就驅車延著堤防往101方向前近。騎著騎著,最終我們竟從人煙稀少的社子島,現身在人山人海的饒河街夜市。不過來到饒河街,我印象中那裡有個彩虹橋可以看到101,只不過如預期,就是人山人海,所以我們只好繼續往前走,最後決定的位置就是麥帥一橋了。
訂閱:
文章 (Atom)