基于C#使用winform技术的游戏平台的实现【C#课程设计】

基于C#使用winform技术的游戏平台的实现【C#课程设计】

  • 说明
    • 项目结构
    • 项目运行截图及实现的功能
  • 部分代码一些说明(个人觉得一些难点的说明)
    • 一、ListView ,ImageList 的综合使用
    • 二、图片上传以及picturebox 图片的动态替换
    • 三、图表插件的使用
    • 四、SQL工具类封装
    • 五、高德地图天气API的使用
  • 数据库设计部分
  • 完整代码资源

说明

今天,也是刚刚答完辩,终于可以将自己写的代码放到CSDN上啦,这个是开学之前就做好的一个项目,然后就是简单的使用winform做了一个CS结构的课设,实现了基础的crud以及扩展的导入导出Excel和图表控件及高德地图天气API接口的使用。使用了一些基本的控件和特殊一点的控件就是ImageList 和 listView (因为我们课上没有学过,所以觉得比较特殊)

项目结构

然后下面的话,是整体项目的一个结构(简单分了一下包,DataAccess就是数据接入层dao,Entity就是对应的一些实体类,Resources是项目的一些静态资源,Utils下的话是我自己做的一些工具类,Views的是winform一些不同功能的窗体区分

在这里插入图片描述

项目运行截图及实现的功能

  1. 登录和注册
    在这里插入图片描述
    在这里插入图片描述
    账号的密码使用md5进行加密

  2. 登录首页
    在这里插入图片描述
    这里的话,实现了一个侧边栏的封装和自定义最小化和最大化按钮,然后中间主体是一个高德地图的天气API,具体使用我会在后面的文章列出,然后还有个底部的计时器实现时间刷新功能。

  3. 用户的个人信息修改,头像上传及重置功能
    在这里插入图片描述

  4. 游戏商城列表查看(用户端)
    在这里插入图片描述
    这里主要使用的两个控件就是listView和imageList,以及Panel布局组件(当我点选左侧的游戏时,右侧的游戏详情会进行显示,当然多条件查询也是可以的哈)

  5. 个人游戏仓库查看
    在这里插入图片描述
    这里的话和上面那个也差不多,就是自己买的游戏,用到的控件也是imageList和那个listView

  6. 管理员账号的登录(游戏管理)
    在这里插入图片描述
    管理员账号登录,右侧显示的侧边栏内容是不一样的,实现了数据的导入导出(可以将Excel中的内容导入到数据库中),然后就是一些crud操作。

  7. 用户信息管理
    在这里插入图片描述
    和上面的游戏管理功能基本差不多,就不一一赘述啦。

  8. 数据分析
    在这里插入图片描述
    这个的话,是使用了一些livecharts的图表控件来做的,算是一点点创新把。

部分代码一些说明(个人觉得一些难点的说明)

一、ListView ,ImageList 的综合使用

在C#中,ListView是一个常用的控件,用于在Windows窗体应用程序中显示数据。它可以以多种方式呈现数据,包括大图标、小图标、列表和详细信息。
在C#中,ImageList是一个用于存储图像集合的类。它提供了一种方便的方式来管理和使用一组图像,通常用于在用户界面控件中显示图像列表。

private void DrawLvGame(DataSet ds)
{// 先清空,防止计时器一直添加this.listViewGames.Items.Clear();this.imageList1.Images.Clear(); //清空图片数组// 渲染到listView中if (ds != null && ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0){listViewGames.View = View.LargeIcon; //设置listview为大图标模式listViewGames.LargeImageList = imageList1;// 设置listview的图片数组listViewGames.Visible = true;// 开始绘制控件,暂时挂起lvlistViewGames.BeginUpdate();for (int i = 0; i < ds.Tables[0].Rows.Count; i++){ListViewItem lv = new ListViewItem();lv.ImageIndex = i;lv.Text = ds.Tables[0].Rows[i][0].ToString();// 设置图标this.imageList1.Images.Add(Image.FromFile(baseImageUrl + ds.Tables[0].Rows[i][1].ToString()));listViewGames.Items.Add(lv);}// 结束绘制listViewGames.EndUpdate();}
}

说明:

  1. 通过 listview对象.view 的方式可以设置ListView的显示方式,其中View对象是一个枚举类,列举了可供listview选择的5种方式,我选择大图标模式(显示效果好看一点)

在这里插入图片描述

  1. 我这里的需求是,需要将数据库的游戏信息读取出来,然后动态的去显示对应的图片,所以需要通过listViewGames.LargeImageList = imageList1 去绑定一个图片数组(imageList1 为 ImageList控件,listViewGames 为ListView控件)

在这里插入图片描述

  1. BeginUpdate() 和 EndUpdate()两个方法,方法用于控制 ListView 的更新。它们的作用是在进行大量添加、删除或修改 ListView 中的项目时,提高性能和用户界面响应速度。
  2. ImageList 添加数据,通过ImageList对象.Images.Add(Image对象),这里有个需要注意的点,应为我们从数据库中读取的图片路径为一个字符串,所以我们需要通过这个字符串转换为Image对象,然后Image类中提供了一个方法 Image.FromFile(path),将文件路径对应的图片读取为Image对象。
  3. 综上所述,我只需要在获取到游戏列表数据时,去遍历,将图片路径添加到imageList控件的项目中,然后在ListView控件中添加ListViewItem即可。

二、图片上传以及picturebox 图片的动态替换

文件框选择 OpenFileDialog 完成文件上传到本地磁盘功能

private void btnChangeAvatr_Click(object sender, EventArgs e)
{OpenFileDialog fileDialog = new OpenFileDialog();fileDialog.Multiselect = true; fileDialog.Title = "请选择文件";fileDialog.Filter = "所有文件(*jpg*)|*.jpg*"; //设置要选择的文件的类型if (fileDialog.ShowDialog() == DialogResult.OK){// 获取图片上传的路径string localFilePath = fileDialog.FileName;//格式化处理,提取文件名 数据库要存的urlstring savePath = localFilePath.Substring(localFilePath.LastIndexOf("\\") + 1);// 存储到本地目录中 如果本地不存在该图片,那么就上传if (!File.Exists(baseImageUrl + savePath)){File.Copy(localFilePath, baseImageUrl + savePath, false);}// 数据库更新操作 传递nickname和新的图片url即可int flag = UserDataAccess.GetInstance().UpdateUserAvatar(user.Nickname, savePath);if (flag > 0){MessageBox.Show("更新成功!!\n本地存储图片路径为:" + baseImageUrl + savePath);RefreshWindow();}else{MessageBox.Show("修改失败!");}}}

说明:

  1. c#中的资源图片通常存放于当前项目的Resources,若想在项目中使用图片,则必须将图片上传到Resources目录下。
  2. 通常上传文件获取文件的路径是一个完整路径,而我们只需要它的文件名,所以通过Substring(localFilePath.LastIndexOf(“\”) + 1) 来截取最后一级目录即文件名
  3. 文件上传一个简单的去重校验 File.Exists(path),返回 true | false,
  4. 文件上传 File.copy(源路径,目的路径,是否重写【true|false】)

文件动态替换功能

Bitmap bitmap = new Bitmap(baseImageUrl + user.Avatar);
this.picAvatar.BackgroundImage = bitmap;

说白了就两行代码,PictureBox.BackgroundImage 的值可以是一个 Bitmap对象(Bitmap对象继承自Image对象),而 Bitmap对象可以通过类似File类的方式(通过路径产生)。

在这里插入图片描述

在这里插入图片描述

三、图表插件的使用

因为之前写过一篇类似的博客 ,我就直接贴博客链接了winform .net6 和 framework 的图表控件,为啥项目中不存在chart控件,该如何解决?

因为我这个项目创建的时候,没注意,然后创建的项目是 .net6版本的,所以下面就介绍 ScottPlot 这个图表插件的使用(看文档就基本ok了),scottPlot 官网链接:。

  1. 进入官网,选择QuickStart快速开始,然后选择winform的就行,看看快速入门的例子
    在这里插入图片描述

  2. 看完之后,就根据自己的需求去选择不同的图表进行配置 https://scottplot.net/cookbook/4.1/,查看它的cookbook就好啦
    一个柱状图的demo https://scottplot.net/cookbook/4.1/,感觉着配置都基本不用说,反正按照配置项去获取对应的数据就可以生成一个动态的图表了。

在这里插入图片描述

下面贴一张我的SQL图表例子:

在这里插入图片描述

四、SQL工具类封装

SQL工具类,我使用的是一个单例模式
提供一个静态类对象,一个私有构造器,以及一个获取类对象的静态方法。这样就可以避免每次操作数据库去new一个对象了,至始至终都是一个对象在操作。

using GamePlantForm.Dao;
using GamePlantForm.Entity;
using GamePlantForm.Utils;
using Microsoft.VisualBasic.ApplicationServices;
using System;
using System.Collections.Generic;
using System.Data;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace GamePlantForm.DataAccess
{public class GameDataAccess{// 使用单例模式private static GameDataAccess instance;private GameDataAccess() { }public static GameDataAccess GetInstance(){return instance ?? (instance = new GameDataAccess());}SqlConnection conn;SqlCommand comm;SqlDataAdapter adapter;/// <summary>/// 数据库资源释放/// </summary>private void Dispose(){if (adapter != null){adapter.Dispose();adapter = null;}if (comm != null){comm.Dispose();comm = null;}if (conn != null){conn.Close();conn.Dispose();conn = null;}}/// <summary>/// 数据库链接/// </summary>private bool DBConnection(){// string connStr = "Data Source=.\\SQLEXPRESS;database=game_plantform;uid=sa;pwd=123456";if (conn == null){conn = new SqlConnection(connStr);}try{conn.Open();return true;}catch (Exception ex){return false;}}}
}

五、高德地图天气API的使用

这个的话,重点在于自己找到对应的API接口文档,然后发送请求,用几个实体类对接一些想要的数据即可。我这里只放一下自己写的发送请求的代码。

tips:注意,一定使用自己申请的密钥哇

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Net.Http;
using System.Threading.Tasks;
using GamePlantForm.Entity;namespace GamePlantForm.Utils
{// 自定义天气接口工具类internal class WeatherRobin{private readonly HttpClient _httpClient;public WeatherRobin(){_httpClient = new HttpClient();}// 150200public async void GetWeatherAsync(string cityName,Label labprovince,Label labcity, Label labadcode, Label labweather,Label labtemperature, Label labwinddirection, Label labwindpower, Label labhumidity, Label labreporttime){var response = await _httpClient.GetAsync("https://restapi.amap.com/v3/weather/weatherInfo?city="+cityName+"&key=自己的天气密钥");var content = await response.Content.ReadAsStringAsync();// 1. 将获取到的json转换为数组RootObject obj = Newtonsoft.Json.JsonConvert.DeserializeObject<RootObject> (content);// 2. 将获取到的数据,填充到传递过来的实体类对象中labprovince.Text += ":"+ obj.lives[0].province;labcity.Text += ":" + obj.lives[0].city;labadcode.Text += ":" + obj.lives[0].adcode;labweather.Text += ":" + obj.lives[0].weather;labtemperature.Text += ":" + obj.lives[0].temperature+"℃";labwinddirection.Text += ":" + obj.lives[0].winddirection;labwindpower.Text += ":" + obj.lives[0].windpower+"级";labhumidity.Text += ":" + obj.lives[0].humidity;labreporttime.Text += ":" + obj.lives[0].reporttime;}}
}

数据库设计部分

在这里插入图片描述
ER图之间的关系,有点偷懒了,不想画啦QAQ,这个SQL资源需要的可以找我拿

完整代码资源

完整代码,可以私信找我发,也可以通过这篇文章的绑定资源去下载。

tips:本人只是个又菜又爱分享的小白,如果这篇文章可以帮助到你,帮我点个👍,哈哈哈!
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/170031.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

09-React路由使用(React Router 6)

9-React Router 6的使用 1.概述 React Router 以三个不同的包发布到 npm 上&#xff0c;它们分别为&#xff1a; react-router: 路由的核心库&#xff0c;提供了很多的&#xff1a;组件、钩子。react-router-dom: 包含react-router所有内容&#xff0c;并添加一些专门用于 DOM …

使用jdbc技术连接数据库

连接数据库 <dependencies><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.28</version><scope>compile</scope></dependency> </dependencies> g…

Mac电脑怎么在Dock窗口预览,Dock窗口预览工具DockView功能介绍

DockView是一款Mac电脑上的软件&#xff0c;它可以增强Dock的功能&#xff0c;让用户更方便地管理和切换应用程序。 DockView的主要功能是在 DockQ&#xff0c;栏上显示每个窗口的缩略图&#xff0c;并提供了一些相关的操作选项。当用户将鼠标悬停在Dock栏上的应用程序图标上时…

mount: /dev/sr0 is write-protected, mounting read-only

报错 原因 只有只读权限&#xff0c;没有写权限 解决 在终端中执行以下命令。 id user_name将 user_name 替换为您的用户名以获取您的 uid 然后执行此命令 sudo mount -o rw,uidyour_uid_here /dev/cdrom /mnt将 your_uid 替换为上面找到的用户的 uid。

Python深度学习实战-基于Sequential方法搭建BP神经网络实现分类任务(附源码和实现效果)

实现功能 第一步&#xff1a;导入模块&#xff1a;import tensorflow as tf 第二步&#xff1a;制定输入网络的训练集和测试集 第三步&#xff1a;搭建网络结构&#xff1a;tf.keras.models.Sequential() 第四步&#xff1a;配置训练方法&#xff1a;model.compile()&#x…

如何在不损失质量的情况下调整图像大小

如何在不损失质量的情况下调整图像大小 如果您在线工作&#xff0c;就会知道图像质量对于呈现干净专业的外观有多么重要。 库存图像和免版税图像很容易找到&#xff0c;但是如何在不损失质量的情况下调整图像大小以使其适合您的目的&#xff1f; 无论您是想将图片用于博客文…

Python 自动化(十五)请求和响应

准备工作 将不同day下的代码分目录管理&#xff0c;方便后续复习查阅 (testenv) [rootlocalhost projects]# ls mysite1 (testenv) [rootlocalhost projects]# mkdir day01 day02 (testenv) [rootlocalhost projects]# cp -rf mysite1/ day01/ (testenv) [rootlocalhost proj…

webrtc-stream编译报错记录

磁盘空间不足错误 错误信息 677.2 fatal: cannot create directory at blink/web_tests/external/wpt: No space left on device说明&#xff1a;这个错误是由于本地在配置docker资源时所给磁盘空间太小导致&#xff0c;直接根据镜像大小合理分配资源大小即可 pushd和popd执…

C# Winform编程(9)网络编程

网络编程 HTTP网络编程IPAddress IP地址类WebClient类WebRequest类和WebResponse类 WebBrowser网页浏览器控件TCP网络编程TcpClient类TcpListener类NetworkStream类Socket类 HTTP网络编程 IPAddress IP地址类 IPAddress类代表IP地址&#xff0c;可在十进制表示法和实际的整数…

第十三章 枚举类型与泛型总结

13.1 枚举类型 枚举类型是一种特殊的数据类型&#xff0c;它允许一个变量只能取预先定义好的一组离散值中的一个。在许多编程语言中&#xff0c;枚举类型通常用于表示具有一定范围内固定取值的情况&#xff0c;例如星期几、月份等。 13.1.1使用枚举类型设置常量 在Java中&am…

【linux系统】服务器安装Pycharm

文章目录 安装pycharm步骤1. 进入pycharm官网2. 上传到服务器3. 安装过程 摘要&#xff1a;pycharm是Python语言的图形化开发工具。因为如果在Linux环境下的Python shell 中直接进行编程&#xff0c;其无法保存与修改&#xff0c;在大型项目当中这是很不方便的&#xff0c;而py…

大学兼职教师管理系统 用JAVA语言开发

一、项目介绍 基于VueSpringBootMySQL的大学兼职教师管理系统包含学生管理、教师管理、课程档案管理、课程评价管理、课程考勤管理、授课管理、课程成绩管理教龄/薪资分析可视化图表&#xff0c;还包含系统自带的用户管理、部门管理、角色管理、菜单管理、日志管理、数据字典管…

13.4web自动化测试(Selenium3+Java)

一.定义 用来做web自动化测试的框架. 二.特点 1.支持各种浏览器. 2.支持各种平台(操作系统). 3.支持各种编程语言. 4.有丰富的api. 三.工作原理 四.搭环境 1.对照Chrome浏览器版本号,下载ChromeDriver,配置环境变量,我直接把.exe文件放在了jdk安装路径的bin文件夹下了(j…

【剑指Offer】:循环有序列表的插入(涉及链表的知识)

给定循环单调非递减列表中的一个点&#xff0c;写一个函数向这个列表中插入一个新元素 insertVal &#xff0c;使这个列表仍然是循环升序的 给定的可以是这个列表中任意一个顶点的指针&#xff0c;并不一定是这个列表中最小元素的指针 如果有多个满足条件的插入位置&#xff0c…

IMU预积分的过程详解

一、IMU和相机数据融合保证位姿的有效性&#xff1a; 当运动过快时&#xff0c;相机会出现运动模糊&#xff0c;或者两帧之间重叠区域太少以至于无法进行特征匹配&#xff0c;所以纯视觉SLAM对快速的运动很敏感。而有了IMU&#xff0c;即使在相机数据无效的那段时间内&#xff…

postman接收后端返回的文件流并自动下载

不要点send&#xff0c;点send and download&#xff0c;postman接受完文件流会弹出文件保存框让你选择保存路径

触摸屏与施耐德PLC之间MODBUS无线通讯

一、 硬件连接 1、PLC通讯接口说明&#xff1a; 2、通讯电缆图&#xff1a; 二、PLC设置 1. 配置端口&#xff1a; 双击串行线路—弹出右侧设置窗口---设置串口通讯参数 2. 添加MODBUS协议。 ① 右击串口线路&#xff0c;选择添加设备&#xff1a; ② 选择现场总线&#xf…

小知识(6) el-table表格选中行和回显行(vue3)

el-table表格选中行和回显行 官方文档说明 https://element-plus.org/zh-CN/component/table.html#table-%E6%96%B9%E6%B3%95 环境&#xff1a;vue3element-plus 选中行selection <el-table ref"baseTableRef" row-key"id" border :selection"tr…

Spring无法加载静态属性和SpringBoot单元测试指定加载配置文件

一、Spring无法加载静态属性&#xff0c;怎么解决&#xff1f; Spring主要用于管理和注入Bean&#xff08;对象&#xff09;的实例属性&#xff0c;而不是静态属性。静态属性属于类本身&#xff0c;而不是类的实例&#xff0c;因此Spring的依赖注入机制不会处理它们。 看图&a…

华为云2023年双十一服务器优惠价格表及活动大全

2023华为云双11优惠活动「云上优选 特惠来袭」&#xff0c;阿腾云atengyun.com整理云服务器优惠价格表&#xff0c;华为云L实例-2核2G3M一年优惠价89元、L实例-2核2G4M价格108元一年、L实例-2核4G5M优惠价198元一年&#xff0c;三年1000元、HECS云服务器-1核2G1M带宽39元一年、…