Android 馬賽克(Mosaics)效果


layout: post
title: Android 馬賽克(Mosaics)效果
date: 2015-12-13
categories: blog
tags: [技術(shù),Android]
category: Android
description: 使用兩種不同的方案實現(xiàn)Android平臺下的馬賽克效果


本文首發(fā)于KuTear,轉(zhuǎn)載請注明
代碼地址
GitHub

前幾天看見開源項目[ExplosionField]效果好贊,看了下代碼,他的實現(xiàn)大致就是在原界面之上覆蓋一成自定義的View,獲取到點擊的那個View的內(nèi)容(Bitmap),然后在覆蓋的那個自定義View的特定位置畫出來,之后就是對這個Bitmap做一些列拆分,變化重繪的過程.在這里根據(jù)他對bitmap的拆分,感覺用來實現(xiàn)Bitmap的效果也是不錯的,就試著做一做.

在這里介紹使用兩種方式實現(xiàn)馬賽克效果.開始之前先看看效果


Screenshot from 2015-12-13 19-09-50.png
Screenshot from 2015-12-13 19-09-50.png

感覺還可以

  1. 直接繪制

    public static Bitmap getMosaicsBitmap(Bitmap bmp, double precent) {
    long start = System.currentTimeMillis();
    int bmpW = bmp.getWidth();
    int bmpH = bmp.getHeight();
    Bitmap resultBmp = Bitmap.createBitmap(bmpW, bmpH, Bitmap.Config.ARGB_8888);
    Canvas canvas = new Canvas(resultBmp);
    Paint paint = new Paint();
    double unit;
    if (precent == 0) {
        unit = bmpW;
    } else {
        unit = 1 / precent;
    }
    double resultBmpW = bmpW / unit;
    double resultBmpH = bmpH / unit;
    for (int i = 0; i < resultBmpH; i++) {
        for (int j = 0; j < resultBmpW; j++) {
            int pickPointX = (int) (unit * (j + 0.5));
            int pickPointY = (int) (unit * (i + 0.5));
            int color;
            if (pickPointX >= bmpW || pickPointY >= bmpH) {
                color = bmp.getPixel(bmpW / 2, bmpH / 2);
            } else {
                color = bmp.getPixel(pickPointX, pickPointY);
            }
            paint.setColor(color);
            canvas.drawRect((int) (unit * j), (int) (unit * i), (int) (unit * (j + 1)), (int) (unit * (i + 1)), paint);
        }
    }
    canvas.setBitmap(null);
    long end = System.currentTimeMillis();
    Log.v(TAG, "DrawTime:" + (end - start));
    return resultBmp;
    } 
    
  2. 修改像素點

    public static Bitmap getMosaicsBitmaps(Bitmap bmp, double precent) {
    long start = System.currentTimeMillis();
    int bmpW = bmp.getWidth();
    int bmpH = bmp.getHeight();
    int[] pixels = new int[bmpH * bmpW];
    bmp.getPixels(pixels, 0, bmpW, 0, 0, bmpW, bmpH);
    int raw = (int) (bmpW * precent);
    int unit;
    if (raw == 0) {
        unit = bmpW;
    } else {
        unit = bmpW / raw; //原來的unit*unit像素點合成一個,使用原左上角的值
    }
    if (unit >= bmpW || unit >= bmpH) {
        return getMosaicsBitmap(bmp, precent);
    }
    for (int i = 0; i < bmpH; ) {
        for (int j = 0; j < bmpW; ) {
            int leftTopPoint = i * bmpW + j;
            for (int k = 0; k < unit; k++) {
                for (int m = 0; m < unit; m++) {
                    int point = (i + k) * bmpW + (j + m);
                    if (point < pixels.length) {
                        pixels[point] = pixels[leftTopPoint];
                    }
                }
            }
            j += unit;
        }
        i += unit;
    }
    long end = System.currentTimeMillis();
    Log.v(TAG, "DrawTime:" + (end - start));
    return Bitmap.createBitmap(pixels, bmpW, bmpH, Bitmap.Config.ARGB_8888);
}

從效率上來看,第二中方式效率會高10倍,只要是因為第一種方式繪制的次數(shù)太多了,而繪制是比較費(fèi)時間的.這里,特別提示,不要在大量的循環(huán)語句內(nèi)部使用Log.v(...),這是一個很耗時間的操作.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末压状,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子种冬,更是在濱河造成了極大的恐慌,老刑警劉巖莺匠,帶你破解...
    沈念sama閱讀 222,252評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件十兢,死亡現(xiàn)場離奇詭異纪挎,居然都是意外死亡跟匆,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評論 3 399
  • 文/潘曉璐 我一進(jìn)店門烤蜕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人虎忌,你說我怎么就攤上這事橱鹏。” “怎么了挑围?”我有些...
    開封第一講書人閱讀 168,814評論 0 361
  • 文/不壞的土叔 我叫張陵糖荒,是天一觀的道長。 經(jīng)常有香客問我蜘矢,道長综看,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,869評論 1 299
  • 正文 為了忘掉前任珍昨,我火速辦了婚禮镣典,結(jié)果婚禮上唾琼,老公的妹妹穿的比我還像新娘。我一直安慰自己锡溯,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 68,888評論 6 398
  • 文/花漫 我一把揭開白布芜茵。 她就那樣靜靜地躺著九串,像睡著了一般。 火紅的嫁衣襯著肌膚如雪猪钮。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,475評論 1 312
  • 那天肘交,我揣著相機(jī)與錄音涯呻,去河邊找鬼腻要。 笑死,一個胖子當(dāng)著我的面吹牛闯第,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播咳短,決...
    沈念sama閱讀 41,010評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼填帽,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了咙好?” 一聲冷哼從身側(cè)響起篡腌,我...
    開封第一講書人閱讀 39,924評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎勾效,沒想到半個月后嘹悼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,469評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡层宫,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,552評論 3 342
  • 正文 我和宋清朗相戀三年杨伙,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片萌腿。...
    茶點故事閱讀 40,680評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖毁菱,靈堂內(nèi)的尸體忽然破棺而出米死,到底是詐尸還是另有隱情,我是刑警寧澤贮庞,帶...
    沈念sama閱讀 36,362評論 5 351
  • 正文 年R本政府宣布峦筒,位于F島的核電站,受9級特大地震影響窗慎,放射性物質(zhì)發(fā)生泄漏物喷。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 42,037評論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望脯丝。 院中可真熱鬧,春花似錦伏伐、人聲如沸宠进。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽材蹬。三九已至,卻和暖如春吝镣,著一層夾襖步出監(jiān)牢的瞬間堤器,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評論 1 274
  • 我被黑心中介騙來泰國打工末贾, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留闸溃,地道東北人。 一個月前我還...
    沈念sama閱讀 49,099評論 3 378
  • 正文 我出身青樓拱撵,卻偏偏與公主長得像辉川,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子拴测,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,691評論 2 361

推薦閱讀更多精彩內(nèi)容