在編程中有時候需要對圖片做特殊的處理,比如將圖片做出黑白的,或者老照片的效果,有時候還要對圖片進行變換,以拉伸,扭曲等等。
這些效果在android中有很好的支持,通過顏色矩陣(ColorMatrix)和坐標變換矩陣(Matrix)可以完美的做出上面的所說的效果。
下面將分別介紹這兩個矩陣的用法和相關的函數(shù)。
顏色矩陣
android中可以通過顏色矩陣(ColorMatrix類)方面的操作顏色,顏色矩陣是一個5x4 的矩陣(如圖1.1)
可以用來方面的修改圖片中RGBA各分量的值,顏色矩陣以一維數(shù)組的方式存儲如下:
[ a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s, t ]
他通過RGBA四個通道來直接操作對應顏色,如果會使用Photoshop就會知道有時處理圖片通過控制RGBA各顏色通道來做出特殊的效果。
這個矩陣對顏色的作用計算方式如1.3示:

矩陣的運算規(guī)則是矩陣A的一行乘以矩陣C的一列作為矩陣R的一行,
C矩陣是圖片中包含的ARGB信息,R矩陣是用顏色矩陣應用于C之后的新的顏色分量,運算結果如下:
R' = a*R + b*G + c*B + d*A + e;
G' = f*R + g*G + h*B + i*A + j;
B' = k*R + l*G + m*B + n*A + o;
A' = p*R + q*G + r*B + s*A + t;
顏色矩陣并不是看上去那么深奧,其實需要使用的參數(shù)很少,而且很有規(guī)律第一行決定紅色第二行決定綠色
第三行決定藍色,第四行決定了透明度,第五列是顏色的偏移量。下面是一個實際中使用的顏色矩陣。

如果把這個矩陣作用于各顏色分量的話,R=A*C,計算后會發(fā)現(xiàn),各個顏色分量實際上沒有任何的改變(R'=R G'=G B'=B A'=A)。

圖1.5所示矩陣計算后會發(fā)現(xiàn)紅色分量增加100,綠色分量增加100,
這樣的效果就是圖片偏黃,因為紅色和綠色混合后得到黃色,黃色增加了100,圖片當然就偏黃了。

