本文首发地址:https://dotnet9.com/10546.html

关键功能点

  1. 抽屉式菜单

  2. 圆形进度条

Demo演示:

1. 新建项目

使用 VS 2019 的 .NET Core 3.1 WPF 项目模板,创建名为 “MobileAppUsageDashboardCore” 的项目,NuGet 引入 MaterialDesign 的两个库 MaterialDesignThemes 和 MaterialDesignColors,整个项目工程文件如下:

<Project Sdk="Microsoft.NET.Sdk.WindowsDesktop"><PropertyGroup><OutputType>WinExe</OutputType><TargetFramework>netcoreapp3.1</TargetFramework><UseWPF>true</UseWPF></PropertyGroup><ItemGroup><PackageReference Include="MaterialDesignColors" Version="1.2.2" /><PackageReference Include="MaterialDesignThemes" Version="3.0.1" /></ItemGroup></Project>

2.抽屉式菜单

前面发过不少抽屉式菜单的Demo文章,套路都是一个竖直菜单隐藏在界面左边边界之外,左边边界留一个菜单按钮,点击该按钮呼出竖直菜单,即达到抽屉式菜单效果。

本文介绍的抽屉式菜单也不外如是,VS设计界面见上图,使用的MD控件的DrawerHost.LeftDrawerContent组件,换一种方式实现,下面是抽屉菜单布局代码:

<materialDesign:DrawerHost.LeftDrawerContent><StackPanel Orientation="Vertical"><StackPanel Margin="10" VerticalAlignment="Top" Orientation="Horizontal"><TextBlockVerticalAlignment="Center"Margin="0,0,10,0">Dashboard</TextBlock><Button Style="{StaticResource MaterialDesignFlatButton}"Command="{x:Static materialDesign:DrawerHost.CloseDrawerCommand}"><materialDesign:PackIcon Kind="HamburgerMenuBack"></materialDesign:PackIcon></Button></StackPanel><StackPanel Orientation="Vertical"><Button Style="{StaticResource MaterialDesignFlatButton}" Click="todayBtnClicked">今天</Button><Button Style="{StaticResource MaterialDesignFlatButton}" Click="weekBtnClicked">本周</Button><Button Style="{StaticResource MaterialDesignFlatButton}" Click="monthBtnClicked">本月</Button></StackPanel></StackPanel>
</materialDesign:DrawerHost.LeftDrawerContent>

跟随菜单隐藏的还有一个菜单关闭按钮,见上面代码中的第一个按钮,点击按钮触发 “DrawerHost.CloseDrawerCommand” 命令可关闭抽屉式菜单。

下面的是窗体边界之内的菜单按钮,点击则展开抽屉式菜单,触发的命令是“DrawerHost.OpenDrawerCommand”:

<Button Style="{StaticResource MaterialDesignFlatButton}" Command="{x:Static materialDesign:DrawerHost.OpenDrawerCommand}"HorizontalAlignment="Left"VerticalAlignment="Top"><materialDesign:PackIcon Kind="HamburgerMenu"></materialDesign:PackIcon></Button>

3.圆形进度条

使用MD控件库实现圆形进度条,效果如下:

圆形进度条代码如下,使用的还是 ProgressBar 控件,样式使用了MD控件库的“MaterialDesignCircularProgressBar” 样式,组件加载时(Loaded事件),使用了双精度动画:

<ProgressBar Height="100"Width="100"
Value="40" Foreground="#FF68E843"x:Name="firstProgress"><ProgressBar.Style><Style TargetType="ProgressBar" BasedOn="{StaticResource MaterialDesignCircularProgressBar}"><Style.Triggers><EventTrigger RoutedEvent="Loaded"><BeginStoryboard><Storyboard><DoubleAnimation Storyboard.TargetProperty="Value" From="0" To="40"Duration="0:0:0.5"></DoubleAnimation></Storyboard></BeginStoryboard></EventTrigger></Style.Triggers></Style></ProgressBar.Style>
</ProgressBar>

4. Demo源码

整个Demo也不难,除了上面两个小功能单独简单说说外,其他的就是一般的布局代码了,主界面XAML代码如下:

<Window x:Class="MobileAppUsageDashboardCore.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:materialDesign="http://materialdesigninxaml.net/winfx/xaml/themes"xmlns:d="http://schemas.microsoft.com/expression/blend/2008"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"mc:Ignorable="d"TextElement.Foreground="{DynamicResource MaterialDesignBody}"TextElement.FontWeight="Regular"TextElement.FontSize="13"TextOptions.TextFormattingMode="Ideal"TextOptions.TextRenderingMode="Auto"Background="{DynamicResource MaterialDesignPaper}"FontFamily="{DynamicResource MaterialDesignFont}"Title="应用程序使用统计信息" Height="450" Width="800" WindowStartupLocation="CenterScreen" AllowsTransparency="True" WindowStyle="None" MouseLeftButtonDown="dragME"><materialDesign:DrawerHost x:Name="mainDrawer"><materialDesign:DrawerHost.LeftDrawerContent><StackPanel Orientation="Vertical"><StackPanel Margin="10" VerticalAlignment="Top" Orientation="Horizontal"><TextBlockVerticalAlignment="Center"Margin="0,0,10,0">Dashboard</TextBlock><Button Style="{StaticResource MaterialDesignFlatButton}"Command="{x:Static materialDesign:DrawerHost.CloseDrawerCommand}"><materialDesign:PackIcon Kind="HamburgerMenuBack"></materialDesign:PackIcon></Button></StackPanel><StackPanel Orientation="Vertical"><Button Style="{StaticResource MaterialDesignFlatButton}" Click="todayBtnClicked">今天</Button><Button Style="{StaticResource MaterialDesignFlatButton}" Click="weekBtnClicked">本周</Button><Button Style="{StaticResource MaterialDesignFlatButton}" Click="monthBtnClicked">本月</Button></StackPanel></StackPanel></materialDesign:DrawerHost.LeftDrawerContent><materialDesign:Card HorizontalAlignment="Stretch" VerticalAlignment="Stretch"><materialDesign:Card.Background><LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0"><GradientStop Color="Black" Offset="1"/><GradientStop Color="#FF474747"/></LinearGradientBrush></materialDesign:Card.Background><Grid><Grid.ColumnDefinitions><ColumnDefinition Width="2*"></ColumnDefinition><ColumnDefinition Width="*"></ColumnDefinition><ColumnDefinition Width="*"></ColumnDefinition></Grid.ColumnDefinitions><StackPanel Grid.Column="0" Orientation="Vertical" Margin="10"><StackPanel Orientation="Horizontal"><Button Style="{StaticResource MaterialDesignFlatButton}" Command="{x:Static materialDesign:DrawerHost.OpenDrawerCommand}"HorizontalAlignment="Left"VerticalAlignment="Top"><materialDesign:PackIcon Kind="HamburgerMenu"></materialDesign:PackIcon></Button><TextBlock VerticalAlignment="Center" Text="移动应用使用仪表板"></TextBlock></StackPanel><StackPanel Orientation="Horizontal"><TextBlock Text="时间段" VerticalAlignment="Center"></TextBlock><StackPanel Orientation="Horizontal" Margin="4"><RadioButton x:Name="todayRadio" Style="{StaticResource MaterialDesignTabRadioButton}"Margin="4"IsChecked="True"Content="今天"></RadioButton><RadioButton x:Name="weekRadio" Style="{StaticResource MaterialDesignTabRadioButton}"Margin="4"IsChecked="False"Content="本周"></RadioButton><RadioButton x:Name="monthRadio" Style="{StaticResource MaterialDesignTabRadioButton}"Margin="4"IsChecked="False"Content="本月"></RadioButton></StackPanel></StackPanel><UniformGrid Columns="3" Margin="0,10,0,0"><materialDesign:TransitioningContent OpeningEffect="{materialDesign:TransitionEffect Kind=ExpandIn}"><Grid><Grid.RowDefinitions><RowDefinition Height="2*"></RowDefinition><RowDefinition Height="*"></RowDefinition></Grid.RowDefinitions><ProgressBar Height="100"Width="100"Value="40" Foreground="#FF68E843"x:Name="firstProgress"><ProgressBar.Style><Style TargetType="ProgressBar" BasedOn="{StaticResource MaterialDesignCircularProgressBar}"><Style.Triggers><EventTrigger RoutedEvent="Loaded"><BeginStoryboard><Storyboard><DoubleAnimation Storyboard.TargetProperty="Value" From="0" To="40"Duration="0:0:0.5"></DoubleAnimation></Storyboard></BeginStoryboard></EventTrigger></Style.Triggers></Style></ProgressBar.Style></ProgressBar><TextBlock HorizontalAlignment="Center" VerticalAlignment="Center" Text="2 小时 / 5 小时"></TextBlock><TextBlock Grid.Row="1" Text="百度" HorizontalAlignment="Center" Margin="0,5,0,0"></TextBlock></Grid></materialDesign:TransitioningContent><materialDesign:TransitioningContent OpeningEffect="{materialDesign:TransitionEffect Kind=ExpandIn}"><Grid><Grid.RowDefinitions><RowDefinition Height="2*"></RowDefinition><RowDefinition Height="*"></RowDefinition></Grid.RowDefinitions><ProgressBar Height="100"Width="100"Value="70" Foreground="#FFE84343"x:Name="secondProgress" Margin="14,-1,13,1"><ProgressBar.Style><Style TargetType="ProgressBar" BasedOn="{StaticResource MaterialDesignCircularProgressBar}"><Style.Triggers><EventTrigger RoutedEvent="Loaded"><BeginStoryboard><Storyboard><DoubleAnimation Storyboard.TargetProperty="Value" From="0" To="70"Duration="0:0:0.5"></DoubleAnimation></Storyboard></BeginStoryboard></EventTrigger></Style.Triggers></Style></ProgressBar.Style></ProgressBar><TextBlock HorizontalAlignment="Center" VerticalAlignment="Center" Text="2 小时 / 3 小时"></TextBlock><TextBlock Grid.Row="1" Text="阿里巴巴" HorizontalAlignment="Center" Margin="0,5,0,0"></TextBlock></Grid></materialDesign:TransitioningContent><materialDesign:TransitioningContent OpeningEffect="{materialDesign:TransitionEffect Kind=ExpandIn}"><Grid><Grid.RowDefinitions><RowDefinition Height="2*"></RowDefinition><RowDefinition Height="*"></RowDefinition></Grid.RowDefinitions><ProgressBar Height="100"Width="100"Value="30" Foreground="#FFE8E843"x:Name="thirdProgress"><ProgressBar.Style><Style TargetType="ProgressBar" BasedOn="{StaticResource MaterialDesignCircularProgressBar}"><Style.Triggers><EventTrigger RoutedEvent="Loaded"><BeginStoryboard><Storyboard><DoubleAnimation Storyboard.TargetProperty="Value" From="0" To="30"Duration="0:0:0.5"></DoubleAnimation></Storyboard></BeginStoryboard></EventTrigger></Style.Triggers></Style></ProgressBar.Style></ProgressBar><TextBlock HorizontalAlignment="Center" VerticalAlignment="Center" Text="1 小时 / 4 小时"></TextBlock><TextBlock Grid.Row="1" Text="腾讯" HorizontalAlignment="Center" Margin="0,5,0,0"></TextBlock></Grid></materialDesign:TransitioningContent></UniformGrid><materialDesign:TransitioningContent OpeningEffect="{materialDesign:TransitionEffect Kind=ExpandIn,Duration=0:0:1}"><StackPanel Orientation="Horizontal" HorizontalAlignment="Center" Margin="0,80,0,0"><TextBlock Text="订阅到 " VerticalAlignment="Center"></TextBlock><materialDesign:PackIcon Kind="DotNet" Foreground="#DDFF1212" Width="100" Height="100"></materialDesign:PackIcon><TextBlock Style="{StaticResource MaterialDesignBody1TextBlock}" Text="www.dotnet9.com" VerticalAlignment="Center"></TextBlock></StackPanel></materialDesign:TransitioningContent></StackPanel><materialDesign:TransitioningContent OpeningEffect="{materialDesign:TransitionEffect Kind=SlideInFromTop}" Grid.Column="1" HorizontalAlignment="Stretch" VerticalAlignment="Stretch"><materialDesign:Card VerticalAlignment="Stretch"><materialDesign:Card.Background><LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0"><GradientStop Color="#FF09A6A6" Offset="0"/><GradientStop Color="#FF044D4D" Offset="1"/></LinearGradientBrush></materialDesign:Card.Background><Grid ><Grid.RowDefinitions><RowDefinition></RowDefinition><RowDefinition></RowDefinition></Grid.RowDefinitions><Grid Grid.Row="0" Margin="5,15,5,5"><Grid.ColumnDefinitions><ColumnDefinition Width="*"></ColumnDefinition><ColumnDefinition Width="*"></ColumnDefinition></Grid.ColumnDefinitions><StackPanel Grid.Column="0"><TextBlock Text="充电" HorizontalAlignment="Center"></TextBlock><materialDesign:TransitioningContent OpeningEffect="{materialDesign:TransitionEffect Kind=FadeIn, Duration=0:0:2}"><StackPanel Orientation="Horizontal" HorizontalAlignment="Center" Margin="0,10,0,0"><TextBlock Style="{StaticResource MaterialDesignCaptionTextBlock}" Text="4" HorizontalAlignment="Center"></TextBlock><TextBlock Text=" 次" VerticalAlignment="Center"></TextBlock></StackPanel></materialDesign:TransitioningContent><TextBlock Text="最高温度" HorizontalAlignment="Center" Margin="0,25,0,0"></TextBlock><materialDesign:TransitioningContent OpeningEffect="{materialDesign:TransitionEffect Kind=FadeIn, Duration=0:0:2}"><StackPanel Orientation="Horizontal" HorizontalAlignment="Center" Margin="0,10,0,0"><TextBlock Style="{StaticResource MaterialDesignCaptionTextBlock}" Text="40" HorizontalAlignment="Center"></TextBlock><TextBlock Text=" ℃" VerticalAlignment="Center"></TextBlock></StackPanel></materialDesign:TransitioningContent><TextBlock Text="解锁" HorizontalAlignment="Center" Margin="0,25,0,0"></TextBlock><materialDesign:TransitioningContent OpeningEffect="{materialDesign:TransitionEffect Kind=FadeIn,Duration=0:0:2}"><TextBlock Style="{StaticResource MaterialDesignCaptionTextBlock}"  Text="75" HorizontalAlignment="Center" Margin="0,10,0,0"></TextBlock></materialDesign:TransitioningContent></StackPanel><StackPanel Grid.Column="1"><TextBlock Text="开机" HorizontalAlignment="Center"></TextBlock><materialDesign:TransitioningContent OpeningEffect="{materialDesign:TransitionEffect Kind=FadeIn, Duration=0:0:2}"><StackPanel Orientation="Horizontal" HorizontalAlignment="Center" Margin="0,10,0,0"><TextBlock Style="{StaticResource MaterialDesignCaptionTextBlock}" Text="6" HorizontalAlignment="Center"></TextBlock><TextBlock Text=" 小时" VerticalAlignment="Center"></TextBlock></StackPanel></materialDesign:TransitioningContent><TextBlock Text="最后一次充电" HorizontalAlignment="Center" Margin="0,25,0,0"></TextBlock><materialDesign:TransitioningContent OpeningEffect="{materialDesign:TransitionEffect Kind=FadeIn, Duration=0:0:2}"><StackPanel Orientation="Horizontal" HorizontalAlignment="Center" Margin="0,10,0,0"><TextBlock Style="{StaticResource MaterialDesignCaptionTextBlock}" Text="4" HorizontalAlignment="Center"></TextBlock><TextBlock Text=" 小时以前" VerticalAlignment="Center"></TextBlock></StackPanel></materialDesign:TransitioningContent><TextBlock Text="通知" HorizontalAlignment="Center" Margin="0,25,0,0"></TextBlock><materialDesign:TransitioningContent OpeningEffect="{materialDesign:TransitionEffect Kind=FadeIn,Duration=0:0:2}"><TextBlock Style="{StaticResource MaterialDesignCaptionTextBlock}"  Text="350" HorizontalAlignment="Center" Margin="0,10,0,0"></TextBlock></materialDesign:TransitioningContent></StackPanel></Grid><Grid Grid.Row="1" Background="#FF086666"><Grid.RowDefinitions><RowDefinition></RowDefinition><RowDefinition></RowDefinition><RowDefinition></RowDefinition></Grid.RowDefinitions><StackPanel Orientation="Vertical" Grid.Row="0" Margin="5,15,5,5"><Grid><TextBlock Style="{StaticResource MaterialDesignCaptionTextBlock}" Text="存储" HorizontalAlignment="Left" VerticalAlignment="Center"></TextBlock><TextBlock Text="19.88 GB / 40 GB" HorizontalAlignment="Right" VerticalAlignment="Center"></TextBlock></Grid><ProgressBar Height="10" Value="19.88" Maximum="40" Margin="0,10,0,0" Foreground="#FF1E1E1E"></ProgressBar></StackPanel><StackPanel Orientation="Vertical" Grid.Row="1" Margin="5,15,5,5"><Grid><TextBlock Style="{StaticResource MaterialDesignCaptionTextBlock}" Text="相册" HorizontalAlignment="Left" VerticalAlignment="Center"></TextBlock><TextBlock Text="3 GB" HorizontalAlignment="Right" VerticalAlignment="Center"></TextBlock></Grid><ProgressBar Height="10" Value="3" Maximum="40" Margin="0,10,0,0" Foreground="#FF1E1E1E"></ProgressBar></StackPanel><StackPanel Orientation="Vertical" Grid.Row="2" Margin="5,15,5,5"><Grid><TextBlock Style="{StaticResource MaterialDesignCaptionTextBlock}" Text="视频" HorizontalAlignment="Left" VerticalAlignment="Center"></TextBlock><TextBlock Text="4 GB" HorizontalAlignment="Right" VerticalAlignment="Center"></TextBlock></Grid><ProgressBar Height="10" Value="4" Maximum="40" Margin="0,10,0,0" Foreground="#FF1E1E1E"></ProgressBar></StackPanel></Grid></Grid></materialDesign:Card></materialDesign:TransitioningContent><!--<TextBlock Style="{DynamicResource MaterialDesignTitleTextBlock}">My First Material Design App</TextBlock>--><materialDesign:TransitioningContent Grid.Column="2" HorizontalAlignment="Center" VerticalAlignment="Top" OpeningEffect="{materialDesign:TransitionEffect Kind=SlideInFromTop}"><TextBlock Style="{StaticResource MaterialDesignCaptionTextBlock}" Text="最常用的应用程序" Margin="0,15,0,0"></TextBlock></materialDesign:TransitioningContent><materialDesign:TransitioningContent Grid.Column="2"OpeningEffect="{materialDesign:TransitionEffect Kind=FadeIn}" Margin="0,40,0,0"><ItemsControl><ItemsControl.ItemsPanel><ItemsPanelTemplate><UniformGrid Columns="2"></UniformGrid></ItemsPanelTemplate></ItemsControl.ItemsPanel><materialDesign:TransitioningContent OpeningEffectsOffset="{materialDesign:IndexedItemOffsetMultiplier 0:0:0.05}" OpeningEffect="{materialDesign:TransitionEffect Kind=ExpandIn}"><Button Style="{StaticResource MaterialDesignIconButton}" ToolTip="Google Chrome"><materialDesign:PackIcon Kind="GoogleChrome" Height="24" Width="24" ></materialDesign:PackIcon></Button></materialDesign:TransitioningContent><materialDesign:TransitioningContent OpeningEffectsOffset="{materialDesign:IndexedItemOffsetMultiplier 0:0:0.05}" OpeningEffect="{materialDesign:TransitionEffect Kind=ExpandIn}"><Button Style="{StaticResource MaterialDesignIconButton}" ToolTip="YouTube"><materialDesign:PackIcon Kind="Youtube" Height="24" Width="24"></materialDesign:PackIcon></Button></materialDesign:TransitioningContent><materialDesign:TransitioningContent OpeningEffectsOffset="{materialDesign:IndexedItemOffsetMultiplier 0:0:0.05}" OpeningEffect="{materialDesign:TransitionEffect Kind=ExpandIn}"><Button Style="{StaticResource MaterialDesignIconButton}" ToolTip="Instagram"><materialDesign:PackIcon Kind="Instagram" Height="24" Width="24"></materialDesign:PackIcon></Button></materialDesign:TransitioningContent><materialDesign:TransitioningContent OpeningEffectsOffset="{materialDesign:IndexedItemOffsetMultiplier 0:0:0.05}" OpeningEffect="{materialDesign:TransitionEffect Kind=ExpandIn}"><Button Style="{StaticResource MaterialDesignIconButton}" ToolTip="Facebook"><materialDesign:PackIcon Kind="Facebook" Height="24" Width="24"></materialDesign:PackIcon></Button></materialDesign:TransitioningContent><materialDesign:TransitioningContent OpeningEffectsOffset="{materialDesign:IndexedItemOffsetMultiplier 0:0:0.05}" OpeningEffect="{materialDesign:TransitionEffect Kind=ExpandIn}"><Button Style="{StaticResource MaterialDesignIconButton}" ToolTip="Twitter"><materialDesign:PackIcon Kind="Twitter" Height="24" Width="24"></materialDesign:PackIcon></Button></materialDesign:TransitioningContent><materialDesign:TransitioningContent OpeningEffectsOffset="{materialDesign:IndexedItemOffsetMultiplier 0:0:0.05}" OpeningEffect="{materialDesign:TransitionEffect Kind=ExpandIn}"><Button Style="{StaticResource MaterialDesignIconButton}" ToolTip="YouTube Creator Studio"><materialDesign:PackIcon Kind="YoutubeCreatorStudio" Height="24" Width="24"></materialDesign:PackIcon></Button></materialDesign:TransitioningContent><materialDesign:TransitioningContent OpeningEffectsOffset="{materialDesign:IndexedItemOffsetMultiplier 0:0:0.05}" OpeningEffect="{materialDesign:TransitionEffect Kind=ExpandIn}"><Button Style="{StaticResource MaterialDesignIconButton}" ToolTip="Adobe Reader"><materialDesign:PackIcon Kind="Adobe" Height="24" Width="24"></materialDesign:PackIcon></Button></materialDesign:TransitioningContent><materialDesign:TransitioningContent OpeningEffectsOffset="{materialDesign:IndexedItemOffsetMultiplier 0:0:0.05}" OpeningEffect="{materialDesign:TransitionEffect Kind=ExpandIn}"><Button Style="{StaticResource MaterialDesignIconButton}" ToolTip="Camera"><materialDesign:PackIcon Kind="Camera" Height="24" Width="24"></materialDesign:PackIcon></Button></materialDesign:TransitioningContent></ItemsControl></materialDesign:TransitioningContent></Grid></materialDesign:Card></materialDesign:DrawerHost>
</Window>

