zoukankan      html  css  js  c++  java
  • react native mapbox 截图压缩(@react-native-mapbox-glmaps)

    修改map.takeSnap(false)方法源码,修改前卫星地图的截图文件大小3.6M修改后截图压缩到130k

    android :
    源码路径 node_modules@react-native-mapbox-glmapsandroid ctmglsrcmainjavacommapbox ctmglutilsBitmapUtils.java

    public static String createBase64(Bitmap bitmap) {
        ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
        //bitmap.compress(Bitmap.CompressFormat.PNG, 100, outputStream);  
        bitmap.compress(Bitmap.CompressFormat.JPEG, 50, outputStream);//文件类型修改成JPEG 质量修改成50
        byte[] bitmapBytes = outputStream.toByteArray();
        closeSnapshotOutputStream(outputStream);
        //String base64Prefix = "data:image/png;base64,";
        String base64Prefix = "data:image/jpeg;base64,";//文件类型修改成JPEG 
        return base64Prefix + Base64.encodeToString(bitmapBytes, Base64.NO_WRAP);
        
    

    ios:
    源码路径 node_modules@react-native-mapbox-glmapsiosRCTMGLRNMBImageUtils.m

    + (NSString *)createBase64:(UIImage *)image
    {
        //NSData *data = UIImagePNGRepresentation(image);
          NSData *data = UIImageJPEGRepresentation(image,0.5);//文件类型修改成JPEG 质量修改成0.5
        //return [NSString stringWithFormat:@"%@%@",  @"data:image/png;base64,", [data base64EncodedStringWithOptions:NSDataBase64EncodingEndLineWithCarriageReturn]];
          return [NSString stringWithFormat:@"%@%@",  @"data:image/jpeg;base64,", [data base64EncodedStringWithOptions:NSDataBase64EncodingEndLineWithCarriageReturn]];//文件类型修改成JPEG
    }
    
  • 相关阅读:
    【笔记】:sort排序大法
    【模块】:torndb
    【模块】:CSV文件 数据可视化
    【模块】:Pygal 绘制直方图
    【模块】:matplotlib 绘制折线图
    【Django】:重构Admin
    【数据结构】:基础
    【数据结构】:排序练习
    【数据结构】:算法(二)
    【数据结构】:算法(一)
  • 原文地址:https://www.cnblogs.com/shuoli/p/14137403.html
Copyright © 2011-2022 走看看