改變各顏色分量不僅可以通過修改第5列的顏色偏移量也可如上面矩陣所示將對應的顏色值乘以一個倍數(shù),直接放大。
上圖1.6是將綠色分量乘以2變?yōu)樵瓉淼?倍。相信讀者至此已經(jīng)明白了如何通過顏色矩陣來改變各顏色分量。
下面編寫一段代碼來,通過調(diào)整顏色矩陣來獲得不同的顏色效果
posted @
2011-10-25 11:05 小果子 閱讀(248) |
評論 (0) |
編輯 收藏
之前一直搞不很明白 AndroidManifest.xml 中 activity 標簽下的 intent-filter 中 data 標簽的屬性含義,今天認真看了 Dev Guide,又在網(wǎng)上查詢了大量相關資料,現(xiàn)把 data 標簽中的屬性含義做一個總結。
一、定義
scheme, host, port, path, pathPrefix, pathPattern 是用來匹配 Intent 中的 Data Uri 的。具體規(guī)則如下:
scheme://host:port/path or pathPrefix or pathPattern
這里需要注意的是這里的 scheme 不是 schema,也許你記得 xmlns:android="http://schemas.android.com/apk/res/android" 這段聲明,你就會想起其中的 schema (至少我是這樣想到了...- -!),但這里的 scheme 不是 schema。雖然在寫 AndroidManifest.xml 的時候,有智能提示,但是希望大家還是能注意到。
上面那句最后的 “path or pathPrefix or pathPattern” 是指后面的 path 驗證可以使用 data 屬性中的 android:path、android:pathPrefix 或 pathPattern,你可以添加任意個 data 標簽,由于是 “or” ,因此,只要其中任意一個 data 匹配,系統(tǒng)就會選擇你的 Activity 啟動,當然,如果別的 Activity 也有相同的 data 標簽,系統(tǒng)就會給用戶彈出一個 Chooser Dialog。
mimeType 也是是用來匹配 Intent 的。比如,當你使用 Intent.setType("text/plain") ,那么系統(tǒng)將會匹配到所有注冊 android:mimeType="text/plain" 的 Activity,想獲取更多有關 mimeType 的知識請參考:【轉】備份:Android 常用 mimeType 表。
這里需要十分注意的是 Intent.setType(), Intent.setData,Intent.setDataAndType() 這三個方法!
- setType 調(diào)用后設置 mimeType,然后將 data 置為 null;
- setData 調(diào)用后設置 data,然后將 mimeType 置為 null;
- setDataAndType 調(diào)用后才會同時設置 data 與 mimeType。
另外需要注意的是,如果你在 data 標簽,既設置了 mimeType 又設置了 scheme 之內(nèi)的,那么你的 Intent 需要同時設置匹配的 data 與 mimeType 即調(diào)用 setDataAndType ,系統(tǒng)才能匹配到這個 Activity(即便你 mimeType 設置為 "*/*" 也是如此)。當然,如果你沒有設置 mimeType,那么調(diào)用 setData 進行匹配,如果你設置了任何的 mimeType 將不會匹配到該 Activity。
二、區(qū)別
這里主要說的區(qū)別是 path、pathPrefix、pathPattern 之間的區(qū)別
- path 用來匹配完整的路徑,如:http://example.com/blog/abc.html,這里將 path 設置為 /blog/abc.html 才能夠進行匹配;
- pathPrefix 用來匹配路徑的開頭部分,拿上面的 Uri 來說,這里將 pathPrefix 設置為 /blog 就能進行匹配了;
- pathPattern 用表達式來匹配整個路徑,這里需要說下匹配符號與轉義。
匹配符號:
- “*” 用來匹配0次或更多,如:“a*” 可以匹配“a”、“aa”、“aaa”...
- “.” 用來匹配任意字符,如:“.” 可以匹配“a”、“b”,“c”...
- 因此 “.*” 就是用來匹配任意字符0次或更多,如:“.*html” 可以匹配 “abchtml”、“chtml”,“html”,“sdf.html”...
轉義:
因為當讀取 Xml 的時候,“\” 是被當作轉義字符的(當它被用作 pathPattern 轉義之前),因此這里需要兩次轉義,讀取 Xml 是一次,在 pathPattern 中使用又是一次。如:“*” 這個字符就應該寫成 “\\*”,“\” 這個字符就應該寫成 “\\\\”。
三、一些例子
例子1:如果我們想要匹配 http 以 “.pdf” 結尾的路徑,使得別的程序想要打開網(wǎng)絡 pdf 時,用戶能夠可以選擇我們的程序進行下載查看。
我們可以將 scheme 設置為 “http”,pathPattern 設置為 “.*\\.pdf”,整個 intent-filter 設置為:

