日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > Android >内容正文

Android

【Android 安装包优化】WebP 应用 ( Android 中使用 libwebp.so 库编码 WebP 图片 )

發布時間:2025/6/17 Android 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【Android 安装包优化】WebP 应用 ( Android 中使用 libwebp.so 库编码 WebP 图片 ) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

  • 一、Android 中使用 libwebp.so 庫編碼 WebP 圖片
  • 二、完整代碼示例
  • 三、參考資料





一、Android 中使用 libwebp.so 庫編碼 WebP 圖片



libwebp.jar 中編碼相關的的方法如下 : libwebpJNI 是 Java 層調用 libwebp.so 動態庫的入口類 ;

public static byte[] WebPEncodeRGB(byte[] var0, int var1, int var2, int var3, float var4) {return wrap_WebPEncodeRGB(var0, 1, 1, outputSize, var1, var2, var3, var4);}public static byte[] WebPEncodeRGBA(byte[] var0, int var1, int var2, int var3, float var4) {return wrap_WebPEncodeRGBA(var0, 1, 1, outputSize, var1, var2, var3, var4);}public static byte[] WebPEncodeBGR(byte[] var0, int var1, int var2, int var3, float var4) {return wrap_WebPEncodeBGR(var0, 1, 1, outputSize, var1, var2, var3, var4);}public static byte[] WebPEncodeBGRA(byte[] var0, int var1, int var2, int var3, float var4) {return wrap_WebPEncodeBGRA(var0, 1, 1, outputSize, var1, var2, var3, var4);}public static byte[] WebPEncodeLosslessRGB(byte[] var0, int var1, int var2, int var3) {return wrap_WebPEncodeLosslessRGB(var0, 1, 1, outputSize, var1, var2, var3);}public static byte[] WebPEncodeLosslessRGBA(byte[] var0, int var1, int var2, int var3) {return wrap_WebPEncodeLosslessRGBA(var0, 1, 1, outputSize, var1, var2, var3);}public static byte[] WebPEncodeLosslessBGR(byte[] var0, int var1, int var2, int var3) {return wrap_WebPEncodeLosslessBGR(var0, 1, 1, outputSize, var1, var2, var3);}public static byte[] WebPEncodeLosslessBGRA(byte[] var0, int var1, int var2, int var3) {return wrap_WebPEncodeLosslessBGRA(var0, 1, 1, outputSize, var1, var2, var3);}

在本博客示例中 , 使用的是 WebPEncodeRGBA 方法 , 傳入的 555 個參數作用 :

  • byte[] var0 : 位圖字節數據 ;
  • int var1 : 位圖寬度 , 單位像素 ;
  • int var2 : 位圖高度 , 單位像素 ;
  • int var3 : 位圖每行的數據字節數 ;
  • float var4 : 壓縮 WebP 圖片質量 , 推薦 75 ;
public static byte[] WebPEncodeRGBA(byte[] var0, int var1, int var2, int var3, float var4) {return wrap_WebPEncodeRGBA(var0, 1, 1, outputSize, var1, var2, var3, var4);}

使用 libwebp.so 庫編碼 WebP 圖片 : 讀取 R.mipmap.icon_png 資源文件 , 使用 libwebp 編碼為 WebP 圖片 , 保存到本地文件中 ;

