成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

Android開(kāi)發(fā)中怎么實(shí)現(xiàn)一個(gè)長(zhǎng)按將文章生成圖片的功能

這篇文章將為大家詳細(xì)講解有關(guān)Android開(kāi)發(fā)中怎么實(shí)現(xiàn)一個(gè)長(zhǎng)按將文章生成圖片的功能,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

創(chuàng)新互聯(lián)致力于互聯(lián)網(wǎng)網(wǎng)站建設(shè)與網(wǎng)站營(yíng)銷(xiāo),提供成都做網(wǎng)站、成都網(wǎng)站設(shè)計(jì)、網(wǎng)站開(kāi)發(fā)、seo優(yōu)化、網(wǎng)站排名、互聯(lián)網(wǎng)營(yíng)銷(xiāo)、重慶小程序開(kāi)發(fā)、公眾號(hào)商城、等建站開(kāi)發(fā),創(chuàng)新互聯(lián)網(wǎng)站建設(shè)策劃專家,為不同類(lèi)型的客戶提供良好的互聯(lián)網(wǎng)應(yīng)用定制解決方案,幫助客戶在新的全球化互聯(lián)網(wǎng)環(huán)境中保持優(yōu)勢(shì)。

長(zhǎng)按菜單實(shí)現(xiàn)

WebView可以如下實(shí)現(xiàn):

mWebView.setOnCreateContextMenuListener(new View.OnCreateContextMenuListener() {
      @Override
      public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) {
        genImg.setVisibility(View.VISIBLE);
        T.showSToast(mContext, "再次點(diǎn)擊文章可隱藏圖片分享");
      }
    });
    // 點(diǎn)擊隱藏底部按鈕
    mWebView.setOnTouchListener(new View.OnTouchListener() {
      @Override
      public boolean onTouch(View v, MotionEvent event) {
        switch (event.getAction()) {
          case MotionEvent.ACTION_DOWN:
            lastTime = SystemClock.uptimeMillis();
            break;
          case MotionEvent.ACTION_UP:
            if (SystemClock.uptimeMillis() - lastTime < 300) {
              genImg.setVisibility(View.GONE);
            }
            break;
        }
        return false;
      }
    });

這里通過(guò)監(jiān)聽(tīng)WebView的ContextMenu 監(jiān)聽(tīng)何時(shí)顯示底部按鈕;同時(shí)在onTouch方法中隱藏底部按鈕。

genImg.setOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View v) {
        genImg.setVisibility(View.INVISIBLE);
        Intent intent = new Intent(FakeJianShuActivity.this, GenScreenShotActivity.class);
        intent.putExtra("data", mHtmlBean);
        startActivity(intent);
      }
    });

點(diǎn)擊底部的Button就會(huì)跳轉(zhuǎn)到生成長(zhǎng)圖的界面,同時(shí)將之前獲取到的HTMLBean對(duì)象傳遞過(guò)去。

長(zhǎng)圖效果實(shí)現(xiàn)

這里首先說(shuō)一下實(shí)現(xiàn)思路(思路來(lái)源于 此 )。

?首先通過(guò)WebView加載一個(gè)本地的Html頁(yè)面,這個(gè)頁(yè)面包含一些固定,定義了一些標(biāo)簽。然后根據(jù)傳遞過(guò)來(lái)的mHtmlBean 對(duì)象中的信息,通過(guò)執(zhí)行JavaScript動(dòng)態(tài)的替換靜態(tài)HTML頁(yè)面中的內(nèi)容;

?關(guān)于黑白兩種風(fēng)格的實(shí)現(xiàn),同樣是WebView執(zhí)行Js,動(dòng)態(tài)替換HTML中CSS 樣式,修改WebView的背景色呈現(xiàn)出兩種不同的UI 效果。

?通過(guò)WebView的capturePicture 和Canvas 可以生成出當(dāng)前WebView的Bitmap對(duì)象,有了這個(gè)Bitmap就可以圖片保存的功能了。

好了,下面就通過(guò)代碼分別實(shí)現(xiàn)上述步驟。

Html 頁(yè)面

<html>
<head>
  <meta charset="utf-8"/>
</head>
<body>
<img src="mark.png" width="13px" height="20px"
   />
<article id="content" ></article>
<script type="text/javascript">
    function changeContent(content) {
      document.getElementById('content').innerHTML = content;
    }
</script>
</body>
</html>

