欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

ndroidbitmapoutofmemory總結(jié)、心得

  • setImageBitmap或setImageResource或BitmapFactory.decodeResource來設(shè)置一張大圖,這些函數(shù)在完成decode后,最終都是通過java層的createBitmap來完成的,需要消耗更多的內(nèi)存。

    目前創(chuàng)新互聯(lián)建站已為成百上千的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)絡(luò)空間、綿陽服務(wù)器托管、企業(yè)網(wǎng)站設(shè)計(jì)、清河網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。

  • 改用先通過BitmapFactory.decodeStream方法,創(chuàng)建出一個(gè)bitmap,再將其設(shè)為ImageView的source

  • decodeStream最大的好處在于其直接調(diào)用JNI  的nativeDecodeAsset()來完成decode,無需再使用java層的createBitmap,從而節(jié)省了java層的空間

  • 如果在讀取時(shí)加上圖片的Config參數(shù),可以更有效減少加載的內(nèi)存,從而更有效避免out of memory的異常

  • 另外,decodeStream直接拿圖片來讀取字節(jié)碼,不會(huì)根據(jù)機(jī)器的各種分辨率來自動(dòng)適應(yīng),使用了decodeStream之后,需要配置相應(yīng)大小的圖片資源

  • 默認(rèn)情況下android進(jìn)程的內(nèi)存占用量為16M,因?yàn)閎itmap他除了java中持有數(shù)據(jù)外,底層C++的skia圖形庫(kù)還會(huì)持有一個(gè)SKBitmap對(duì)象,因此一般圖片占用內(nèi)存推薦大小應(yīng)該不超過8M


1、BitmapFactory.Options

  • inPreferredConfig 指定decode到內(nèi)存中,手機(jī)中所采用的編碼,可選值定義在Bitmap.Config中。缺省值是ARGB_8888??梢允笰LPHA_8、ARGB_444、ARGB_8888、RGB_565                                               bitmap占用內(nèi)存的算法如下:圖片的width*height*Config                                                                                                                                                                                                                                             如果config設(shè)置為ARGB_8888,那么上面的Config為4,也就是4個(gè)字節(jié)的意思。一張480*320的圖片占用的內(nèi)存就是480*320*4byte。 

  • inJustDecodeBounds 如果設(shè)置為true,并不會(huì)把圖像的數(shù)據(jù)完全解碼,亦即decodeXyz()返回值為null,但是Options的outAbc中解出了圖像的基本信息。

  • inSampleSize 設(shè)置decode時(shí)的縮放比例。

  • inPurgeable設(shè)為true的話表示使用BitmapFactory創(chuàng)建的Bitmap用于存儲(chǔ)Pixel的內(nèi)存空間在系統(tǒng)內(nèi)存不足時(shí)可以被回收,在應(yīng)用需要再次訪問bitmap的Pixel時(shí),系統(tǒng)會(huì)再次條用BitmapFactory decoder重新生成Bitmap的Pixel數(shù)組,為了能夠重新解碼圖像,bitmap要能夠訪問存儲(chǔ)bitmap的原始數(shù)據(jù)。在inPugeable為false時(shí)表示創(chuàng)建bitmap的pixel內(nèi)存空間不能被回收,這樣bitmapfactory在不停decodeByteArray創(chuàng)建新的Bitmap對(duì)象,不同設(shè)備的內(nèi)存不同,因此能夠同時(shí)創(chuàng)建的Bitmap個(gè)數(shù)可能有所不同,200個(gè)bitmap足以使大部分的設(shè)備出現(xiàn)OutOfMemory錯(cuò)誤。當(dāng)inPurgeable設(shè)為true時(shí),系統(tǒng)中內(nèi)存不足時(shí),可以回收部分bitmap占據(jù)的內(nèi)存空間,這時(shí)一般不會(huì)出現(xiàn)OutOfMemory錯(cuò)誤

  • inInputShareable是否深拷貝   




2、以最省內(nèi)存的方式讀取本地資源的圖片 

  1. BitmapFactory.Options opt = new BitmapFactory.Options();   

  2. opt.inPreferredConfig = Bitmap.Config.RGB_565;    

  3. opt.inPurgeable = true;   

  4. opt.inInputShareable = true;   

  5. //獲取資源圖片   

  6. InputStream is = context.getResources().openRawResource(resId);   

  7. BitmapFactory.decodeStream(is,null,opt);  


