• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    ImageGetter顯示Html中的圖片_html/css

    來源:懂視網 責編:小采 時間:2020-11-27 16:26:43
    文檔

    ImageGetter顯示Html中的圖片_html/css

    ImageGetter顯示Html中的圖片_html/css_WEB-ITnose: ImageGetter 在 TextView 中顯示 html ,需要使用 ImageGetter 解析標簽。ImageGetter 是一個接口,需要實現里面的方法。 public DrawablegetDrawable(String source); 簡單的 ImageGetter 實現 創建一個 Drawab
    推薦度:
    導讀ImageGetter顯示Html中的圖片_html/css_WEB-ITnose: ImageGetter 在 TextView 中顯示 html ,需要使用 ImageGetter 解析標簽。ImageGetter 是一個接口,需要實現里面的方法。 public DrawablegetDrawable(String source); 簡單的 ImageGetter 實現 創建一個 Drawab

    ImageGetter

    在 TextView 中顯示 html ,需要使用 ImageGetter 解析標簽。ImageGetter 是一個接口,需要實現里面的方法。

    public DrawablegetDrawable(String source); 

    簡單的 ImageGetter 實現

    創建一個 Drawable 對象,保留引用并返回,異步請求網絡,獲取圖片,獲取到圖片后,轉換為 Bitmap ,交給 Drawable 對象進行繪制。– 自定義 Drawable 對象

    static class MyDrawable extends BitmapDrawable{ BitmapmBitmap; public MyDrawable() { super(); } @Override public void draw(Canvascanvas) { super.draw(canvas); if(mBitmap != null) { canvas.drawBitmap(mBitmap,0,0,getPaint()); } } public void setBitmap(Bitmapbitmap) { mBitmap = bitmap; }} 

  • 實現 getDrawable() 方法

    MyImageGetter 有一個 TextView 成員,用于保存用于圖片顯示的 TextView ,加載完成后,調用 TextView 的 invalidate() 方法刷新視圖。

  • public MyImageGetter(TextViewview){ mContainer = view;} @Overridepublic DrawablegetDrawable(String s){ // 初始化占位 Drawable final MyDrawabledrawable = new MyDrawable(); // 初始化請求對象 LocalHostModelmodel = new LocalHostModel(); // 設置回調函數 model.setImageListener(new LocalHostModel.OnRequestImageListener() { @Override public void onSuccess(Bitmapbitmap) { // 處理 bitmap 刷新視圖 drawable.setBitmap(bitmap); int height = bitmap.getHeight(); int width = bitmap.getWidth(); drawable.setBounds(0, 0, width, height); mContainer.invalidate(); } @Override public void onFailed(String msg) { Log.i(TAG, "onFailed: " + msg); } }); // 請求圖片 model.requestImage(s); return drawable;} 

    圖片的顯示

  • Drawable.setBounds(Rect) 方法

    The setBounds(Rect) method must be called to tell the Drawable where it is drawn and how large it should be. All Drawables should respect the requested size, often simply by scaling their imagery. A client can find the preferred size for some Drawables with the getIntrinsicHeight() and getIntrinsicWidth() methods.

    Drawable.setBounds(Rect) 用于設置繪圖的位置,和繪圖的區域。

  • Canvas.drawBitmap()bitmap 要通過 Drawable.draw(Canvas) 函數繪制,可以通過 Canvas.drawBitmap() 控制 bitmap 在Drawable 中的顯示位置。

  • 控制圖片居中顯示
  • 首先獲取 TextView 的寬度,減去 paddingLeft paddingRight 即為 Drawable 可用的顯示寬度;
  • 通過上面的兩個方法配合,控制圖片居中顯示。
  • private void handleBitmap(MyDrawabledrawable, BitmapsrcBitmap){ // 獲取原 bitmap 的大小 int srcHeight = srcBitmap.getHeight(); int srcWidth = srcBitmap.getWidth(); // drawable 可用的顯示寬度 int containerPadding = mContainer.getPaddingLeft() + mContainer.getPaddingRight(); int drawableWidth = mContainer.getMeasuredWidth() - containerPadding; int dstWidth = drawableWidth - mPadding * 2; // 圖片較小,不縮放 if (dstWidth >= srcWidth) { drawable.setBitmap(srcBitmap); // 設置 drawable 區域 int drawableHeight = srcHeight + 2 * mPadding; drawable.setBounds(0, 0, drawableWidth, drawableHeight); // 設置 bitmap 繪制區域 int left = (drawableWidth - srcWidth) / 2; int top = mPadding; Rectrect = new Rect(left, top, left + srcWidth, top + srcHeight); drawable.setDstRect(rect); } else { // 圖片縮放矩陣 Matrixmatrix = new Matrix(); float scale = (float) dstWidth / srcWidth; matrix.postScale(scale, scale); // 轉換 bitmap 為適合 drawable 的大小 BitmapdstBitmap = Bitmap.createBitmap(srcBitmap, 0, 0, srcWidth, srcHeight, matrix, false); drawable.setBitmap(dstBitmap); // 設置 drawable 區域 int dstHeight = srcHeight * drawableWidth / srcWidth; int drawableHeight = dstHeight + 2 * mPadding; drawable.setBounds(0, 0, drawableWidth, drawableHeight); // 設置 bitmap 繪制區域 int left = mPadding; int top = mPadding; Rectrect = new Rect(left, top, left + dstWidth, top + dstHeight); drawable.setDstRect(rect); }}static class MyDrawable extends BitmapDrawable{ BitmapmBitmap; RectmSrcRect; RectmDstRect; public MyDrawable(Resourcesres, Bitmapbitmap) { super(res, bitmap); } public void setSrcRect(RectsrcRect) { mSrcRect = srcRect; } public void setDstRect(RectdstRect) { mDstRect = dstRect; } @Override public void draw(Canvascanvas) { super.draw(canvas); // 繪制 bitmap if (mBitmap != null) { if (mSrcRect != null && mDstRect != null) { canvas.drawBitmap(mBitmap, mSrcRect, mDstRect, getPaint()); } else if (mDstRect != null) { int width = mBitmap.getWidth(); int height = mBitmap.getHeight(); RectsrcRect = new Rect(0, 0, width, height); canvas.drawBitmap(mBitmap, srcRect, mDstRect, getPaint()); } else { canvas.drawBitmap(mBitmap, 0, 0, getPaint()); } } } public void setBitmap(Bitmapbitmap) { mBitmap = bitmap; }} 

    參考鏈接

  • Drawable
  • 聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    ImageGetter顯示Html中的圖片_html/css

    ImageGetter顯示Html中的圖片_html/css_WEB-ITnose: ImageGetter 在 TextView 中顯示 html ,需要使用 ImageGetter 解析標簽。ImageGetter 是一個接口,需要實現里面的方法。 public DrawablegetDrawable(String source); 簡單的 ImageGetter 實現 創建一個 Drawab
    推薦度:
    標簽: 圖片 顯示 的圖片
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 国产伦精品一区二区三区| 成人区精品一区二区不卡| 久久精品aⅴ无码中文字字幕不卡| 四虎国产精品永久一区| 亚洲国产精品无码久久久不卡| 在线电影国产精品| 国产精品美女久久久m| 亚洲?V乱码久久精品蜜桃| 北条麻妃国产九九九精品视频| 精品福利一区二区三区免费视频 | 人妻熟妇乱又伦精品视频| 精品无码三级在线观看视频| 久久国产精品成人免费| 精品偷自拍另类在线观看| 无码国模国产在线无码精品国产自在久国产| 91精品国产综合久久四虎久久无码一级| 国产午夜精品一区二区三区漫画| 亚洲精品无码AV中文字幕电影网站| 精品国产成人在线| 国产va免费精品| 91不卡在线精品国产| 精品久久久久久国产| 国产精品扒开腿做爽爽爽视频| 中文字幕无码精品亚洲资源网久久| 精品国产欧美一区二区三区成人 | 97久久超碰成人精品网站| 日韩精品乱码AV一区二区| 亚洲国产精品综合久久一线| 精品国产人成亚洲区| 国产精品自在线拍国产第一页| 97视频在线精品国自产拍| 四虎在线精品视频一二区| 欧美777精品久久久久网| 日韩麻豆国产精品欧美| 欧美精品手机在线播放| 欧美精品一本久久男人的天堂| 精品国产免费一区二区三区香蕉 | 91精品日韩人妻无码久久不卡| 久久精品国产99国产电影网 | 亚洲精品乱码久久久久久蜜桃不卡 | 久久夜色精品国产亚洲|