這個(gè)HTML頁(yè)面的內(nèi)容很簡(jiǎn)單,在整個(gè)文檔左上角放置了一個(gè)小角標(biāo),就是簡(jiǎn)書(shū)APP生成長(zhǎng)圖時(shí)的那個(gè)mark.

同時(shí)定義了一個(gè)JavaScript 方法,功能也很簡(jiǎn)單,就是用傳遞的參數(shù)content替換article標(biāo)簽中的文檔內(nèi)容。

自定義WebView

為了方便,我們自定義WebView,這里看一下核心邏輯:

public class FakeWebView extends WebView {
  private boolean isFirstLoad = false;
  public void loadData(HtmlBean bean) {
    assembleData(bean);
    if (Build.VERSION.SDK_INT >= 21) {
      isFirstLoad = true;
      webView.setWebChromeClient(new WebChromeClient() {
        @Override
        public void onProgressChanged(WebView view, int newProgress) {
          if (newProgress == 100) {
            if (isFirstLoad) {
              isFirstLoad = false;
              Log.e("TAG", "onProgressChanged");
              updateView();
            }
          }
        }
      });
    } else {
      isFirstLoad = true;
      webView.setVisibility(View.INVISIBLE);
      webView.setWebChromeClient(new WebChromeClient() {
        @Override
        public void onProgressChanged(WebView view, int newProgress) {
          if (newProgress == 100) {
            updateView();
            if (!isFirstLoad)
              webView.setVisibility(View.VISIBLE);
          }
        }
      });
    }
    webView.loadUrl("file:///android_asset/JianShu.html");
  }
  private void assembleData(HtmlBean bean) {
    final String data = bean.getContent();
    final String title = bean.getTitle();
    final String username = bean.getUsername();
    final String publishTime = bean.getPublishTime();
    String Title = "<h3>" + title + "</h3>";
    String Footer = "<p>" + username + "</p><p>" + publishTime + "</p>";
    content = Title + data + Footer;
  }
  public void updateView() {
    if (mode == MODE_DAY) {
      webView.setBackgroundColor(Color.WHITE);
    } else {
      webView.setBackgroundColor(Color.parseColor("#263238"));
      content = "<div style=\"color: gray;display: inline;\">" + content + "</div>";
    }
    webView.loadUrl("javascript:changeContent(\"" + content.replace("\n", "\\n").replace("\"", "\\\"").replace("'", "\\'") + "\")");
  }
}

這幾個(gè)方法是生成長(zhǎng)圖最核心的方法。在loadData 方法中首先調(diào)用了assembleData,這個(gè)方法會(huì)根據(jù)mHtmlBean 這個(gè)對(duì)象中的數(shù)據(jù)拼接出一段 HTML 文檔。在webView的loadUrl 方法中會(huì)從本地加載之前定義好的JianShu.html這個(gè)頁(yè)面。然后在頁(yè)面加載完成,即onProgressChanged 回調(diào)方法中newProgress 的值等于100時(shí)調(diào)用updateView方法;這個(gè)方法會(huì)根據(jù)當(dāng)前設(shè)置的模式,設(shè)置WebView的背景,如果是夜間模式,則會(huì)對(duì)assembleData 中生成的文檔外部在添加 一個(gè)灰色風(fēng)格的div標(biāo)簽,將整個(gè)內(nèi)容包在這個(gè)div標(biāo)簽中,最后WebView執(zhí)行JS方法 changeContent,傳遞的參數(shù)就是之前我們拼接好的內(nèi)容。這樣整個(gè)WebView又會(huì)刷新一次,整個(gè)WebView的內(nèi)容就是文章內(nèi)容了。

GenScreenShotActivity
mFakeWebView = (FakeWebView) findViewById(R.id.fakeWebView);
    bean = (HtmlBean) getIntent().getSerializableExtra("data");
    RadioGroup changeMode = (RadioGroup) findViewById(R.id.changeMode);
    changeMode.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
      @Override
      public void onCheckedChanged(RadioGroup group, @IdRes int checkedId) {
        if (checkedId == R.id.rb_day) {
          mFakeWebView.setMode(FakeWebView.MODE_DAY);
        } else {
          mFakeWebView.setMode(FakeWebView.MODE_NIGHT);
        }
      }
    });
    mFakeWebView.loadData(bean);

   /**
   * @param mode
   */
  public void setMode(@ViewMode int mode) {
    this.mode = mode;
    updateView();
  }

這樣在Activity中,mFakeWebView對(duì)象通過(guò)上一個(gè)頁(yè)面(文章頁(yè))傳遞的mHtmlBean 對(duì)象就可以更新當(dāng)前視圖了,同時(shí)可以通過(guò)RadioButton實(shí)現(xiàn)頁(yè)面風(fēng)格的切換。

