高考考试网
当前位置: 首页 高考资讯

wpf报表怎么做(基于WPF重复造轮子)

时间:2023-08-06 作者: 小编 阅读量: 2 栏目名: 高考资讯

SmartSQL-一款方便、快捷的数据库文档管理工具项目背景公司业务历史悠久且复杂,数据库的表更是多而繁杂,每次基于老业务做功能开发都需要去翻以前的表和业务代码。在网上搜索关于数据库文档管理工具搜到最多的就是Screw和DBCHM,一个是基于Java的工具、另一个则是bug很多,表一多就一直转圈圈进不去。所以自己就动手开发了这款SmartSQL的工具。现在将它开源分享出来,供更多的小伙伴使用和参考学习。

SmartSQL - 一款方便、快捷的数据库文档管理工具

项目背景

公司业务历史悠久且复杂,数据库的表更是多而繁杂,每次基于老业务做功能开发都需要去翻以前的表和业务代码。需要理解旧的表的用途以及包含的字段的含义,表少还好说,但是表一多这就很浪费时间,而且留下来的文档都是残缺不全,每次查一些表的含义都要捯饬很久。在网上搜索关于数据库文档管理工具搜到最多的就是Screw和DBCHM,一个是基于Java的工具、另一个则是bug很多,表一多就一直转圈圈进不去。所以自己就动手开发了这款SmartSQL的工具。

它是一款基于.Net 4.6.1、WPF开发的一款数据库文档管理,不仅支持多种数据库(SQLServer、MySQL、PostgreSQL、SQLite)表、视图、存储过程的查询管理,还支持对其进行导出成离线文档,支持的文档包括CHM、Word、Excel、PDF、HTML、Xml、Json、MarkDown等多种格式。

现在将它开源分享出来,供更多的小伙伴使用和参考学习(文末附开源地址)。

技术栈
  • .Net 4.6.1
  • WPF
  • HandyControl
  • SqlSugar
  • AvalonEdit
  • SharpVectors

HandyControl是一款非常优秀的WPF框架,做出来的页面都很漂亮,所以我们选择使用它。Nuget中引用HandyControl:

引用HandyControl

一.菜单栏

菜单栏

然后我们要实现一个基于WPF边框上的菜单栏,刚好HandyControl中有这么一个菜单栏的控件,下面就是实现菜单栏的代码:

<hc:GlowWindow.NonClientAreaContent><StackPanelMargin="25,0,0,0"><Menu HorizontalAlignment="Left"><MenuItemx:Name="SwitchMenu"Cursor="Hand"FontWeight="Bold"Foreground="{DynamicResource DarkPrimaryBrush}"Header="选择连接"><MenuItem.Icon><PathData="{StaticResource DownGeometry}"Fill="{DynamicResource DarkPrimaryBrush}"Stretch="Uniform" /></MenuItem.Icon><MenuItem.ItemTemplate><HierarchicalDataTemplate><MenuItemMargin="0"Padding="0"HorizontalAlignment="Left"VerticalAlignment="Stretch"Click="SwitchMenu_Click"Cursor="Hand"FontWeight="Normal"Header="{Binding ConnectName}"><MenuItem.Icon><svgc:SvgViewboxHorizontalAlignment="Left"IsHitTestVisible="False"Source="{Binding Icon}" /></MenuItem.Icon></MenuItem></HierarchicalDataTemplate></MenuItem.ItemTemplate></MenuItem><MenuItemName="MenuConnect"Cursor="Hand"FontWeight="Bold"Foreground="{DynamicResource DarkPrimaryBrush}"Header="文件"><MenuItem.Icon><PathData="{StaticResource FileGeometry}"Fill="{DynamicResource DarkPrimaryBrush}"Stretch="Uniform" /></MenuItem.Icon><MenuItemName="AddConnect"Click="AddConnect_OnClick"FontWeight="Normal"Header="新建连接"><MenuItem.Icon><PathData="{StaticResource NewConnectGeometry}"Fill="{DynamicResource DarkPrimaryBrush}"Stretch="Uniform" /></MenuItem.Icon></MenuItem><MenuItemName="ImportMark"Click="ImportMark_OnClick"FontWeight="Normal"Header="导入备注"><MenuItem.Icon><PathData="{StaticResource ImportGeometry}"Fill="{DynamicResource DarkPrimaryBrush}"Stretch="Uniform" /></MenuItem.Icon></MenuItem><MenuItemName="ExportDoc"Click="ExportDoc_OnClick"FontWeight="Normal"Header="导出文档"><MenuItem.Icon><PathData="{StaticResource ExportGeometry}"Fill="{DynamicResource DarkPrimaryBrush}"Stretch="Uniform" /></MenuItem.Icon></MenuItem></MenuItem><MenuItemName="MenuGroup"Click="MenuGroup_OnClick"Cursor="Hand"FontWeight="Bold"Foreground="{DynamicResource DarkPrimaryBrush}"Header="分组"><MenuItem.Icon><PathData="{StaticResource GroupGeometry}"Fill="{DynamicResource DarkPrimaryBrush}"Stretch="Uniform" /></MenuItem.Icon></MenuItem><MenuItemName="MenuSetting"Click="MenuSetting_OnClick"Cursor="Hand"FontWeight="Bold"Foreground="{DynamicResource DarkPrimaryBrush}"Header="设置"><MenuItem.Icon><PathData="{StaticResource SettingGeometry}"Fill="{DynamicResource DarkPrimaryBrush}"Stretch="Uniform" /></MenuItem.Icon></MenuItem><MenuItemName="MenuAbout"Click="MenuAbout_OnClick"Cursor="Hand"FontWeight="Bold"Foreground="{DynamicResource DarkPrimaryBrush}"Header="关于"><MenuItem.Icon><PathData="{StaticResource InfoGeometry}"Fill="{DynamicResource DarkPrimaryBrush}"Stretch="Uniform" /></MenuItem.Icon></MenuItem></Menu></StackPanel></hc:GlowWindow.NonClientAreaContent><!--工具栏菜单-->

其中有个小插曲,在WPF中是默认不支持svg图形的,所以我们需要引用一个组件:SharpVectors,它的使用方法是这样的,引用svg界面需要引入下面语句:xmlns:svgc="http://sharpvectors.codeplex.com/svgc/"然后引用要显示的svg图形:

<svgc:SvgViewboxHorizontalAlignment="Left"IsHitTestVisible="False"Source="{Binding Icon}" />

二.左侧菜单栏

然后就是左侧的菜单栏,我们要实现一个数据库的选择和数据库对象的搜索,可以搜索相关表、视图、存储过程等对象。首先我们要对我们的主界面进行一个简单的1:1:1的竖向布局,分别为左侧菜单栏、中间可以移动的分隔栏、右面的主界面:

<!--Main区域--><Grid x:Name="GridMain" Background="{StaticResource CloudDrawingBrush}"><Grid.RowDefinitions><RowDefinition/></Grid.RowDefinitions><Grid.ColumnDefinitions><ColumnDefinitionMin /><ColumnDefinition/><ColumnDefinition/></Grid.ColumnDefinitions></Grid>

现在我们要实现一个左侧树形的菜单栏,我们使用的是WPF里面的TreeView控件进行实现这样一个功能,下面是相关代码:

<DockPanel Grid.Row="0" Grid.Column="0"><hc:SimplePanel><BorderMargin="5,5,0,5"Background="{DynamicResource RegionBrush}"CornerRadius="{Binding CornerRadius}"><GridMargin="5"Background="Transparent"><TextBox x:Name="HidSelectDatabase" Visibility="Hidden" /><Grid><Grid.ColumnDefinitions><ColumnDefinition/><ColumnDefinitionMin /></Grid.ColumnDefinitions><ComboBoxx:Name="SelectDatabase"VerticalAlignment="Top"HorizontalContentAlignment="Stretch"hc:BorderElement.CornerRadius="5"hc:InfoElement.Placeholder="请选择数据库"Cursor="Hand"IsTextSearchEnabled="True"SelectionChanged="SelectDatabase_OnSelectionChanged"Text="{Binding DbName}"><ComboBox.ItemTemplate><DataTemplate><StackPanel VerticalAlignment="Center" Orientation="Horizontal"><ImageSource="/SmartSQL;component/Resources/Img/dataBase.ico" /><TextBlockMargin="5,0,0,0"HorizontalAlignment="Center"VerticalAlignment="Center"Text="{Binding DbName}" /></StackPanel></DataTemplate></ComboBox.ItemTemplate></ComboBox><ButtonName="BtnFresh"Grid.Column="2"Margin="0,0,0,0"Padding="4"VerticalAlignment="Top"Background="Transparent"BorderThickness="0"Click="BtnFresh_OnClick"Cursor="Hand"><Button.Content><Image Source="/SmartSQL;component/Resources/Img/Refresh.png" Stretch="Fill" /></Button.Content></Button></Grid><hc:SearchBarx:Name="SearchMenu"Margin="0,34,0,0"Padding="5,0,5,0"VerticalAlignment="Top"HorizontalContentAlignment="Stretch"hc:BorderElement.CornerRadius="5"hc:InfoElement.Placeholder="搜索数据表/视图/存储过程"FontShowClearButton="True"TextChanged="SearchMenu_OnTextChanged" /><TabControlx:Name="TabLeftType"Margin="0,65,0,40"SelectionChanged="TabLeftType_OnSelectionChanged"><TabItemx:Name="TabAllData"Cursor="Hand"Header="全部"IsSelected="True" /><TabItemx:Name="TabGroupData"Cursor="Hand"Header="分组"IsSelected="False" /><!--<TabItemx:Name="TabFavData"Cursor="Hand"Header="收藏"IsSelected="False" />--></TabControl><TreeViewx:Name="TreeViewTables"Margin="0,100,0,0"VerticalAlignment="Top"BorderThickness="0"ItemsSource="{Binding TreeViewData}"SelectedItemChanged="SelectedTable_OnClick"><TreeView.ItemContainerStyle><Style BasedOn="{StaticResource TreeViewItemBaseStyle}" TargetType="{x:Type TreeViewItem}"><Setter Property="IsExpanded" Value="{Binding IsExpanded}" /><Setter Property="FontWeight" Value="{Binding FontWeight}" /><Setter Property="FontSize" Value="12" /><Setter Property="Visibility" Value="{Binding Visibility}" /><Setter Property="Foreground" Value="{Binding TextColor}" /><Setter Property="Cursor" Value="Hand" /><!--禁止水平滚动条自动滚动--><EventSetter Event="RequestBringIntoView" Handler="EventSetter_OnHandler" /><Style.Triggers><Trigger Property="IsSelected" Value="True"><Setter Property="FontWeight" Value="Bold" /></Trigger></Style.Triggers></Style></TreeView.ItemContainerStyle><TreeView.ContextMenu><!--右键菜单--><ContextMenu Visibility="Visible"><MenuItemx:Name="MenuSelectedItem"Padding="5,0,5,0"VerticalAlignment="Center"Click="MenuSelectedItem_OnClick"Cursor="Hand"Header="复制对象名" /></ContextMenu></TreeView.ContextMenu><TreeView.ItemTemplate><HierarchicalDataTemplate DataType="{x:Type models:TreeNodeItem}" ItemsSource="{Binding Children}"><StackPanel Orientation="Horizontal"><svgc:SvgViewboxMargin="0,0,5,0"HorizontalAlignment="Left"Source="{Binding Icon}" /><TextBlockVerticalAlignment="Center"FontText="{Binding DisplayName}"ToolTip="{Binding DisplayName}" /></StackPanel></HierarchicalDataTemplate></TreeView.ItemTemplate></TreeView><Gridx:Name="NoDataText"Margin="0,100,0,5"HorizontalAlignment="Stretch"Background="White"Cursor="Arrow"><local:NoDataAreax:Name="NoDataAreaText"Margin="0"HorizontalAlignment="Center"ShowType="All" /></Grid><GridMargin="0"VerticalAlignment="Bottom"Visibility="Hidden"><Grid.ColumnDefinitions><ColumnDefinition/><ColumnDefinition/><ColumnDefinition/></Grid.ColumnDefinitions><Grid><ComboBoxx:Name="CbTargetConnect"VerticalAlignment="Bottom"HorizontalContentAlignment="Left"hc:InfoElement.Placeholder="目标连接"Cursor="Hand"DisplayMemberPath="ConnectName"IsTextSearchEnabled="True"SelectedValuePath="DbMasterConnectString"SelectionChanged="CbTargetConnect_OnSelectionChanged"/></Grid><Grid Grid.Column="1" Margin="5,0,0,0"><ComboBoxx:Name="CbTargetDatabase"MinVerticalAlignment="Bottom"HorizontalContentAlignment="Left"hc:InfoElement.Placeholder="目标数据库"Cursor="Hand"IsTextSearchEnabled="True"/></Grid><Grid Grid.Column="2"><!--差异比较按钮--><Buttonx:Name="BtnCompare"Margin="5,5,0,0"HorizontalAlignment="Right"hc:BorderElement.CornerRadius="6"hc:IconElement.Geometry="{StaticResource CompareGeometry}"Click="BtnCompare_OnClick"Content="差异比较"Cursor="Hand" /></Grid></Grid><!--数据加载Loading--><hc:LoadingLinex:Name="LoadingLine"Margin="0,0,0,0"Visibility="Collapsed" /></Grid></Border></hc:SimplePanel></DockPanel>

