WPF控制項操作之改變父控制項之TabControl示例

来源:https://www.cnblogs.com/usen521/archive/2020/03/24/12557092.html
-Advertisement-
Play Games

昨天做個簡單的演示,想偷懶,但同時又想用WPF再做一個,稍微提高一下演示的美觀,助力拿下訂單。所以,在做完WinForm後,又做了一個wpf版本的,但控制項在不同容器之間的移動,winform和wpf差別很大,winform很簡單、直觀。但wpf就很坑了。 於是昨天下午網上搜了一些“答案”,都不能解決 ...


昨天做個簡單的演示,想偷懶,但同時又想用WPF再做一個,稍微提高一下演示的美觀,助力拿下訂單。所以,在做完WinForm後,又做了一個wpf版本的,但控制項在不同容器之間的移動,winform和wpf差別很大,winform很簡單、直觀。但wpf就很坑了。

於是昨天下午網上搜了一些“答案”,都不能解決問題。今天又重新理了一下頭緒,非常簡單的實現了,並沒有用到網上那些很裝逼的答案。

效果圖

,要實現的效果就是通過TabControl的Select事件,讓最子層的界面在第二層TabControl的不同TAbItem之間移動,而第二層TabControl又在最頂層的TabControl的TabItem之間移動。偽造每個頁面都有內容的假象,並且用黑體字元串來標識不同的TabItem。

XAML代碼

 1 <TabControl Grid.Row="1" Name="tabControl1" SelectedIndex="0" SelectionChanged="tabControl1_SelectionChanged">
 2             <TabItem Header="生產模式">
 3                 <TabControl x:Name="tabControl2" SelectedIndex="0" SelectionChanged="tabControl1_SelectionChanged">
 4                         <TabItem Header="單站查詢">
 5                             <DockPanel x:Name="container" LastChildFill="True">
 6                                 <Grid DockPanel.Dock="Top">
 7                                     <Grid.RowDefinitions>
 8                                         <RowDefinition/>
 9                                         <RowDefinition/>
10                                     </Grid.RowDefinitions>
11                                     <Grid.ColumnDefinitions>
12                                         <ColumnDefinition Width="2*"/>
13                                         <ColumnDefinition Width="2*"/>
14                                         <ColumnDefinition Width="4*"/>
15                                         <ColumnDefinition Width="1*"/>
16                                     </Grid.ColumnDefinitions>
17                                     <Label Grid.Row="0" Grid.Column="0" Content="不良品查詢方式"/>
18                                     <ComboBox Grid.Row="1" Grid.Column="0" SelectedIndex="0">
19                                         <ComboBoxItem Content="按固定時間查詢"/>
20                                         <ComboBoxItem Content="按批次查詢"/>
21                                         <ComboBoxItem Content="按產品型號查詢"/>
22                                     </ComboBox>
23                                     <Label Grid.Row="0" Grid.Column="1" Content="選擇日期"/>
24                                     <DatePicker Grid.Row="1" Grid.Column="1"/>
25                                     <Label Grid.Row="0" Grid.Column="2" Grid.RowSpan="2" x:Name="lblTitle" Background="AliceBlue" FontWeight="ExtraBold" FontSize="20" VerticalAlignment="Center" HorizontalAlignment="Center"/>
26                                     <Button Content="生成報表" Grid.Column="3" Grid.Row="1"/>
27                                 </Grid>
28                                 <DataGrid x:Name="grid"/>
29                             </DockPanel>
30                         </TabItem>
31                         <TabItem Header="所有數據查詢"></TabItem>
32                         <TabItem Header="不良數據查詢"></TabItem>
33                         <TabItem Header="巡檢件查詢"></TabItem>
34                         <TabItem Header="報廢記錄查詢"></TabItem>
35                         <TabItem Header="返工記錄查詢"></TabItem>
36                         <TabItem Header="MES數據查詢"></TabItem>
37                         <TabItem Header="產量查詢"></TabItem>
38                 </TabControl>
39             </TabItem>
40             <TabItem Header="補單模式">
41             </TabItem>
42         </TabControl>

c#代碼

 1         private void tabControl1_SelectionChanged(object sender, SelectionChangedEventArgs e)
 2         {
 3             TabControl tab = sender as TabControl;
 4             TabItem tabItem = tab.SelectedItem as TabItem;
 5             if (tabItem != null)
 6             {
 7                 if (tab == tabControl1)
 8                 {
 9                     (tab.SelectedItem as ContentControl).Content = tabControl2;
10                 }
11                 else
12                 {
13                     (tab.SelectedItem as ContentControl).Content = container;
14                 }
15             }
16 
17             if (tabControl1.SelectedIndex != -1 && tabControl2.SelectedIndex != -1)
18             {
19                 lblTitle.Content = (tabControl1.SelectedItem as TabItem).Header + "->" + (tabControl2.SelectedItem as TabItem).Header;
20             }
21         }

 


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

-Advertisement-
Play Games
更多相關文章
  • 記錄表達式樹的學習過程 表達式樹將代碼表示為可以檢測、修改、或執行的一種結構,一種定義代碼的結構。 表達式樹是代碼的完整表示形式:可以看到任何子表達式的值。 可以看到方法和屬性名稱。 可以看到任何常數表達式的值。 還可以將自己轉換為可執行的委托,並執行代碼。 通過表達式樹 API,可創建幾乎任何有效 ...
  • 在大多數情況下,Blazor將與以前相同的線路上重新連接到伺服器。但有時無法重新連接,需要重新載入web瀏覽器才能使網站重新工作。如果伺服器回收應用程式池,則需要手動重新載入頁面在沒有調試的情況下在IIS Express上開發和運行站點時,使用自動重新載入可以加快開發過程。只需保存您的文件並切換到w ...
  • 不論是連接Access資料庫或是SQL Server資料庫,“未在本地電腦上註冊“Microsoft.ACE.OLEDB.12.0”提供程式。”這個問題從Office2016開始,困擾了我好多年。 我的軟體版本:Win10(x64)版本系統 + Office 2019(x64)版本軟體 + Vis ...
  • 至於基礎知識,大神們已經總結的非常好了,這裡直接上鏈接 參考文章: https://blog.csdn.net/TVwR8OfV0P/article/details/80155333 https://www.cnblogs.com/refuge/category/1395422.html (Rabb ...
  • String的常見方法 String 變數的聲明方式 C 中字元串常見的聲明有兩種: 1. 直接使用字面值 即 2. 使用構造器,即 string 的特點 (字元串)在大多數開發語言中屬於不可變數,任何針對String的修改都會生成一個新的字元串。為什麼會如此呢,究其原因是String在記憶體中以類似 ...
  • 在微信開發H5頁面的時候,往往藉助於Weui或者Jquery Weui等基礎上進行界面效果的開發,由於本人喜歡在Asp.net的Web界面上使用JQuery,因此比較傾向於使用 jQuery WeUI,本篇隨筆結合官方案例和自己的項目實際開發過程的經驗總結,對在H5頁面開發過程中設計到的界面控制項進行... ...
  • 一、asp.net mvc 通用許可權管理系統(響應佈局)源碼主要以下特點: AngelRM(Asp.net MVC)是基於asp.net(C#)MVC+前端bootstrap+ztree+lodash+jquery技術,採用bootstrap為前臺開發展示UI,Web Api主要負責前端的邏輯交互, ...
  • 內托管模式超時 不允許請求謂詞、直接請求無響應、拒絕服務405 Net Core IIS 部署 進程內托管 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...