fun libwebpEncode(){var webPStart = System.currentTimeMillis()// 讀取一張本地圖片var bitmap = BitmapFactory.decodeResource(resources, R.mipmap.icon_png)// 獲取位圖寬高var width = bitmap.widthvar height = bitmap.height// 申請一個 Byte 緩沖區var byteBuffer: ByteBuffer = ByteBuffer.allocate(bitmap.byteCount)// 將 位圖 數據拷貝到 Byte 緩沖區中bitmap.copyPixelsToBuffer(byteBuffer)// 使用 libwebp.so 進行 WebP 格式編碼var data: ByteArray = libwebp.WebPEncodeRGBA(byteBuffer.array(), // 位圖數據width, // 位圖寬度height, // 位圖高度width * 4, // 位圖每行數據75F // 圖像質量)// 將數據寫出到文件中var fos = FileOutputStream("${cacheDir}/icon_webp2.webp")fos.write(data)fos.close()Log.e(TAG, "使用 libwebp.so 庫編碼 WebP 格式圖片時間 : ${System.currentTimeMillis() - webPStart} ms , " +"輸出文件 : ${cacheDir}/icon_webp2.webp")}



二、完整代碼示例



調用 libweb.jar 中的 libwebp.WebPEncodeRGBA 函數 , 進行 WebP 圖片的編碼操作 ;

同時測試編碼的時長 ;

package kim.hsl.webpimport android.graphics.Bitmap import android.graphics.BitmapFactory import android.os.Bundle import android.util.Log import androidx.appcompat.app.AppCompatActivity import com.google.webp.libwebp import java.io.FileOutputStream import java.nio.ByteBufferclass MainActivity : AppCompatActivity() {companion object{val TAG = "MainActivity"init {System.loadLibrary("webp")}}override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContentView(R.layout.activity_main)Log.e(TAG, "libwebp 函數庫版本 : ${libwebp.WebPGetDecoderVersion()}")// 測試 WebP 解碼速度decodeWebP()// 測試 WebP 編碼速度encodeWebP()// 使用 libwebp 庫編碼 WebP 圖片libwebpEncode()}fun libwebpEncode(){var webPStart = System.currentTimeMillis()// 讀取一張本地圖片var bitmap = BitmapFactory.decodeResource(resources, R.mipmap.icon_png)// 獲取位圖寬高var width = bitmap.widthvar height = bitmap.height// 申請一個 Byte 緩沖區var byteBuffer: ByteBuffer = ByteBuffer.allocate(bitmap.byteCount)// 將 位圖 數據拷貝到 Byte 緩沖區中bitmap.copyPixelsToBuffer(byteBuffer)// 使用 libwebp.so 進行 WebP 格式編碼var data: ByteArray = libwebp.WebPEncodeRGBA(byteBuffer.array(), // 位圖數據width, // 位圖寬度height, // 位圖高度width * 4, // 位圖每行數據75F // 圖像質量)// 將數據寫出到文件中var fos = FileOutputStream("${cacheDir}/icon_webp2.webp")fos.write(data)fos.close()Log.e(TAG, "使用 libwebp.so 庫編碼 WebP 格式圖片時間 : ${System.currentTimeMillis() - webPStart} ms , " +"輸出文件 : ${cacheDir}/icon_webp2.webp")}fun encodeWebP(){// 讀取一張本地圖片var bitmap = BitmapFactory.decodeResource(resources, R.mipmap.icon_png)var pngStart = System.currentTimeMillis()var fos = FileOutputStream("${cacheDir}/icon_png.png")bitmap.compress(Bitmap.CompressFormat.PNG, 75, fos)fos.close()Log.e(TAG, "編碼 png 格式圖片時間 : ${System.currentTimeMillis() - pngStart} ms , " +"輸出文件 : ${cacheDir}/icon_png.png")var webPStart = System.currentTimeMillis()fos = FileOutputStream("${cacheDir}/icon_webp.webp")bitmap.compress(Bitmap.CompressFormat.WEBP, 75, fos)fos.close()Log.e(TAG, "編碼 WebP 格式圖片時間 : ${System.currentTimeMillis() - webPStart} ms , " +"輸出文件 : ${cacheDir}/icon_webp.webp")}fun decodeWebP(){var pngStart = System.currentTimeMillis()BitmapFactory.decodeResource(resources, R.mipmap.icon_png)Log.e(TAG, "解碼 png 格式圖片時間 : ${System.currentTimeMillis() - pngStart} ")var webPStart = System.currentTimeMillis()BitmapFactory.decodeResource(resources, R.mipmap.icon_webp)Log.e(TAG, "解碼 WebP 格式圖片時間 : ${System.currentTimeMillis() - webPStart} ")} }

執行結果 :

2021-04-25 13:36:57.719 31716-31757/kim.hsl.webp E/libc: Access denied finding property "vendor.debug.egl.profiler" 2021-04-25 13:36:57.732 31716-31716/kim.hsl.webp E/MainActivity: 動態庫加載完成 2021-04-25 13:36:57.895 31716-31716/kim.hsl.webp E/MainActivity: 1537 2021-04-25 13:36:58.174 31716-31716/kim.hsl.webp E/MainActivity: 解碼 png 格式圖片時間 : 278 2021-04-25 13:36:58.374 31716-31716/kim.hsl.webp E/MainActivity: 解碼 WebP 格式圖片時間 : 200 2021-04-25 13:37:01.053 31716-31716/kim.hsl.webp E/MainActivity: 編碼 png 格式圖片時間 : 2410 ms , 輸出文件 : /data/user/0/kim.hsl.webp/cache/icon_png.png 2021-04-25 13:37:04.130 31716-31716/kim.hsl.webp E/MainActivity: 編碼 WebP 格式圖片時間 : 3077 ms , 輸出文件 : /data/user/0/kim.hsl.webp/cache/icon_webp.webp 2021-04-25 13:37:07.512 31716-31716/kim.hsl.webp E/MainActivity: 使用 libwebp.so 庫編碼 WebP 格式圖片時間 : 3382 ms , 輸出文件 : /data/user/0/kim.hsl.webp/cache/icon_webp2.webp

使用 libwebp.so 庫編碼 WebP 圖片的速度要 低于 Android 本身自帶 API 的速度 , 由于是為了適配低版本系統 , 聊勝于無 ;





三、參考資料



參考文檔 :

  • 創建 WebP 圖片 : https://developer.android.google.cn/studio/write/convert-webp

  • Android 中支持的媒體格式 : https://developer.android.google.cn/guide/topics/media/media-formats

  • isparta 工具官網 : http://isparta.github.io/

  • isparta 工具 GitHub 地址 : https://github.com/iSparta/iSparta

  • Google 提供的 WebP 工具 ( 國內不能訪問 ) : https://developers.google.com/speed/webp/download

  • Google WebP 主頁 : https://developers.google.com/speed/webp

  • WebP 相關工具下載頁 : https://developers.google.com/speed/webp/download

  • WebP工具和函數庫使用文檔 : https://developers.google.com/speed/webp/docs/using


Android NDK 編譯構建腳本參考文檔 :

  • ndk-build 腳本 : https://developer.android.google.cn/ndk/guides/ndk-build
  • Android.mk 構建腳本 : https://developer.android.google.cn/ndk/guides/android_mk
  • Application.mk 構建腳本 : https://developer.android.google.cn/ndk/guides/application_mk

博客資源 :

  • iSparta 工具 : https://download.csdn.net/download/han1202012/17496041
  • Google libwebp 庫 : https://download.csdn.net/download/han1202012/17498155
  • libwebp 源碼及編譯相關資源 : https://download.csdn.net/download/han1202012/17826464 ( 源碼 , 編譯腳本 , 編譯結果 so 庫 )

博客源碼 :

  • GitHub 地址 : https://github.com/han1202012/Webp
  • CSDN 下載地址 : https://download.csdn.net/download/han1202012/18125733
《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀

總結

以上是生活随笔為你收集整理的【Android 安装包优化】WebP 应用 ( Android 中使用 libwebp.so 库编码 WebP 图片 )的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。