UWP中實現大爆炸效果(一)

来源:https://www.cnblogs.com/blue-fire/archive/2018/05/26/9094575.html
-Advertisement-
Play Games

自從老羅搞出大爆炸之後,各家安卓都內置了類似功能。UWP怎麼能落下呢,在這裡我們就一起擼一個簡單的大爆炸實現。 ...


自從老羅搞出大爆炸之後,各家安卓都內置了類似功能。UWP怎麼能落下呢,在這裡我們就一起擼一個簡單的大爆炸實現。

閑話不說,先上效果:

因為代碼太多,所以我打算寫成一個系列,下麵是第一篇的正文:

 

首先,我們構思一下BigbangView需要哪些部分:

1、一個能多選的控制項;

2、一個能給Item佈局的面板;

3、選中之後出現的Header和Footer。

這裡我們先來實現第二項,BigbangPanel。

BigbangPanel繼承自Panel,重載MeasureOverride和ArrangeOverride方法。

MeasureOverride實現調用此方法以形成遞歸佈局更新;

ArrangeOverride為其子元素實現自定義佈局的父對象應從其佈局重寫實現調用此方法以形成遞歸佈局更新。

我們對面板子元素佈局的思路是,遍歷子元素,從左到右依次排列,若當前行子元素總寬度超過Panel寬度,則換一行從頭繼續排列。

(在此我們只實現一個簡單版,不考慮子元素的VerticalAlignment)

protected override Size MeasureOverride(Size availableSize)
{
    foreach (var child in Children)
    {
        child.Measure(availableSize);
    }

    double width = 0d, height = 0d;
    double col_width = 0d, row_height = 0d;
    int end_row_count = -1;

    for (int i = 0; i < Children.Count; i++)
    {
        if (Children[i].DesiredSize.Width + col_width > availableSize.Width)
        {
            end_row_count = i;
            height += row_height;
            width = Math.Max(width, col_width);
            col_width = 0;
            row_height = 0;
        }
        col_width += Children[i].DesiredSize.Width;
        row_height = Math.Max(row_height, Children[i].DesiredSize.Height);
    }

    //計算最後一行
    if (end_row_count != -1)
    {
        col_width = 0;
        row_height = 0;
        for (int i = end_row_count; i < Children.Count; i++)
        {
            row_height = Math.Max(row_height, Children[i].DesiredSize.Height);
            col_width += Children[i].DesiredSize.Width;
        }
        height += row_height;
        width = Math.Max(width, col_width);
    }

    return new Size(width, height);
}

  

protected override Size ArrangeOverride(Size finalSize)
{
    double x = 0d, y = 0d;
    double items_height = 0d;
    int end_count = -1;
    int row_start_index = 0;

    for (int i = 0; i < Children.Count; i++)
    {
        if (Children[i].DesiredSize.Width + x > finalSize.Width)
        {
            x = 0;
            y += items_height;

            items_height = 0;
            end_count = i;
            row_start_index = i;
        }
        Children[i].Arrange(new Rect(x, y, Children[i].DesiredSize.Width, Children[i].DesiredSize.Height));
        x += Children[i].DesiredSize.Width;
        items_height = Math.Max(items_height, Children[i].DesiredSize.Height);
    }
    return finalSize;
}

  

現在可以測試一下,新建一個頁面,添加一個ListView,修改ListView的ItemsPanel

<ListView.ItemsPanel>
    <ItemsPanelTemplate>
        <control:BigbangPanel >
            <control:BigbangPanel.ChildrenTransitions>
                <TransitionCollection>
                <AddDeleteThemeTransition />
                </TransitionCollection>
            </control:BigbangPanel.ChildrenTransitions>
        </control:BigbangPanel>
    </ItemsPanelTemplate>
</ListView.ItemsPanel>
View Code

後臺代碼:

public sealed partial class BigbangPage : Page
{
    public BigbangPage()
    {
        this.InitializeComponent();
        for(int i = 0; i < 50; i++)
        {
            list.Add(rnd.Next(100000).ToString());
        }
    }

    public static Random rnd = new Random();
    ObservableCollection<string> list { get; set; } = new ObservableCollection<string>();
}

  

然後設置ListView的ItemSource="{x:Bind list}",然後我懶得新建個項目截圖了,大佬們自行測試一下吧。

下集預告:實現可以選中的BigbangView

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 內建的 datetime 模塊 讓我們看看其他庫是如何處理這種轉換的。 Dateutil 通過 Arrow datetime 類的實例,你可以訪問 Arrow 的其他有用方法。例如,它的humanize()方法將日期時間翻譯成人類可讀的短語,就像這樣: 由於 Maya 與 datetime 庫中很多 ...
  • 1. 學習計劃 第一天 1、SpringMVC介紹 2、入門程式 3、SpringMVC架構講解 a) 框架結構 b) 組件說明 4、SpringMVC整合MyBatis 5、參數綁定 a) SpringMVC預設支持的類型 b) 簡單數據類型 c) Pojo類型 d) Pojo包裝類型 e) 自定 ...
  • 在Spring Cloud封裝的Feign中並不直接支持傳文件,但可以通過引入Feign的擴展包來實現,本來就來具體說說如何實現。 原文:http://blog.didispace.com/spring cloud starter dalston 2 4/ 服務提供方(接收文件) 服務提供方的實現比 ...
  • 目錄 1. 什麼是正則化? 2. 正則化如何減少過擬合? 3. 深度學習中的各種正則化技術: L2和L1正則化 Dropout 數據增強(Data augmentation) 提前停止(Early stopping) 4. 案例:在MNIST數據集上使用Keras的案例研究 1. 什麼是正則化? 在 ...
  • 一、單個參數: 二、多參數: 三、Map封裝多參數: 四、List封裝in: 五、多參數傳遞之註解方式示: 六、selectList()只能傳遞一個參數,但實際所需參數既要包含String類型,又要包含List類型時的處理方法: 將參數放入Map,再取出Map中的List遍歷。如下: ...
  • 什麼是進程/線程 眾所周知,CPU是電腦的核心,它承擔了所有的計算任務。而操作系統是電腦的管理者,是一個大管家,它負責任務的調度,資源的分配和管理,統領整個電腦硬體。應用程式是具有某種功能的程式,程式運行與操作系統之上。 進程 進程時一個具有一定功能的程式在一個數據集上的一次動態執行過程。進程 ...
  • import time # 我們先以當前時間為準,讓大家快速認識三種形式的時間 print (time.time()) # 時間戳 :1487130156.419527 print (time.strftime("%Y-%m-%d %X")) # 格式化的時間字元串 :'2017-02-15 11: ...
  • 博客地址:http://www.cnblogs.com/yudanqu/ 一、讀文件 要把大象裝冰箱,需要分幾步?對於讀寫文件也是這樣簡單的流程,打開文件、讀取文件和關閉文件。 描述符:文件所有操作涉及到描述符,描述符就是一個游標,讀取數據可以從游標開始向後依次讀,等等。 1、打開文件 path:要 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...