天天看點

轉載 Android仿今日頭條詳情頁實作Android仿今日頭條詳情頁實作歡迎使用Markdown編輯器

轉載自@ice_Anson

Android仿今日頭條詳情頁實作

源碼位址:

Android仿今日頭條詳情頁實作 github源碼位址

動态圖

最近項目有個需求,需要實作一個和今日頭條新聞詳情頁一樣的體驗。上部分是webview來展示新聞内容,下半部分是listview來展示評論區,可無限加載更多。

起初的實作思路是 将webview放置在listview頭部,看似沒有什麼問題,實作之後發現,webview各種奇怪的問題:黑屏,圖檔閃爍白屏,渲染速度慢等等問題;

将webview和listview獨立放置遍沒有問題;于是反編譯了一下頭條的實作:

轉載 Android仿今日頭條詳情頁實作Android仿今日頭條詳情頁實作歡迎使用Markdown編輯器

從上圖可以知道,實作的原理是,ViewGroup包着listview和webview實作的;于是順着這條思路往下走。

今日頭條的代碼是混淆的無法直接使用,我采用的方案是ScrollView裡邊嵌套了webview+listview;

這套方案有以下幾個問題需要解決:

解決webview在scrollview全部展開的問題。不展開的方法太過複雜,手勢處理太麻煩,這裡采用展開的形式
  我們知道scrollview包含的childview是無法複用了,那麼首先要解決listview的複用問題;
  滑動到listview和webview邊界的時候,對于手勢事件的交換和狀态的儲存。
           
  • 1
  • 2
  • 3
  • 4

1、webview全部展開的問題

mWebView.loadUrl(url);
        mWebView.setWebViewClient(new WebViewClient() {
            @Override
            public void onPageFinished(WebView view, String url) {
                super.onPageFinished(view, url);
                int w = View.MeasureSpec.makeMeasureSpec(,
                        View.MeasureSpec.UNSPECIFIED);
                int h = View.MeasureSpec.makeMeasureSpec(,
                        View.MeasureSpec.UNSPECIFIED);
                //重新測量
                view.measure(w, h);
                mWebViewHeight = view.getHeight();
                Log.i(TAG, "WEBVIEW高度:" + view.getHeight());
            }
        });
           
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

2和3、listview複用問題和手勢切換問題

1、複用意味着不能全部展開,現将高度定為(螢幕高度-狀态欄高度-标題欄高度);

2、當scrollview滾動到底部的時候,讓listview根據手勢慣性fling一會,以加強體驗,然後将手勢交給listview;

3、當listview滑動到底部的時候,加載更多;

4、當listview滑動到頂部的時候,向上滾5個像素,并将手勢交給scrollview,便可向上流暢滑動;

5、當listview即将到達頂部的時候,手動往下拖動,當到達邊界的時候,需要讓scrollview跟着以前scrollby,讓使用者感覺是一起滑動的,當手指松開的時候,要讓scrollview慣性滾動一會,以增強體驗;

遺留問題

1、scrollview和listview的内部滾動速度是不一緻的,scrollview是比較大的,在scrollview滾動到底部的時候,listview采用scrollview滾動速度的三分之一進行fling,體驗下來感覺還是比較流暢的。但總感覺還是不夠穩妥,優化思路是:接管scrollview和listview的滾動速度,手動控制兩個控件的過渡過程;

2、當listview即将到達頂部的時候,手動往下拖動,當到達邊界的時候,需要讓scrollview跟着以前scrollby,讓使用者感覺是一起滑動的,當手指松開的時候,要讓scrollview慣性滾動一會,這裡的慣性也由于速度不一緻的問題,造成一點點的那麼不自然;優化思路和1一緻;

Done

QQ:452825089

mail:[email protected]

wechat:ice3897315

blog:http://iceAnson.github.io

@[TOC](這裡寫自定義目錄标題)

歡迎使用Markdown編輯器

你好! 這是你第一次使用 Markdown編輯器 所展示的歡迎頁。如果你想學習如何使用Markdown編輯器, 可以仔細閱讀這篇文章,了解一下Markdown的基本文法知識。

新的改變

我們對Markdown編輯器進行了一些功能拓展與文法支援,除了标準的Markdown編輯器功能,我們增加了如下幾點新功能,幫助你用它寫部落格:

  1. 全新的界面設計 ,将會帶來全新的寫作體驗;
  2. 在創作中心設定你喜愛的代碼高亮樣式,Markdown 将代碼片顯示選擇的高亮樣式 進行展示;
  3. 增加了 圖檔拖拽 功能,你可以将本地的圖檔直接拖拽到編輯區域直接展示;
  4. 全新的 KaTeX數學公式 文法;
  5. 增加了支援甘特圖的mermaid文法1 功能;
  6. 增加了 多螢幕編輯 Markdown文章功能;
  7. 增加了 焦點寫作模式、預覽模式、簡潔寫作模式、左右區域同步滾輪設定 等功能,功能按鈕位于編輯區域與預覽區域中間;
  8. 增加了 檢查清單 功能。

