時間軸、流程類時間軸繪製

来源:https://www.cnblogs.com/myfittinglife/p/18244244
-Advertisement-
Play Games

目錄效果圖思路具體實現步驟一:ItemView頂部偏移步驟二:繪製圓和線條註意:下標的獲取流程類的繪製總結 效果圖 可控制是否繪製在中間 控制繪製的線條是否為虛線 控制第一條數據圓頂部線條和最後一條數據圓底部線條是否繪製 除了gif圖片展示的屬性,還可以控制圓的大小顏色、圓是否有上和左偏移、線條顏色 ...


目錄

效果圖

時間軸效果圖
  • 可控制是否繪製在中間
  • 控制繪製的線條是否為虛線
  • 控制第一條數據圓頂部線條和最後一條數據圓底部線條是否繪製

除了gif圖片展示的屬性,還可以控制圓的大小顏色、圓是否有上和左偏移、線條顏色等屬性

除了通用的時間軸繪製,我們還可以通過改變繪製圓的樣式,改為繪製相應的bitmap圖像,來實現展示相關的流程

流程類時間軸效果圖

思路

關於ItemDecoration相關的內容已經寫了不少,這個其實就是小菜一碟。我們需要做的工作有兩點

  • ItemDecoration在getItemOffsets()方法內做相應的偏移
  • onDraw()方法內分別繪製圓、圓頂部線條、圓底部線條
    • 繪製線條,我們需要知道start和end的點坐標;
    • 繪製圓,我們需要知道圓心和半徑;

通過下圖,你將能清楚地獲取到這些繪製需要的一些信息

image

具體實現

有了以上內容,我們開始繪製

步驟一:ItemView頂部偏移

 override fun getItemOffsets(
        outRect: Rect,
        view: View,
        parent: RecyclerView,
        state: RecyclerView.State,
    ) {
        if (parent.getChildAdapterPosition(view) != 0) {
            //第一個不做頂部偏移
            outRect.top = topItemSpace
        }
        outRect.left = leftItemSpace

    }

步驟二:繪製圓和線條

override fun onDraw(c: Canvas, parent: RecyclerView, state: RecyclerView.State) {
        //獲取到的是當前屏幕可見的個數
        val childCount = parent.childCount

        for (i in 0 until childCount) {
            val view = parent.getChildAt(i)
            //獲取真實的在整體數據中的位置
            val index=parent.getChildAdapterPosition(view)

            //ItemView左側+偏移的矩形框(綠色框部分)
            val spaceRectTop = if (index == 0) view.top else view.top - topItemSpace
            val spaceRectBottom = view.bottom
            val spaceRectLeft = view.left - leftItemSpace
            val spaceRectRight = view.left

            //ItemView左側,不包含偏移的矩形框(紅色框部分)
            val dataRectLeft = view.left - leftItemSpace
            val dataRectTop = view.top
            val dataRectRight = view.left
            val dataRectBottom = view.bottom

            //圓心坐標
            var centerX = if(isDrawAtMiddle) (dataRectLeft + dataRectRight)/ 2  else (dataRectLeft + dataRectRight)/ 2 + circleLeftPadding
            val centerY =
                if (isDrawAtMiddle) (dataRectTop + dataRectBottom) / 2 else dataRectTop + circleRadius + circleTopPadding

            //繪製第一條線
            if (index==0){
                if (isDrawFirstItemTopLine){
                    c.drawLine(
                        centerX.toFloat(),
                        spaceRectTop.toFloat(),
                        centerX.toFloat(),
                        (centerY - circleRadius).toFloat(),
                        mLinePaint
                    )
                }
            }else{
                c.drawLine(
                    centerX.toFloat(),
                    spaceRectTop.toFloat(),
                    centerX.toFloat(),
                    (centerY - circleRadius).toFloat(),
                    mLinePaint
                )
            }
            //繪製圓(居中顯示)
            c.drawCircle(centerX.toFloat(), centerY.toFloat(), circleRadius.toFloat(), mCirclePaint)


            //繪製第二條線,註意這裡要用itemCount,因為上面的childCount是當前頁面可見的個數
            parent.adapter?.let {
                if (index!=it.itemCount-1){
                    c.drawLine(
                        centerX.toFloat(),
                        (centerY + circleRadius).toFloat(),
                        centerX.toFloat(),
                        spaceRectBottom.toFloat(),
                        mLinePaint
                    )
                }else{
                    if (isDrawLastItemBottomLine){
                        c.drawLine(
                            centerX.toFloat(),
                            (centerY + circleRadius).toFloat(),
                            centerX.toFloat(),
                            spaceRectBottom.toFloat(),
                            mLinePaint
                        )
                    }
                }
            }
        }
    }