3、最近解決bitmap加載時(shí)out of memory的心得


游戲在加載背景圖片

       要么掛在BitmapFactory. decodeStreamassets .open(path));

    要么掛在surface = Bitmap.createBitmap (surface , 0, 0,
                surface .getWidth(), surface .getHeight(), matrix, true);

ndroid bitmap out of memory總結(jié)、心得第一次嘗試:看到圖片是png格式的,將圖片轉(zhuǎn)為jpg。圖片大小減少了不少。不過沒多大效果。  

        原因:雖然改為jpg,加載時(shí)存儲(chǔ)的方式會(huì)默認(rèn)為ARGB_565,本來是png為ARGB_8888,占用內(nèi)存會(huì)減少一半。不過開銷還是很大,用createBitmap放大時(shí),改方法是java層的實(shí)現(xiàn),效率太差。

ndroid bitmap out of memory總結(jié)、心得第二次嘗試:想到cocos2d-x的瓦片地圖,所以將背景圖片分割為9份(自己用ps切),有些效果,不會(huì)每次切換場(chǎng)景都會(huì)掛,但是很多的征戰(zhàn)地圖,沒全部切,所以當(dāng)進(jìn)入沒切的場(chǎng)景時(shí),還是會(huì)掛。

                   原因:沒有找到問題的源頭,變小圖了,加載時(shí)開銷的內(nèi)存確實(shí)減少不少。不過太多場(chǎng)景都去切不太實(shí)際,這樣程序改變很大??赡軙?huì)出現(xiàn)bug的風(fēng)險(xiǎn)。

ndroid bitmap out of memory總結(jié)、心得第三次嘗試:配置BitmapFactory.Config的屬性,使用(2)中的方式讀取圖片,省去createBitmap去放大圖片,使用兩套資源,在這些屏幕上用大圖。成功解決問題。

             原因:都用了BitmapFactory.decodeStream方法讀取圖片,改方法直接使用native方法,用c++實(shí)現(xiàn)。效率果然是高。雖然當(dāng)時(shí)還不知道這個(gè)原因。今天總結(jié)的時(shí)候通過源代碼才理解。

本文名稱:ndroidbitmapoutofmemory總結(jié)、心得
文章分享:http://aaarwkj.com/article44/gihdhe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、動(dòng)態(tài)網(wǎng)站、外貿(mào)網(wǎng)站建設(shè)、微信小程序、網(wǎng)站營(yíng)銷、企業(yè)網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計(jì)公司
国产av综合一区二区| 国产经典三级在线观看| 98热这里只有精品视频| 国产精品视频一区二区噜| 久久精品高潮999久久久| 国产999精品免费国产| 精品妇女一区二区三区| 日韩精品一区二区国产| 韩国av毛片在线播放| 黑人巨大精品欧美一区免| 国产精品伦一区二区三级| 日韩经典三级精品自拍| 久久久久久精品妇女| 久久这里只有精品伊人网| 韩国电视剧大全免费国语观看| 国产精品成久久久久三级| 精品久久久久久亚洲电影| 一区二区三区国产欧美日本 | 欧美亚洲尤物久久精品| 森泽佳奈在线视频观看| 亚洲欧美日韩成人在线| 深夜毛片一区二区三区| 日日狠狠久久偷偷综合色| 91精品国产欧美在线| 91人妻精品一区二区| 亚洲成色在线综合剧情网站| 92午夜福利精品视频| av天堂网站在线观看| 五月婷婷六月丁香在线观看| 亚洲性感美女男人的天堂| 亚洲性感人妻系列网站| 少妇太爽高潮在线播放| 国产v精品欧美精品v日韩| 日本少妇人妻中文字幕| 欧美一区二区国产日韩在线| 97全国免费观看视频| 麻豆资源视频在线观看| 国产丝袜肉丝在线播放| 国产精品久久乱码综合| 人成在线免费视频网站| 又黄又爽又刺激的性视频|