功能快捷鍵

撤銷:Ctrl/Command + Z

重做:Ctrl/Command + Y

加粗:Ctrl/Command + B

斜體:Ctrl/Command + I

标題:Ctrl/Command + Shift + H

無序清單:Ctrl/Command + Shift + U

有序清單:Ctrl/Command + Shift + O

檢查清單:Ctrl/Command + Shift + C

插入代碼:Ctrl/Command + Shift + K

插傳入連結接:Ctrl/Command + Shift + L

插入圖檔:Ctrl/Command + Shift + G

合理的建立标題,有助于目錄的生成

直接輸入1次#,并按下space後,将生成1級标題。

輸入2次#,并按下space後,将生成2級标題。

以此類推,我們支援6級标題。有助于使用

TOC

文法後生成一個完美的目錄。

如何改變文本的樣式

強調文本 強調文本

加粗文本 加粗文本

标記文本

删除文本

引用文本

H2O is是液體。

210 運算結果是 1024.

插傳入連結接與圖檔

連結: link.

圖檔:

轉載 Android仿今日頭條詳情頁實作Android仿今日頭條詳情頁實作歡迎使用Markdown編輯器

帶尺寸的圖檔:

轉載 Android仿今日頭條詳情頁實作Android仿今日頭條詳情頁實作歡迎使用Markdown編輯器

居中的圖檔:

轉載 Android仿今日頭條詳情頁實作Android仿今日頭條詳情頁實作歡迎使用Markdown編輯器

居中并且帶尺寸的圖檔:

轉載 Android仿今日頭條詳情頁實作Android仿今日頭條詳情頁實作歡迎使用Markdown編輯器

當然,我們為了讓使用者更加便捷,我們增加了圖檔拖拽功能。

如何插入一段漂亮的代碼片

去部落格設定頁面,選擇一款你喜歡的代碼片高亮樣式,下面展示同樣高亮的

代碼片

.

// An highlighted block
var foo = 'bar';
           

生成一個适合你的清單

  • 項目
    • 項目
      • 項目
  1. 項目1
  2. 項目2
  3. 項目3
  • 計劃任務
  • 完成任務

建立一個表格

一個簡單的表格是這麼建立的:

項目 Value
電腦 $1600
手機 $12
導管 $1

設定内容居中、居左、居右

使用

:---------:

居中

使用

:----------

居左

使用

----------:

居右

第一列 第二列 第三列
第一列文本居中 第二列文本居右 第三列文本居左

SmartyPants

SmartyPants将ASCII标點字元轉換為“智能”印刷标點HTML實體。例如:

TYPE ASCII HTML
Single backticks

'Isn't this fun?'

‘Isn’t this fun?’
Quotes

"Isn't this fun?"

“Isn’t this fun?”
Dashes

-- is en-dash, --- is em-dash

– is en-dash, — is em-dash

建立一個自定義清單

Markdown
Text-to- HTML conversion tool
Authors
John
Luke

如何建立一個注腳

一個具有注腳的文本。2

注釋也是必不可少的

Markdown将文本轉換為 HTML。

KaTeX數學公式

您可以使用渲染LaTeX數學表達式 KaTeX:

Gamma公式展示 Γ ( n ) = ( n − 1 ) ! ∀ n ∈ N \Gamma(n) = (n-1)!\quad\forall n\in\mathbb N Γ(n)=(n−1)!∀n∈N 是通過歐拉積分

Γ ( z ) = ∫ 0 ∞ t z − 1 e − t d t   . \Gamma(z) = \int_0^\infty t^{z-1}e^{-t}dt\,. Γ(z)=∫0∞​tz−1e−tdt.

你可以找到更多關于的資訊 LaTeX 數學表達式here.

新的甘特圖功能,豐富你的文章

  • 關于 甘特圖 文法,參考 這兒,

UML 圖表

可以使用UML圖表進行渲染。 Mermaid. 例如下面産生的一個序列圖::

這将産生一個流程圖。:

  • 關于 Mermaid 文法,參考 這兒,

FLowchart流程圖

我們依舊會支援flowchart的流程圖:

  • 關于 Flowchart流程圖 文法,參考 這兒.

導出與導入

導出

如果你想嘗試使用此編輯器, 你可以在此篇文章任意編輯。當你完成了一篇文章的寫作, 在上方工具欄找到 文章導出 ,生成一個.md檔案或者.html檔案進行本地儲存。

導入

如果你想加載一篇你寫過的.md檔案或者.html檔案,在上方工具欄可以選擇導入功能進行對應擴充名的檔案導入,

繼續你的創作。

  1. mermaid文法說明 ↩︎
  2. 注腳的解釋 ↩︎