保存圖片

距離我們最后的目標(biāo) 生成長(zhǎng)圖片 ,前面的工作可以說(shuō)只是完成了50%,因?yàn)榈侥壳盀橹刮覀冎徊贿^(guò)是在WebView中把整個(gè)文章內(nèi)容加載出來(lái)而已;長(zhǎng)圖還沒(méi)有呢。因此,下面的工作就是通過(guò)WebView 生成長(zhǎng)圖。

public Bitmap getScreenView(){
    Picture snapShot = webView.capturePicture();
    Bitmap bmp = Bitmap.createBitmap(snapShot.getWidth(),snapShot.getHeight(), Bitmap.Config.ARGB_8888);
    Canvas canvas = new Canvas(bmp);
    snapShot.draw(canvas);
    return bmp;
  }

WebVeiw 很人性化,通過(guò)這個(gè)方法,我們就可以獲得當(dāng)前WebView視圖 可見(jiàn)與不可見(jiàn) 部分的Bitmap了。

其實(shí)通過(guò)WebView生成圖片并不是一件難事,難得是如何把我們這里的圖片保存下來(lái);因?yàn)槲覀冞@里生成的是長(zhǎng)圖,如下圖所示,這張照片的高度達(dá)到了驚人的。因此這里就要需要之前在 Bitmap 初探 中提到的第一種壓縮方法進(jìn)行文件大小的壓縮了。具體實(shí)現(xiàn),就不再重復(fù)貼出代碼了,有興趣的同學(xué)可參考文末Github源碼。

到這里,我們就完全實(shí)現(xiàn)了仿照簡(jiǎn)書(shū)長(zhǎng)按生成圖片的功能。那么回過(guò)頭再來(lái)看,這樣一個(gè)功能,為什么在我的手機(jī)上,簡(jiǎn)書(shū)APP的長(zhǎng)按功能會(huì)有bug呢。

缺陷

文章詳情頁(yè)的WebView是系統(tǒng)自帶的WebView,在加載帶 代碼的文章時(shí),沒(méi)有對(duì)代碼類(lèi)的內(nèi)容做特殊的解析,因此無(wú)法對(duì)代碼高亮顯示。只是最為普通的文本進(jìn)行了顯示,因此生成的長(zhǎng)圖中代碼也是普通文本。簡(jiǎn)書(shū)APP還是高大上呀,對(duì)代碼的高亮顯示正是棒棒噠!

后話

一個(gè)偶然的機(jī)會(huì),在嘗試簡(jiǎn)書(shū)長(zhǎng)按生成圖片的功能時(shí)發(fā)現(xiàn),原來(lái)簡(jiǎn)書(shū)是通過(guò)WebView選擇的區(qū)域生成第二頁(yè)的內(nèi)容;因此當(dāng)我在文章頁(yè)空白區(qū)域長(zhǎng)按后,點(diǎn)擊生成圖片時(shí)必然是只有空白的,只有底部的一些固定標(biāo)簽。因此,這應(yīng)該不算是一個(gè)bug,只是為大家提供了一種更方便的功能,可以按自己喜歡的內(nèi)容生成更有效的長(zhǎng)圖。

關(guān)于Android開(kāi)發(fā)中怎么實(shí)現(xiàn)一個(gè)長(zhǎng)按將文章生成圖片的功能就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

本文名稱:Android開(kāi)發(fā)中怎么實(shí)現(xiàn)一個(gè)長(zhǎng)按將文章生成圖片的功能
文章鏈接:http://jinyejixie.com/article0/gggsoo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)建站網(wǎng)站策劃、網(wǎng)站設(shè)計(jì)公司、網(wǎng)站維護(hù)網(wǎng)站排名、App設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

綿陽(yáng)服務(wù)器托管
二连浩特市| 兴海县| 绍兴县| 鄂伦春自治旗| 横山县| 吴桥县| 栾城县| 垦利县| 桃园市| 济源市| 嘉兴市| 凌源市| 万盛区| 临桂县| 德州市| 大埔县| 兴城市| 陕西省| 江都市| 永善县| 杭州市| 甘泉县| 关岭| 县级市| 临安市| 紫阳县| 济源市| 鹰潭市| 乐清市| 五河县| 肥乡县| 贵南县| 吴忠市| 龙井市| 青铜峡市| 鸡泽县| 尼勒克县| 清河县| 靖安县| 连州市| 巩留县|