5. 主界面后台代码

代码不多,比较简单,源码如下:

using System;
using System.Windows;
using System.Windows.Input;namespace MobileAppUsageDashboardCore
{/// <summary>/// Interaction logic for MainWindow.xaml/// </summary>public partial class MainWindow : Window{public MainWindow(){InitializeComponent();}private void todayBtnClicked(object sender, RoutedEventArgs e){mainDrawer.IsLeftDrawerOpen = false;todayRadio.IsChecked = true;monthRadio.IsChecked = false;weekRadio.IsChecked = false;}private void weekBtnClicked(object sender, RoutedEventArgs e){mainDrawer.IsLeftDrawerOpen = false;todayRadio.IsChecked = false;weekRadio.IsChecked = true;monthRadio.IsChecked = false;}private void monthBtnClicked(object sender, RoutedEventArgs e){mainDrawer.IsLeftDrawerOpen = false;todayRadio.IsChecked = false;weekRadio.IsChecked = false;monthRadio.IsChecked = true;}private void dragME(object sender, MouseButtonEventArgs e){try{DragMove();}catch (Exception){//throw;}}}
}

3. Demo展示、源码下载

前面演示的Demo源码已经全部贴上。

参考视频:WPF Dashboard UI - Material Design [Speed Design]

参考源码:WPF-Dashboard-UI-Material-Design-Concept

