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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

获取远程文章内容时,显示图片的两种方式

發布時間:2025/7/14 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 获取远程文章内容时,显示图片的两种方式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

第一種:

通過Html.fromHtml(String,ImageGetter,tagHandler)

CharSequence text = Html.fromHtml(capter, new ImageGetter() {?? ??? ??? ??? ??? ?
?? ??? ??? ??? ??? ?@Override
?? ??? ??? ??? ??? ?public Drawable getDrawable(String source) {
?? ??? ??? ??? ??? ??? ?Drawable drawable = null;
?? ??? ??? ??? ??? ??? ?try {
?? ??? ??? ??? ??? ??? ??? ?drawable = Drawable.createFromStream(new URL(source).openStream(),"image");//從遠程獲取圖片
?? ??? ??? ??? ??? ??? ??? ?drawable.setBounds(0, 0, drawable.getIntrinsicWidth(), drawable.getIntrinsicHeight());//要設置邊界信息? Drawable本身是沒有邊界信息的
?? ??? ??? ??? ??? ??? ?} catch (Exception e) {
?? ??? ??? ??? ??? ??? ??? ?e.printStackTrace();
?? ??? ??? ??? ??? ??? ?}
?? ??? ??? ??? ??? ??? ?return drawable;
?? ??? ??? ??? ?}}, null);

capter_view= (TextView)findViewById(R.id.bookcapter);

capter_view.setText(text);//就可以顯示出img的圖片信息了(這些操作都不要放在UI線程里做,因為圖片下載可能比較費時。)

?

第二種:

這個需要服務端配合,服務端需要將圖片和文字信息在服務端分割開,同時給index來標示位置(為了解決內容分割后不會交叉,客戶端可以按index按原來的順序來排列顯示)

服務端返回的是以圖片img標簽分割的json數組(這個操作android端應該也可以做)

?

客戶端遍歷json數組顯示

如果是img的類型則創建ImageView來顯示img

如果是text的類型則創建TextView來顯示text

這塊操作可以封裝成 繼承LinearLayout?的自定義TestView控件

然后把json數組轉成List<HashMap<key,value>> datas;

模擬TextView的setText方法,我們也可以自定義一個setText(),當然你也可以定義其他名稱,這個方法不是重寫,所以隨便自定義。

在這個方法里遍歷數據生成ImageView或TextView

最后通過調用TestView.setText(datas);

生成ImageView后,把ImageView傳給新線程,在線程里遠程獲取圖片drawable后,再ImageView.setImageDrawable(drawable)

?

?

轉載于:https://www.cnblogs.com/jshen/p/4008062.html

總結

以上是生活随笔為你收集整理的获取远程文章内容时,显示图片的两种方式的全部內容,希望文章能夠幫你解決所遇到的問題。

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