• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題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關(guān)鍵字專題關(guān)鍵字專題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
    當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

    ImageGetter顯示Html中的圖片_html/css

    來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-27 16:26:43
    文檔

    ImageGetter顯示Html中的圖片_html/css

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

    ImageGetter

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

    public DrawablegetDrawable(String source); 

    簡單的 ImageGetter 實現(xiàn)

    創(chuàng)建一個 Drawable 對象,保留引用并返回,異步請求網(wǎng)絡(luò),獲取圖片,獲取到圖片后,轉(zhuǎn)換為 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; }} 

  • 實現(xiàn) getDrawable() 方法

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

  • public MyImageGetter(TextViewview){ mContainer = view;} @Overridepublic DrawablegetDrawable(String s){ // 初始化占位 Drawable final MyDrawabledrawable = new MyDrawable(); // 初始化請求對象 LocalHostModelmodel = new LocalHostModel(); // 設(shè)置回調(diào)函數(shù) 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) 用于設(shè)置繪圖的位置,和繪圖的區(qū)域。

  • Canvas.drawBitmap()bitmap 要通過 Drawable.draw(Canvas) 函數(shù)繪制,可以通過 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); // 設(shè)置 drawable 區(qū)域 int drawableHeight = srcHeight + 2 * mPadding; drawable.setBounds(0, 0, drawableWidth, drawableHeight); // 設(shè)置 bitmap 繪制區(qū)域 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); // 轉(zhuǎn)換 bitmap 為適合 drawable 的大小 BitmapdstBitmap = Bitmap.createBitmap(srcBitmap, 0, 0, srcWidth, srcHeight, matrix, false); drawable.setBitmap(dstBitmap); // 設(shè)置 drawable 區(qū)域 int dstHeight = srcHeight * drawableWidth / srcWidth; int drawableHeight = dstHeight + 2 * mPadding; drawable.setBounds(0, 0, drawableWidth, drawableHeight); // 設(shè)置 bitmap 繪制區(qū)域 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
  • 聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    ImageGetter顯示Html中的圖片_html/css

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

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 2018国产精华国产精品| 中文精品久久久久国产网址| 国产精品女同一区二区| 久久精品国产99久久香蕉| 国产精品一在线观看| 无码人妻精品一区二区三区东京热| 国产精品熟女福利久久AV| 精品国产自在在线在线观看| 久久99热只有频精品8| 午夜在线视频91精品 | 国产精品性爱| 国产午夜精品视频| 国产午夜精品久久久久免费视 | 欧美激情精品久久久久久久九九九| 99热这里只有精品国产66| 国产在视频线精品视频二代| 国产精品污WWW在线观看| 亚洲αv在线精品糸列| 亚洲а∨天堂久久精品9966| 精品99又大又爽又硬少妇毛片| 热RE99久久精品国产66热| 日本伊人精品一区二区三区| 亚洲精品网站在线观看不卡无广告| 惠民福利中文字幕人妻无码乱精品| 国产精品乱码一区二区三区| 国产精品国产三级在线高清观看 | 亚洲国产婷婷综合在线精品| 久久国产精品波多野结衣AV| 国产这里有精品| 精品无码久久久久久国产| 国产一区二区精品尤物| 国产一区麻豆剧传媒果冻精品| 国产精品内射久久久久欢欢| 国产色婷婷精品综合在线| 国产精品免费看久久久香蕉| 精品国产午夜福利在线观看| 精品无码人妻一区二区三区不卡| 久久国产乱子伦精品免费午夜| 日本加勒比久久精品| 亚洲视频在线精品| 日韩精品系列产品|