应用程序使用统计信息 – .NET CORE(C#) WPF界面设计相关推荐

  1. 信息发布类网站后台界面设计一点思考(整体布局)

    源起:做过,也用过一些信息发布系统的后台.特别最近,用的又比较多.曾经觉得,后台要设计的好用,让内容编辑来提意见来设计就好了.但是发现没那么简单. 因为,很多内容编辑,不懂得编程或者美工设计,一个后台 ...

  2. python爬网页统计数据_Python爬取阿拉丁统计信息过程图解

    背景 目前项目在移动端上,首推使用微信小程序.各项目的小程序访问数据有必要进行采集入库,方便后续做统计分析.虽然阿拉丁后台也提供了趋势分析等功能,但一个个的获取数据做数据分析是很痛苦的事情.通过将数据 ...

  3. python执行结果在gui界面显示_Python PyQt5运行程序把输出信息展示到GUI图形界面上...

    概述:最近在赶毕业设计,遇到一个问题,爬虫模块我用PyQt5写了图形界面,为了将所有的输出信息都显示到图形界面上遇到了问题. 先演示一下效果最终效果吧,下面两张图用来镇楼.可以看到我们图形界面和程序运 ...

  4. JS 中国象棋程序(0):界面设计

    "JavaScript中国象棋程序" 这一系列教程将带你从头使用JavaScript编写一个中国象棋程序.希望通过这个系列,我们对博弈程序的算法有一定的了解.同时,我们也将构建出一 ...

  5. 展示型app用什么型号服务器,APP版式设计教程:信息展示型UI界面设计的四种类型...

    作为一名专业的APP设计师,版式设计也是我们日常设计当中的一项基本功. 那你到底对版式设计有多深的理解呢? 你现在可以摸着旁边妹子的手说,什么是版式设计ma ? 版式设计又分为哪几种呢? 这个时候妹子 ...

  6. pta7-3 统计不及格人数_编写程序,统计学生的成绩信息

    编写一程序,统计学生的成绩信息(成绩信息保存在文件Score.dat中) 要求: 1. 能按总分,数学成绩,英语成绩,计算机成绩分别排序 2. 能分别统计数学,英语,计算机中不及格人数 3. 能按学号 ...

  7. PLSQL_统计信息系列10_统计信息过旧导致程序出现性能问题

    2014-11-15 Created By BaoXinjian 一.摘要 在性能的稳定数据库中,所有的job都需要在一定时间内完成 以前在一个银行系统中,突然某一个job原本在30minutes内完 ...

  8. oracle事务数统计,【学习笔记】Oracle数据库收集统计信息的两种方法介绍案例

    天萃荷净 分享一篇关于Oracle数据库收集统计信息的办法,Oracle DBMS_STATS与Oracle analyze使用方法案例 今天群里面讨论DBMS_STATS和analyze,这里进行了 ...

  9. SQL SERVER的统计信息

    可以看到,统计信息分为三部分内容,头信息,数据字段选择性及直方图. 2.1 头信息 列名 说明 Name 统计信息的名称. Updated 上次更新统计信息的日期何时间 Rows 预估表中的行数,不一 ...

最新文章

  1. MindSpore网络模型类
  2. Subversion客户端认证凭证缓存总结
  3. 七种与輻射和平相處的妙法 - 生活至上,美容至尚!
  4. Win32基础知识5 - Win32汇编语言006
  5. leetcode 64. 最小路径和(递归 / 动态规划解法图解)(Java版)
  6. Foxmail添加微软最新outlook.com邮箱解决方案
  7. python 初始化数组_Python里面这些点,据说90%的新手都会一脸懵逼
  8. python怎么标注折线图_利用python画折线图
  9. Oracle数据库的下载安装教程
  10. 时间序列模型 (六):平稳时间序列模型 :自回归AR 、移动平均 MA 、ARMA 模型
  11. 时间复杂度为O(n)的排序(JAVA)
  12. 计算机主板用料,【技嘉H55评测】主板供电篇——CPU辅助电源-中关村在线
  13. PS案例提升 【第1节】抠图--薄、透、露的朦胧美 案例二:扣取婚纱新娘
  14. 小程序跳转至企业微信客服wx.openCustomerServiceChat
  15. java比较两个对象_java判断两个对象是否相等的方法
  16. mysql特殊符号无法储存_解决MYSQL数据库无法保存emoji表情及特殊符号问题
  17. photoshop中调整橡皮擦的像素大小
  18. Gif动图如何在线编辑?教你三步在线编辑动图
  19. 基于Arduino IDE开发的ESP8266(ESP-12F)项目4 ——中断及高级输入输出
  20. SCARA工业机器人

热门文章

  1. 如何快速编写代码及注意点 - 学习/总结
  2. HPL-用于分布式内存计算机的高性能Linpack基准的便携式实现测试
  3. 最新JDK版本JDK7U51以及帮助文档下载
  4. 莫兰指数(Moran's I)讲解
  5. 如何快速实现学生身份到职场人的转变的思考
  6. 广告点阵屏和熟悉字模软件的使用
  7. pip与 conda的区别
  8. css轮播图底部小点点位置问题
  9. 申请Zanox 德国联盟攻略
  10. Oracle 创建视图、修改表的约束 创建级联删除触发器、存储过程