註意:下標的獲取

因為我們需要每個ItemView都繪製,所以需要使用迴圈。但因為val childCount = parent.childCount獲取到的是當前頁面可見的個數,並不是實際的個數,所以我們在判斷是否是首條或者最後一條數據時,那個index要通過val index=parent.getChildAdapterPosition(view)的方式來獲取到真實的下標位置。

流程類的繪製

和繪製通用的圓類似,不過是將Canvas.drawCircle()改為Canvas.drawBitmap()。至於不同的bitmap的載入,我們可以通過傳入集合的數據類型來判斷繪製哪種圖片即可。

override fun onDraw(c: Canvas, parent: RecyclerView, state: RecyclerView.State) {
	...
	val srcRect = Rect(0, 0, progressBitmap.width, progressBitmap.height)
	val dstRect = Rect(
        centerX - circleRadius,
        centerY - circleRadius,
        centerX + circleRadius,
        centerY + circleRadius
    )
    c.drawBitmap(errorBitmap, srcRect, dstRect, mCirclePaint)
    ...
}

總結

其實主要還是ItemDecoration相關的內容,在onDraw()方法內繪製圓、繪製bitmap和繪製線條,根據上面的圖,知道具體的坐標位置,繪製就很輕鬆了,也可以在此基礎上繼續擴展,使得我們的時間軸ItemDecoration更加的通用,方便運用到項目中。

如果本文對你有幫助,請別忘記三連,如果有不恰當的地方也請提出來,下篇文章見。

時間軸效果圖
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在這個數據如潮的時代,SQL 已遠遠超越了簡單的查詢語言範疇,它已成為數據分析和決策制定的基石,成為撬動企業智慧決策的關鍵杠桿。SQL 的編寫和執行效率直接關係到數據處理的速度和分析結果的深度,對企業洞察市場動態、優化業務流程、提升決策質量起著至關重要的作用。 如何在浩瀚的數據海洋中快速捕撈到價值信 ...
  • 指標是反映企業的各項核心業務活動、管理成效的數據體系,指標體系作為聯結業務邏輯與數據實體的關鍵橋梁,是構建高質量數據統計的基礎單元,併在量化業務績效和效果評估中扮演著核心角色。 為了更好地服務於客戶並提供切實可行的實踐指導,自4月24日起,袋鼠雲將推出全新《指標體系建設實戰》系列直播。該系列內容覆蓋 ...
  • 天翼雲TeleDB分析型實例是一款性能卓越、完全托管的PB級國產化雲分析型資料庫產品,可提供輕鬆的海量數據分析體驗。基於元數據、計算和存儲分離的架構,TeleDB分析型實例集成了MPP資料庫的高性能和分析功能、大數據平臺的擴展性和靈活性以及雲計算的彈性和敏捷性,支持SQL及標準的JDBC和ODBC接... ...
  • 近日,全國智能計算標準化工作組算力互聯互通研究組啟動會在北京正式召開,來自中國工程院、工業和信息化部、中國信息通信研究院、全國智能計算標準化工作組的領導及智算行業知名企業代表和業內專家共襄盛舉,圍繞推進算力互聯互通展開交流碰撞,凝智聚力,共話行業生態,共謀算力發展。會上成立算力互聯互通國家標準研究組... ...
  • 1.開啟hive 1.首先在master的/usr/local/soft/下啟動hadoop: master : start-all.sh start-all.sh 2.在另一個master(2)上監控hive日誌: master(2): tail -F /tmp/root/hive.log tai ...
  • 轉載自東華果汁哥 Apache DophinScheduler 運行一段時間後,實例調度日誌越來越多,需要定期清理。 SQL 錯誤 [1701] [42000]: Cannot truncate a table referenced in a foreign key constraint (`dol ...
  • 本文提供了利用數據觸發Feishu Webhook的具體操作指南,包括Webhook的設置以及編寫觸發代碼的方法,為讀者提供了實踐參考,希望能幫助解決你目前遇到的問題。 描述 用於使用數據觸發 Feishu Webhook。 例如,如果來自上游的數據是 [age: 12, name: tyrantl ...
  • 目錄一、目的二、環境三、相關概念3.1 屏幕尺寸(screen size)3.2 屏幕解析度(Resolution)3.3 像素(pixel)3.4 ppi3.5 dpi3.6 dp/dip3.7 sp四、Q&A4.1 為啥dpi = 160?4.2 為啥Android要引入dp概念?五、代碼倉庫地 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...