在这里我没有详细介绍底层c#的相关代码,里面逻辑有些复杂感兴趣的可以去我的开源项目中学习。在上面的左侧菜单代码中,我们使用的不仅有TreeView控件、也有ContextMenu、hc:LoadingLine等控件,还有自己写的自定义控件。

其实WPF要比WinForm好用不少,不仅支持MVVM数据绑定还支持灵活的页面渲染,自从用了WPF再也不用WinForm了。

今天分享暂时到这里,下一篇讲介绍DataGrid表格数据绑定及相关条件搜索。下面是工具的开源地址,感兴趣的可以Clone下来学习一下。码砖不易,喜欢的麻烦点下Star.

开源地址

SmartSQL: 一款方便、快捷的数据库文档查询、生成工具,支持SqlServer/MySql/PostgreSQL/SQLite数据库表结构文档查询、生成;导出文档支持CHM、Word、Excel、PDF、Html、Xml、Json、MarkDown等多种格式。

,
    推荐阅读
  • 冥婚阎王大人(冥界殿下太撩人我一次见到他)

    那黑无常打开生死簿,例行公事核对道,「萧招娣,年16,死于意外坠崖。」「是,大人。」我应声。阿绯姐姐说,她是和心上人殉了情,可那人来了冥界却又和其它女鬼跑了,她便一人住在这里。此时,我的新婚丈夫,东海龙王的小儿子敖夜公子又拿了一颗灵芝开始啃。6我原以为神仙都是宅心仁厚、普渡众生的,不过现在看来敖夜是个例外。这位小殿下丝毫不食人间烟火,甚至可以说没有自理能力。可是找来找去,却发现冥界只有忘川这一条河。

  • 空气炸锅怎么做烤芝麻饼 空气炸锅怎么做烤芝麻饼窍门

    生芝麻拌点白糖,放入锅内铺均匀。再开火5分钟,出锅倒入抹油案板,按平,趁热切好。

  • 怎样正确复印身份证(如何正确复印身份证)

    以下内容希望对你有帮助!怎样正确复印身份证日常生活工作中我们常常会使用打印机来打印或复印一些文件,例如复印身份证。下面的经验将由HP5088多功能一体打印机进行演示,一起来看看身份证该怎么复印吧。将原件打印面朝下,对准扫描仪玻璃板右前角放置。点击主屏幕上的“复印”,在微调框中进行调整。点击微调框右侧键盘按钮,输入具体份数。点击“开始黑白”或“开始彩色”即可。

  • 杏组词(杏组词有哪些)

    种子有味苦的和味甜的两种。原产亚洲西部,我国西北有栽培。时值杏花盛开,故称。以其形如杏叶,故称。借指备有杏叶鞯的马。

  • 苹果12音量键下陷自修小窍门(如何处理苹果12音量键下陷)

    主界面找到设置图标点击进入设置界面然后下拉找到然后选择,即可看到选择开启后屏幕上就会显示该按钮点击该按钮,然后选择,即可看到音量选项点击调高调低即可,今天小编就来说说关于苹果12音量键下陷自修小窍门?下面更多详细答案一起来看看吧!然后选择,即可看到。选择开启后屏幕上就会显示该按钮。

  • 毛薯的功效和作用大全(毛薯的功效和作用有哪些)

    毛薯的功效和作用大全滋补身体滋补强壮身体是毛薯的重要功效,这种食材中含有大量的高质量蛋白,还含有丰富多糖和大量碳水化合物,人们使用户能尽快把它含有的丰富营养吸收和利用,能促进人体代谢,也能增强人类身体机能,它会让人类体虚症状明显减轻,也能让人体变得更强壮更健康。

  • 我国规定盗窃案刑事立案追诉标准是怎么样规定

    2、情节标准依据刑法修正案(八)规定,多次盗窃、入户盗窃、携带凶器盗窃、扒窃的,也可以直接认定构成盗窃罪。

  • 八戒和卵二姐怎样认识的(卵二姐和猪八戒成婚一年为何就丢了性命)

    他在这段话中,透露了两个重要信息:第一、他与卵二姐结过婚。八戒曾是指挥八万水军的元帅,而卵二姐只是一名小妖。可见,他们之间是有感情的,并没有逼奸行为。这家当,其实也是嫦娥转交的,可见,嫦娥还是讲感情的。这再次说明,世间没有无缘无故的爱,也没有无缘无故的恨。原著中不可能不明不白地出现一个卵二姐,并且一年就死了,肯定是有其原因的。

  • 我的电脑删除右键菜单(电脑鼠标右键菜单管理及彻底删除方法技巧)

    右键菜单是电脑使用中会经常用到的功能,正常情况下菜单选项是很少的。以上图中的“百度一下”为例。①同时按住键,输入,点击。②依次点击、、、,点击下边文件夹,在右侧可以看到包含的文件夹是哪一个。③选中包含的文件夹,右键点击删除。关闭注册表,回到桌面,就可以看到右键菜单不显示了。不喜欢用其它软件或者嫌安装软件麻烦的小伙伴儿,可以尝试一下这种方法。

  • 冬天吃木耳有什么好处 冬天吃木耳有什么好处和坏处

    补血黑木耳被营养学家誉为“素中之荤”和“素中之王”,每100克黑木耳中含铁185毫克,它比绿叶蔬菜中含铁量最高的菠菜高出20倍,比动物性食品中含铁量最高的猪肝还高出约7倍,是各种荤素食品中含铁量最多的。减肥瘦身黑木耳中含有丰富的纤维素和一种特殊的植物胶质,能促进胃肠蠕动,促使肠道脂肪食物的排泄,减少食物脂肪的吸收,从而起到减肥作用。常吃黑木耳能起到清理消化道、清胃涤肠的作用。