国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統(tǒng) > Android > 正文

android Bitmap圓角與倒影的具體實現(xiàn)代碼

2020-04-11 12:12:42
字體:
供稿:網(wǎng)友

[html]

復(fù)制代碼 代碼如下:

/**
     * 畫一個圓角圖
     * 
     * @param bitmap
     * @param roundPx
     * @return
     */
    public static Bitmap getRoundedCornerBitmap(Bitmap bitmap, float roundPx) {
        Bitmap output = Bitmap.createBitmap(bitmap.getWidth(),
                bitmap.getHeight(), Config.ARGB_8888);
        Canvas canvas = new Canvas(output);
        final int color = 0xff424242;
        final Paint paint = new Paint();
        final Rect rect = new Rect(0, 0, bitmap.getWidth(), bitmap.getHeight());
        final RectF rectF = new RectF(rect);
        paint.setAntiAlias(true);
        canvas.drawARGB(0, 0, 0, 0);
        paint.setColor(color);
        canvas.drawRoundRect(rectF, roundPx, roundPx, paint);
        paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));
        canvas.drawBitmap(bitmap, rect, rect, paint);
        return output;
    }

    /**
     * 創(chuàng)建倒影效果
     * 
     * @return
     */
    public boolean createReflectedImages() {
        // 倒影圖和原圖之間的距離
        final int reflectionGap = 4;
        int index = 0;
        for (GalleryWith3DData imageId : mImageIds) {
            // 返回原圖解碼之后的bitmap對象
            Bitmap originalImage = BitmapFactory.decodeResource(
                    mContext.getResources(), imageId.getInteger());
            int width = originalImage.getWidth();
            int height = originalImage.getHeight();
            // 創(chuàng)建矩陣對象
            Matrix matrix = new Matrix();
            // 指定矩陣(x軸不變,y軸相反)
            matrix.preScale(1, -1);
            // 將矩陣應(yīng)用到該原圖之中,返回一個寬度不變,高度為原圖1/2的倒影位圖
            Bitmap reflectionImage = Bitmap.createBitmap(originalImage, 0,
                    height / 2, width, height / 2, matrix, false);
            // 創(chuàng)建一個寬度不變,高度為原圖+倒影圖高度的位圖
            Bitmap bitmapWithReflection = Bitmap.createBitmap(width,
                    (height + height / 2), Config.ARGB_8888);
            // 將上面創(chuàng)建的位圖初始化到畫布
            Canvas canvas = new Canvas(bitmapWithReflection);
            canvas.drawBitmap(getRoundedCornerBitmap(originalImage, 20), 0, 0,
                    null);
            int len = imageId.getstr().length();
            double lenWeght = len * 50 * 0.9;
            int ban = width / 2;
            int ban1 = (int) (lenWeght / 2);
            int hua = ban - ban1;
            if (imageId.getFlagRecommend()) {
                canvas.rotate(30);
                canvas.drawText(mStrRecommend, hua - 20, 150,
                        createPaint(Color.RED));
                canvas.rotate(-30);
            }
            Paint deafaultPaint = new Paint();
            deafaultPaint.setAntiAlias(false);
            canvas.drawBitmap(getRoundedCornerBitmap(reflectionImage, 20), 0,
                    height + reflectionGap, null);
            Paint paint = new Paint();
            paint.setAntiAlias(false);
            /**
             * 參數(shù)一:為漸變起初點坐標(biāo)x位置, 參數(shù)二:為y軸位置, 參數(shù)三和四:分辨對應(yīng)漸變終點, 最后參數(shù)為平鋪方式,
             * 這里設(shè)置為鏡像Gradient是基于Shader類,所以我們通過Paint的setShader方法來設(shè)置這個漸變
             */
            LinearGradient shader = new LinearGradient(0,
                    originalImage.getHeight(), 0,
                    bitmapWithReflection.getHeight() + reflectionGap,
                    0x70ffffff, 0x00ffffff, TileMode.MIRROR);
            // 設(shè)置陰影
            paint.setShader(shader);
            paint.setXfermode(new PorterDuffXfermode(
                    android.graphics.PorterDuff.Mode.DST_IN));
            // 用已經(jīng)定義好的畫筆構(gòu)建一個矩形陰影漸變效果
            canvas.drawRect(0, height, width, bitmapWithReflection.getHeight() + reflectionGap, paint);
            canvas.drawText(imageId.getstr(), hua, 430,
                    createPaint(Color.WHITE));
            // 創(chuàng)建一個ImageView用來顯示已經(jīng)畫好的bitmapWithReflection
            ImageView imageView = new ImageView(mContext);
            imageView.setImageBitmap(bitmapWithReflection);
            // 設(shè)置imageView大小 ,也就是最終顯示的圖片大小
            imageView.setLayoutParams(new GalleryWith3D.LayoutParams(150, 250));
            // imageView.setScaleType(ScaleType.MATRIX);
            mImages[index++] = imageView;
        }
        return true;
    }

下面是效果圖:

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 铜山县| 龙海市| 堆龙德庆县| 大理市| 通海县| 宜君县| 海原县| 乐都县| 大足县| 海盐县| 泰顺县| 福海县| 江源县| 巴林右旗| 平罗县| 汉沽区| 钟山县| 五台县| 东辽县| 阿鲁科尔沁旗| 左权县| 黄大仙区| 扶风县| 九江县| 承德市| 水城县| 宁安市| 淳化县| 秀山| 金寨县| 寿阳县| 丽江市| 屏东县| 墨玉县| 哈密市| 抚州市| 潼关县| 宁晋县| 荥阳市| 临江市| 东明县|