Android分享海报如何添加底部二维码

需求:

1.界面显示“正常界面内容”,无“二维码”模块,切记,仅仅只会显示“正常界面显示内容”

2.当点击分享时,分享一张长图,长图包含“正常显示内容”+“二维码”

3.实现方式

① 当用户点击分享,此时在保存图片到本地的步骤设置“二维码”模块显示,等保存成功后隐藏,

这样通过scrollview计算截取长图(切记需要加个几百毫秒延时,否则会出现截图包含不了二维码计算),可将整张图截取完全,最后弹出分享框分享各渠道。

    /**
     * 截取scrollview的屏幕
     *
     * @param scrollView 滑动控件
     * @return bitmap图片
     */
    public Bitmap getBitmapByView(NestedScrollView scrollView) {
        int h = 0;
        Bitmap bitmap;
        // 获取scrollview实际高度
        for (int i = 0; i < scrollView.getChildCount(); i++) {
            h += scrollView.getChildAt(i).getHeight();//获取scrollView的屏幕高度
            scrollView.getChildAt(i).setBackgroundColor(
                    Color.parseColor("#ffffff"));
        }
        //如果传的参数不是NestedScrollView,则不需要循环遍历高度
//        h += scrollView.getHeight();//获取scrollView的屏幕高度
//        scrollView.setBackgroundColor(
//                    Color.parseColor("#ffffff"));
        // 创建对应大小的bitmap
        bitmap = Bitmap.createBitmap(scrollView.getWidth(), h,
                Bitmap.Config.RGB_565);
        final Canvas canvas = new Canvas(bitmap);//把创建的bitmap放到画布中去
        scrollView.draw(canvas);//绘制canvas 画布
        return bitmap;
    }

②将两个布局生成bitmap,然后进行合成(当前的没有具体试过,

具体链接:https://blog.csdn.net/jabony/article/details/104375486
private Bitmap mergeBitmap(Bitmap firstBitmap, Bitmap secondBitmap) {
        int w1 = firstBitmap.getWidth();
        int h1 = firstBitmap.getHeight();
        int w2 = secondBitmap.getWidth();
        int h2 = secondBitmap.getHeight();
        int space = 20;
        Bitmap bitmap = Bitmap.createBitmap(w1, h1 + h2 + 40,
                firstBitmap.getConfig());
        Canvas canvas = new Canvas(bitmap);
        canvas.drawRGB(255, 255, 255);
        canvas.drawBitmap(firstBitmap, new Matrix(), null);
        int left = w1 - w2 > 0 ? ((w1 - w2) / 2) : 0;
        canvas.drawBitmap(secondBitmap, left, h1 + 20, null);
        return bitmap;
    }

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是Android生成带logo的二维码的步骤: 1. 引入依赖坐标 在项目的build.gradle文件中,添加以下依赖坐标: ```groovy implementation 'com.google.zxing:core:3.4.0' implementation 'com.journeyapps:zxing-android-embedded:3.6.0' ``` 2. 简单二维码实现 使用ZXing库生成简单的二维码,可以参考以下代码: ```java import android.graphics.Bitmap; import android.graphics.Color; import android.os.Bundle; import android.widget.ImageView; import androidx.appcompat.app.AppCompatActivity; import com.google.zxing.BarcodeFormat; import com.google.zxing.WriterException; import com.google.zxing.common.BitMatrix; import com.google.zxing.qrcode.QRCodeWriter; public class MainActivity extends AppCompatActivity { private ImageView qrCodeImageView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); qrCodeImageView = findViewById(R.id.qr_code_image_view); String content = "https://www.example.com"; // 二维码内容 try { // 设置二维码的宽高 int width = 400; int height = 400; // 创建QRCodeWriter对象 QRCodeWriter writer = new QRCodeWriter(); // 使用QRCodeWriter对象生成BitMatrix对象 BitMatrix bitMatrix = writer.encode(content, BarcodeFormat.QR_CODE, width, height); // 创建一个空的Bitmap对象 Bitmap bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.RGB_565); // 遍历BitMatrix对象,设置Bitmap对象的像素值 for (int x = 0; x < width; x++) { for (int y = 0; y < height; y++) { bitmap.setPixel(x, y, bitMatrix.get(x, y) ? Color.BLACK : Color.WHITE); } } // 设置ImageView显示二维码图片 qrCodeImageView.setImageBitmap(bitmap); } catch (WriterException e) { e.printStackTrace(); } } } ``` 3. 带logo的二维码实现 为了生成带logo的二维码,我们可以在生成二维码的基础上,将logo图片合并到二维码中。可以参考以下代码: ```java import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.os.Bundle; import android.widget.ImageView; import androidx.appcompat.app.AppCompatActivity; import com.google.zxing.BarcodeFormat; import com.google.zxing.WriterException; import com.google.zxing.common.BitMatrix; import com.google.zxing.qrcode.QRCodeWriter; public class MainActivity extends AppCompatActivity { private ImageView qrCodeImageView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); qrCodeImageView = findViewById(R.id.qr_code_image_view); String content = "https://www.example.com"; // 二维码内容 int logoResId = R.drawable.logo; // logo图片资源ID try { // 设置二维码的宽高 int width = 400; int height = 400; // 创建QRCodeWriter对象 QRCodeWriter writer = new QRCodeWriter(); // 使用QRCodeWriter对象生成BitMatrix对象 BitMatrix bitMatrix = writer.encode(content, BarcodeFormat.QR_CODE, width, height); // 创建一个空的Bitmap对象 Bitmap bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.RGB_565); // 遍历BitMatrix对象,设置Bitmap对象的像素值 for (int x = 0; x < width; x++) { for (int y = 0; y < height; y++) { bitmap.setPixel(x, y, bitMatrix.get(x, y) ? Color.BLACK : Color.WHITE); } } // 加载logo图片 Bitmap logoBitmap = BitmapFactory.decodeResource(getResources(), logoResId); // 创建一个新的Bitmap对象,用于合并二维码和logo图片 Bitmap resultBitmap = Bitmap.createBitmap(width, height, Bitmap.Config.RGB_565); // 创建一个Canvas对象,用于绘制二维码和logo图片 Canvas canvas = new Canvas(resultBitmap); // 绘制二维码 canvas.drawBitmap(bitmap, 0, 0, null); // 计算logo图片的宽高 int logoWidth = width / 4; int logoHeight = height / 4; // 设置logo图片的绘制区域 int logoLeft = (width - logoWidth) / 2; int logoTop = (height - logoHeight) / 2; int logoRight = logoLeft + logoWidth; int logoBottom = logoTop + logoHeight; // 创建一个Paint对象,用于设置logo图片的抗锯齿和透明度 Paint paint = new Paint(); paint.setAntiAlias(true); paint.setAlpha(255); // 绘制logo图片 canvas.drawBitmap(logoBitmap, null, new Rect(logoLeft, logoTop, logoRight, logoBottom), paint); // 设置ImageView显示带logo的二维码图片 qrCodeImageView.setImageBitmap(resultBitmap); } catch (WriterException e) { e.printStackTrace(); } } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值