功能实现主要分三步:
1、添加两个引用: WindowsFormsIntegration.dll (负责整合WPF和Windows)、System.Windows.Forms.
2、在 XAML文件中添加两个引用(粗体部分):
<Window x:Class="CrossBowDemo.MainWindow"
xmlns:wfi ="clr-namespace:System.Windows.Forms.Integration;assembly=WindowsFormsIntegration"
xmlns:wf ="clr-namespace:System.Windows.Forms;assembly=System.Windows.Forms"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="Hosting Windows Forms Control In WPF"
Height="300"
Width="650"
ResizeMode="NoResize"
Loaded="WindowLoadedHandler"
>
![](https://i-blog.csdnimg.cn/blog_migrate/d4a10af7296638c91f73d970d44e930c.gif)
</Window>
3、在XAML编码区实现你想添加的控件:
原文添加的是 DataGridView控件:
<wfi:WindowsFormsHost>
<!-- Set some properties on Windows Forms control in Xaml -->
<wf:DataGridView x:Name="dataGridView" Dock="Fill" SelectionMode="FullRowSelect"/>
</wfi:WindowsFormsHost>
效果图:
![](https://i-blog.csdnimg.cn/blog_migrate/e6c3d91e37aaf810e00e134b5b861f4a.jpeg)
本人添加的是 NumericUpDown控件:
<Grid Height="0" Margin="146,0,0,116" MinHeight="20" MinWidth="20" Name="grid1" VerticalAlignment="Bottom" HorizontalAlignment="Left" Width="50">
<wfi:WindowsFormsHost>
<wf:NumericUpDown x:Name="nupCounter" Maximum="100"></wf:NumericUpDown>
</wfi:WindowsFormsHost>
</Grid>
效果图:
![](https://i-blog.csdnimg.cn/blog_migrate/3a7549d3935bd7963c3b119940f70517.jpeg)
在本人的代码中Grid的作用相当于Web页面中用来布局的Table。 此处加上Grid是为了方便移动控件的位置。
1、添加两个引用: WindowsFormsIntegration.dll (负责整合WPF和Windows)、System.Windows.Forms.
2、在 XAML文件中添加两个引用(粗体部分):
![](https://i-blog.csdnimg.cn/blog_migrate/4a5cdc04d48eca9c93272fe4aa563c78.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/bb09630dfa034e4daeb110bf8431c8b6.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/49bb75efd82b4e63c04f93e72e97bb5a.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/bfa26e38ffe3a3e573f8388a9517296f.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/5cc45c51802d4fad74aaa9c4e06f0717.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/7f45dd323e1a170b52b94ced37a3b533.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/3900078554416ab28b4e2bf700b0f406.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/38c1e79f501c4d7e8bbcdd4e31ca52d3.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/8ee8aacc459a86dd4ef73a6d467b27cc.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/f680e1a967499cf352f0f325b04f3368.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/2bad55475ebcfb9ee4acd62f19c172f9.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/d4a10af7296638c91f73d970d44e930c.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/6a4894bc069256ffd84f7532041c77fa.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/4abf91bf98af5e8c9c30bde88c9ca9b1.gif)
3、在XAML编码区实现你想添加的控件:
原文添加的是 DataGridView控件:
![](https://i-blog.csdnimg.cn/blog_migrate/cf2a30fef0949e0c88420fa117cdf062.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/7df5038c31be28153f65a3b44171678d.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/9aac438f323f33bb7ffc7a279241aed1.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/b2fef8e391eff5516799ec8cdd2339e9.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/d3e09a2855ad7aa61b3142f5157cc440.gif)
效果图:
![](https://i-blog.csdnimg.cn/blog_migrate/e6c3d91e37aaf810e00e134b5b861f4a.jpeg)
本人添加的是 NumericUpDown控件:
![](https://i-blog.csdnimg.cn/blog_migrate/fc11ae64aecda7818b9a05df80710b7e.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/ebcf013fa3363d4910d9eec5e9b1ac7d.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/adc2777e3bb2da64ec0508e9b0371178.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/7eb8a3d7fabc18756872222b703b021f.gif)
![](https://i-blog.csdnimg.cn/blog_migrate/7e0c3a92d6693ee2ee295ca7f32af6c6.gif)
效果图:
![](https://i-blog.csdnimg.cn/blog_migrate/3a7549d3935bd7963c3b119940f70517.jpeg)
在本人的代码中Grid的作用相当于Web页面中用来布局的Table。 此处加上Grid是为了方便移动控件的位置。