采用C#WPF實(shí)現(xiàn)自己的網(wǎng)頁(yè)瀏覽器(自定義Tab控件)

上傳人:cjc2****371 文檔編號(hào):56304968 上傳時(shí)間:2022-02-21 格式:DOC 頁(yè)數(shù):12 大?。?1.50KB
收藏 版權(quán)申訴 舉報(bào) 下載
采用C#WPF實(shí)現(xiàn)自己的網(wǎng)頁(yè)瀏覽器(自定義Tab控件)_第1頁(yè)
第1頁(yè) / 共12頁(yè)
采用C#WPF實(shí)現(xiàn)自己的網(wǎng)頁(yè)瀏覽器(自定義Tab控件)_第2頁(yè)
第2頁(yè) / 共12頁(yè)
采用C#WPF實(shí)現(xiàn)自己的網(wǎng)頁(yè)瀏覽器(自定義Tab控件)_第3頁(yè)
第3頁(yè) / 共12頁(yè)

下載文檔到電腦,查找使用更方便

10 積分

下載資源

還剩頁(yè)未讀,繼續(xù)閱讀

資源描述:

《采用C#WPF實(shí)現(xiàn)自己的網(wǎng)頁(yè)瀏覽器(自定義Tab控件)》由會(huì)員分享,可在線閱讀,更多相關(guān)《采用C#WPF實(shí)現(xiàn)自己的網(wǎng)頁(yè)瀏覽器(自定義Tab控件)(12頁(yè)珍藏版)》請(qǐng)?jiān)谘b配圖網(wǎng)上搜索。

1、采用C#WPF實(shí)現(xiàn)自己的網(wǎng)頁(yè)瀏覽器(自定義Tab控件) 采用C#WPF實(shí)現(xiàn)自己的網(wǎng)頁(yè)瀏覽器(自定義Tab控件) 時(shí)間:2012-06-12 18:51來(lái)源:CSDN 作者:chenyujing1234 點(diǎn)擊:108次 編譯平臺(tái):VS2008 + .Net Framework 3.5 語(yǔ)言: C# 此博客的目的: 以瀏覽器程序的實(shí)現(xiàn),學(xué)習(xí)自定義TabControl的方法,使之能實(shí)現(xiàn)系統(tǒng)Tab不具有的功能: (1)排列方式擴(kuò)展為:Top、Bottom、Left、Right (2)增加對(duì)TabItem的事件處理 (3) 一、瀏覽器實(shí)現(xiàn) 效果圖: 1、啟動(dòng)窗口顯示兩個(gè)按鈕 1

2、、首先導(dǎo)入我們自己寫(xiě)的控件 它們     編譯平臺(tái):VS2008 + .Net Framework 3.5   語(yǔ)言: C#   此博客的目的:   以瀏覽器程序的實(shí)現(xiàn),學(xué)習(xí)自定義TabControl的方法,使之能實(shí)現(xiàn)系統(tǒng)Tab不具有的功能:   (1)排列方式擴(kuò)展為:Top、Bottom、Left、Right   (2)增加對(duì)TabItem的事件處理   (3)   一、瀏覽器實(shí)現(xiàn)   效果圖:      1、啟動(dòng)窗口顯示兩個(gè)按鈕   1、首先導(dǎo)入我們自己寫(xiě)的控件      它們的處理函數(shù)對(duì)應(yīng)是去創(chuàng)建窗口WindowUsingItemPro

3、perty或WindowUsingItemsSourceProperty private void Items_Click(object sender, RoutedEventArgs e) { // WindowUsingItemProperty對(duì)應(yīng)于WindowUsingItemsProperty.xaml文件中的 // <Window x:Class="Test.WindowUsingItemProperty" var win = new WindowUsingIte

4、mProperty(); win.Show(); } private void ItemsSource_Click(object sender, RoutedEventArgs e) { var win = new WindowUsingItemsSourceProperty(); win.Show(); }   接下來(lái)的設(shè)計(jì)我們以WindowUsingItemProperty為例來(lái)說(shuō)明.   2、加入自定義控件W