View Code
1 <intent-filter>
2 <action android:name="android.intent.action.VIEW"></action>
3 <category android:name="android.intent.category.DEFAULT"></category>
4 <data android:scheme="http" android:pathPattern=".*\\.pdf"></data>
5 </intent-filter>
如果你只想處理某個站點的 pdf,那么在 data 標簽里增加 android:host="yoursite.com" 則只會匹配 http://yoursite.com/xxx/xxx.pdf,但這不會匹配 www.yoursite.com,如果你也想匹配這個站點的話,你就需要再添加一個 data 標簽,除了 android:host 改為 “www.yoursite.com” 其他都一樣。
例子2:如果我們做的是一個IM應用,或是其他類似于微博之類的應用,如何讓別人通過 Intent 進行調(diào)用分享出現(xiàn)在選擇框里呢?
我們只用注冊 android.intent.action.SEND 與 mimeType 為 “text/plain” 或 “*/*” 就可以了,整個 intent-filter 設置為:

View Code
1 <intent-filter>
2 <action android:name="android.intent.action.SEND" />
3 <category android:name="android.intent.category.DEFAULT" />
4 <data mimeType="*/*" />
5 </intent-filter>
這里設置 category 的原因是,創(chuàng)建的 Intent 的實例默認 category 就包含了 Intent.CATEGORY_DEFAULT ,google 這樣做的原因是為了讓這個 Intent 始終有一個 category。
例子3:如果我們做的是一個音樂播放軟件,當文件瀏覽器打開某音樂文件的時候,使我們的應用能夠出現(xiàn)在選擇框里?
這類似于文件關聯(lián)了,其實做起來跟上面一樣,也很簡單,我們只用注冊 android.intent.action.VIEW 與 mimeType 為 “audio/*” 就可以了,整個 intent-filter 設置為:

View Code
1 <intent-filter>
2 <action android:name="android.intent.action.VIEW" />
3 <category android:name="android.intent.category.DEFAULT" />
4 <data android:mimeType="audio/*" />
5 </intent-filter>
參考:
posted @
2011-09-28 12:40 小果子 閱讀(1160) |
評論 (0) |
編輯 收藏
Content Provider這個東西在Android平臺上是最常用的共享數(shù)據(jù)的方法(似乎應用程序之間共享數(shù)據(jù)也只有這種方法吧,待求證)。雖然常用,但是這個東 西要理解透徹還是要先掌握一些基礎的。URI就是Content Provider(簡稱CP)的基礎。我們要標識一個CP,就必須用URI這個東東。這就類似于我們要通過網(wǎng)址來標識某個特定網(wǎng)站,實際上網(wǎng)址URL本身 就是一種URI。URI全稱Uniform Resource Identifier, 它包括了URL和URN。而關于它們的詳細解釋,有心的朋友可以參考RFC3896:http://tools.ietf.org/html /rfc3986。URI不僅可以標識特定CP,還可以標識CP中特定的數(shù)據(jù)庫表,就好像URL不僅可以標識特定網(wǎng)站,也可以標識這個網(wǎng)站某個特定網(wǎng)頁一 樣。實際上在Android平臺上URI的用途更廣泛一些,它還用于Intent中data的標識。
就Android平臺而言,URI主要分三個部分:scheme, authority and path。其中authority又分為host和port。格式如下:
scheme://host:port/path
舉個實際的例子:
content://com.example.project:200/folder/subfolder/etc
\---------/ \---------------------------/ \---/ \--------------------------/
scheme host port path
\--------------------------------/
authority
現(xiàn)在大家應該知道data flag中那些屬性的含義了吧,看下data flag
<data android:host="string"
android:mimeType="string"
android:path="string"
android:pathPattern="string"
android:pathPrefix="string"
android:port="string"
android:scheme="string" />
轉自:http://goldenrod-z4.iteye.com/blog/978194
posted @
2011-09-28 10:51 小果子 閱讀(1913) |
評論 (0) |
編輯 收藏

posted @
2011-09-28 10:05 小果子 閱讀(89) |
評論 (0) |
編輯 收藏
ImageView的屬性android:scaleType,即 ImageView.setScaleType(ImageView.ScaleType)。android:scaleType是控制圖片如何 resized/moved來匹對ImageView的size。ImageView.ScaleType /
android:scaleType值的意義區(qū)別:
CENTER /center 按圖片的原來size居中顯示,當圖片長/寬超過View的長/寬,則截 取圖片的居中部分顯示
CENTER_CROP / centerCrop 按比例擴大圖片的size居中顯示,使得圖片長 (寬)等于或大于View的長(寬)
CENTER_INSIDE / centerInside 將圖片的內(nèi)容完整居中顯示,通過按比例縮小 或原來的size使得圖片長/寬等于或小于View的長/寬
FIT_CENTER / fitCenter 把圖片按比例擴大/縮小到View的寬度,居中顯示
FIT_END / fitEnd 把 圖片按比例擴大/縮小到View的寬度,顯示在View的下部分位置
FIT_START / fitStart 把 圖片按比例擴大/縮小到View的寬度,顯示在View的上部分位置
FIT_XY / fitXY 把圖片 不按比例 擴大/縮小到View的大小顯示
posted @
2011-09-11 02:57 小果子 閱讀(319) |
評論 (0) |
編輯 收藏