<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答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
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        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; }} 

      1. 實現(xiàn) getDrawable() 方法

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

      2. 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;} 

        圖片的顯示

      3. 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ū)域。

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

      5. 控制圖片居中顯示
      6. 首先獲取 TextView 的寬度,減去 paddingLeft paddingRight 即為 Drawable 可用的顯示寬度;
      7. 通過上面的兩個方法配合,控制圖片居中顯示。
      8. 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; }} 

        參考鏈接

      9. Drawable
      10. 聲明:本網(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
        主站蜘蛛池模板: 午夜毛片不卡高清免费| 久久国产高潮流白浆免费观看| 免费看国产精品3a黄的视频 | 国产色爽免费无码视频| 亚洲一级片免费看| av午夜福利一片免费看久久| 亚洲熟女乱综合一区二区| 51午夜精品免费视频| 国产午夜亚洲精品理论片不卡| 成人免费ā片在线观看| 精品国产亚洲一区二区三区 | 亚洲国产成人精品久久| 青青视频观看免费99| 中文字幕无码亚洲欧洲日韩| 性色av免费观看| 免费在线观看亚洲| 中文字幕精品亚洲无线码一区应用| 精品乱子伦一区二区三区高清免费播放| 久久久久久久亚洲精品| 丁香花在线视频观看免费| 亚洲日本在线免费观看| 免费观看一级毛片| 国产成人无码精品久久久久免费| 亚洲AV综合色区无码一区爱AV| 久久不见久久见免费视频7| 在线观看日本亚洲一区| 日韩一卡2卡3卡4卡新区亚洲| 久久精品国产这里是免费| 亚洲午夜国产精品| 四虎亚洲国产成人久久精品| 在线观看免费无码视频| 亚洲国产成人手机在线电影bd| 高清国语自产拍免费视频国产| 国产国产人免费人成成免视频| 亚洲国产综合专区电影在线| 九九精品免费视频| 一区二区三区在线观看免费| 久久av无码专区亚洲av桃花岛| 日本免费网站观看| 先锋影音资源片午夜在线观看视频免费播放| 亚洲成a人片在线观看中文app|