5、pf.TabControl   在WindowUsingItemProperty窗口的界面設(shè)計(jì)文件WindowUsingItemProperty.xaml中加入自定義控件Wpf.TabControl.      3、瀏覽器界面控件布局   首先將界面分為三行:      3、1 每一行加入TextBlock與TextBox,用于輸入網(wǎng)址      當(dāng)輸入網(wǎng)址確認(rèn)后的處理是獲得瀏覽器對(duì)象并讓瀏覽器導(dǎo)航到指定的網(wǎng)址 private void textBox_KeyDown(object sender, System.Windows.Input.Ke

6、yEventArgs e) { // 按了回車鍵 if (e.Key == Key.Return) { try { // 鼠標(biāo)變成等待 Cursor = System.Windows.Input.Cursors.Wait; // 通過(guò)自己封閉的函數(shù)GetCurrentWeb

7、Browser 獲得當(dāng)前的瀏覽器 System.Windows.Forms.WebBrowser browser = GetCurrentWebBrowser(); if (browser == null) return; // 瀏覽器導(dǎo)航到指定的網(wǎng)址 browser.Navigate(textBox.Text); } finally

8、 { Cursor = System.Windows.Input.Cursors.Arrow; } } }   而瀏覽器的獲得是通過(guò)當(dāng)前TabItem來(lái)得到的 private System.Windows.Forms.WebBrowser GetCurrentWebBrowser() { // 獲得TabControl當(dāng)前選擇的TabItem

9、Wpf.Controls.TabItem item = tabControl.SelectedItem as Wpf.Controls.TabItem; if (item == null) return null; // 獲得選中的TabItem中的Content,并轉(zhuǎn)化為WindowFormsHost WindowsFormsHost host = item.Content as WindowsFormsHost; if (host == null) return null;

10、 // 獲得WindowFormsHost的Child,來(lái)得到瀏覽器對(duì)象 System.Windows.Forms.WebBrowser browser = host.Child as System.Windows.Forms.WebBrowser; return browser; }   3、2 根據(jù)自定義控件TabControl的規(guī)則加入節(jié)點(diǎn)   請(qǐng)注意空間 r: 的原因。      3、2、1 對(duì)TabControl中的TabItem顯示的三種狀態(tài)進(jìn)行設(shè)置。   目的是為

11、了看起來(lái)像IE7的樣子。      3、2、2 加入TabItem   TabItem中包括了對(duì)Header、Icon的設(shè)置,及在Item中的內(nèi)容中包裹WebI瀏覽器      在 3、1 中我們看到GetCurrentWebBrowser的獲得有兩個(gè)步驟:   (1)獲得選中的TabItem中的Content,并轉(zhuǎn)化為WindowFormsHost   (2)獲得WindowFormsHost的Child,來(lái)得到瀏覽器對(duì)象 // 獲得選中的TabItem中的Content,并轉(zhuǎn)化為WindowFormsHost Window

12、sFormsHost host = item.Content as WindowsFormsHost; if (host == null) return null; // 獲得WindowFormsHost的Child,來(lái)得到瀏覽器對(duì)象 System.Windows.Forms.WebBrowser browser = host.Child as System.Windows.Forms.WebBrowser;   3、2、2、1 瀏覽器DocumentTitleChanged、Navigated兩個(gè)事件的處理

13、   Browser_DocumentTitleChanged主要是更新TabItems的頭特性、增加一個(gè)Icon到tabItem、把瀏覽器的DocumentTitle加入到tabItem中的Head中 void Browser_DocumentTitleChanged(object sender, EventArgs e) { System.Windows.Forms.WebBrowser browser = sender as System.Windows.Forms.WebBrowser; if

14、(browser == null) return; // 更新TabItems的頭特性 Wpf.Controls.TabItem item = tabControl.SelectedItem as Wpf.Controls.TabItem; // 增加一個(gè)Icon到tabItem BitmapImage image = new BitmapImage(new Uri("pack://application:,,,/Test;component/Images/ie.ico"));

15、 Image img = new Image(); img.Source = image; img.Width = 16; img.Height = 16; img.Margin = new Thickness(2, 0, 2, 0); if (item != null) item.Icon = img; // 把瀏覽器的DocumentTitle加入到tabItem中的Head中 Te

16、xtBlock tb = new TextBlock(); tb.Text= browser.DocumentTitle; tb.TextTrimming = TextTrimming.CharacterEllipsis; tb.TextWrapping = TextWrapping.NoWrap; if (item != null) item.Header = tb; }   Browser_Navigated主要是將瀏覽器當(dāng)前的網(wǎng)址傳給textBox

17、 void Browser_Navigated(object sender, WebBrowserNavigatedEventArgs e) { // 獲得Web瀏覽器 System.Windows.Forms.WebBrowser browser = sender as System.Windows.Forms.WebBrowser; if (browser == null) return; // 將瀏覽器當(dāng)前的網(wǎng)址傳給textBox textBox.Text = browser.Url.ToString(); }

展開(kāi)閱讀全文
溫馨提示:
1: 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
5. 裝配圖網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

相關(guān)資源

更多
正為您匹配相似的精品文檔
關(guān)于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號(hào):ICP2024067431號(hào)-1 川公網(wǎng)安備51140202000466號(hào)


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務(wù)平臺(tái),本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請(qǐng)立即通知裝配圖網(wǎng),我們立即給予刪除!