Android使用WebView實現(xiàn)截圖分享功能
在APP項目的開發(fā)過程中,經(jīng)常會用到分享圖片的功能,有時候還需要根據(jù)當前用戶信息獲取指定的分享圖片,比如要求在用戶分享圖中顯示用戶名、Uid、用戶頭像等信息。想到的實現(xiàn)方法主要有兩點:
1.通過android SDK自帶的Canvas方法進行繪制。
2.通過webView實現(xiàn)客戶端與H5交互,然后將H5界面做截圖處理。
本文主要介紹第二種方式的實現(xiàn)過程,第一種方式的實現(xiàn)方法,后續(xù)有時間會在博客中做說明,下面開始本文內(nèi)容。
首先確定我們要實現(xiàn)的邏輯:
1.客戶端與H5的交互,客戶端將用戶信息(用戶名、Uid、用戶頭像等)發(fā)送給H5;
2.客戶端截取WebView功能的實現(xiàn);
3.分享功能的添加。
1.客戶端與H5交互
在界面布局中添加webView布局,對WebView布局進行初始化操作(此處需要網(wǎng)絡(luò)權(quán)限,不做單獨處理)
wv_imgweb = (WebView) findViewById(R.id.h5_wv_imgweb);
WebSettings webSettings = wv_imgweb.getSettings();
//此處可更加具體的H5界面功能進行相應(yīng)的WebSettings設(shè)置,本文只是演示基本效果
webSettings.setJavaScriptEnabled(true);
webSettings.setSupportZoom(false);
wv_imgweb.requestFocusFromTouch();
wv_imgweb.setDrawingCacheEnabled(true);
wv_imgweb.setVerticalScrollBarEnabled(false);
wv_imgweb.setHorizontalScrollBarEnabled(false);
wv_imgweb.setVerticalScrollbarOverlay(false);
wv_imgweb.setHorizontalScrollbarOverlay(false);
wv_imgweb.setWebViewClient(new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
@Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
//加載邏輯的處理
}
@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
super.onPageStarted(view, url, favicon);
//加載邏輯的處理
}
});
//添加用戶信息參數(shù),加載H5分享地址
wv_imgweb.loadUrl(h5_url);
2.截圖功能的實現(xiàn)
上文中的WebView頁面加載完成后,即可調(diào)用截圖功能,并將圖片保存在本地指定文件夾(此處需要存儲權(quán)限,不做單獨處理)
android中WebView可以通過多種方式實現(xiàn)截圖,下面分別做不同介紹:
2.1截取屏幕內(nèi)內(nèi)容
第一種方式是通過Bitmap bitmap = webView.getDrawingCache()截取屏幕內(nèi)顯示內(nèi)容,注意調(diào)用此方法setDrawingCacheEnabled(true)必須設(shè)置為true;
2.2截取整個WebView內(nèi)容
第二種方式是通過Picture snapShot = wv_imgweb.capturePicture()來截取整個WebView的內(nèi)容
Picture snapShot = wv_imgweb.capturePicture();
if (snapShot != null && snapShot.getWidth() > 0 && snapShot.getHeight() > 0) {
Bitmap bitmap = Bitmap.createBitmap(snapShot.getWidth(), snapShot.getHeight(), Bitmap.Config.ARGB_8888);//設(shè)置相應(yīng)的圖片質(zhì)量
Canvas canvas = new Canvas(bitmap);
snapShot.draw(canvas);
//將截取的圖片保存到本地
try {
File appFile = new File(Environment.getExternalStorageDirectory() + "/testpic/app");
if (!appFile.exists() && !appFile.isDirectory()) {
appFile.mkdirs();
}
String fileName = Environment.getExternalStorageDirectory().getPath() + "/testpic/app/share.jpg";
FileOutputStream fos = new FileOutputStream(fileName);
//設(shè)置保存本地圖片質(zhì)量
bitmap.compress(Bitmap.CompressFormat.JPEG, 70, fos);
fos.close();
} catch (Exception e) {
UIUtils.setLogInfo("eee", e.getMessage());
}
}
2.3截取整個WebView內(nèi)容
Android 為了提高各方面的繪制速度(如滾動操作),為每一個 View 建立一個緩存,使用 View.buildDrawingCache 為自己的 View 建立相應(yīng)的緩存, 這個 cache 就是一個 bitmap 對象。利用這個功能可以對整個屏幕視圖進行截屏并生成 Bitmap ,也可以獲得指定的 View 的 Bitmap 對象。
wv_imgweb.measure(View.MeasureSpec.makeMeasureSpec(View.MeasureSpec.UNSPECIFIED, View.MeasureSpec.UNSPECIFIED),
View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED));
wv_imgweb.layout(0, 0, wv_imgweb.getMeasuredWidth(), wv_imgweb.getMeasuredHeight());
wv_imgweb.setDrawingCacheEnabled(true);
wv_imgweb.buildDrawingCache();
Bitmap longImage = Bitmap.createBitmap(wv_imgweb.getMeasuredWidth(),
wv_imgweb.getMeasuredHeight(), Bitmap.Config.ARGB_8888);
Canvas canvas = new Canvas(longImage); // 畫布的寬高和 WebView 保持一致
Paint paint = new Paint();
canvas.drawBitmap(longImage, 0, wv_imgweb.getMeasuredHeight(), paint);
wv_imgweb.draw(canvas);
//將截取的圖片保存到本地
try {
File appFile = new File(Environment.getExternalStorageDirectory() + "/testpic/app");
if (!appFile.exists() && !appFile.isDirectory()) {
appFile.mkdirs();
}
String fileName = Environment.getExternalStorageDirectory().getPath() + "/testpic/app/share.jpg";
FileOutputStream fos = new FileOutputStream(fileName);
longImage.compress(Bitmap.CompressFormat.JPEG, 70, fos);
fos.close();
} catch (Exception e) {
UIUtils.setLogInfo("eee", e.getMessage());
}
問題:在5.0+上會發(fā)現(xiàn),截取的快照只顯示了webview中顯示出來的那部分,沒有顯示出來的部分是空白的。通過google找到了原因,在5.0+版本上,Android對webview做了優(yōu)化,旨在減少內(nèi)存占用以提高性能。因此在默認情況下會智能的繪制html中需要繪制的部分,其實就是當前屏幕展示的html內(nèi)容,因此會出現(xiàn)未顯示的圖像是空白的。解決辦法是調(diào)用enableSlowWholeDocumentDraw()方法。這個方法需要在webview創(chuàng)建之前調(diào)用,在Activity里就是在setContentView前去調(diào)用,此方法會有顯著的性能開銷。
3.分享圖片
通過原生或第三方分享功能,將上述生成的圖片添加到代碼中,完成分享。
如果有不同的見解,歡迎留言指正。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- Android開發(fā)筆記之如何正確獲取WebView的網(wǎng)頁Title
- 快速解決android webview https圖片不顯示的問題
- Android使用WebView實現(xiàn)文件下載功能
- Android WebView實現(xiàn)截長圖功能
- Android混合開發(fā)教程之WebView的使用方法總結(jié)
- 關(guān)于Android中WebView遠程代碼執(zhí)行漏洞淺析
- WebView的介紹與簡單實現(xiàn)Android和H5互調(diào)的方法
- Android實現(xiàn)視頻播放--騰訊瀏覽服務(wù)(TBS)功能
- Android在項目中接入騰訊TBS瀏覽器WebView的教程與注意的地方
相關(guān)文章
Android中的webview支持頁面中的文件上傳實例代碼
本篇文章主要介紹了Android中的webview支持頁面中的文件上傳,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-03-03
Android開發(fā)必知 九種對話框的實現(xiàn)方法
App中少不了與用戶交互的各種dialog,以此達到很好的用戶體驗,下面給大家介紹Android開發(fā)必知 九種對話框的實現(xiàn)方法,有需要的朋友可以參考下2015-08-08
Android動態(tài)權(quán)限申請實現(xiàn)步驟分解
對于一些危險權(quán)限在AndroidManifest清單文件中申請之后,還需要得到用戶的許可并打開,才算是真正的開啟了這個權(quán)限。所以可以使用動態(tài)申請權(quán)限,對于某個功能,如果需要開啟某個權(quán)限,在用戶使用它之前,彈窗提示用戶是否要開啟這個權(quán)限2023-04-04
另外兩種Android沉浸式狀態(tài)欄實現(xiàn)思路
這篇文章主要為大家介紹了另外兩種Android沉浸式狀態(tài)欄實現(xiàn)思路,android5.0及以后版本都支持給狀態(tài)欄著色,而目前android主流版本還是4.4,想要深入了解的朋友可以參考一下2016-01-01

