Visual Studio C# WinForm开发入门(4):概述

news2024/10/5 23:29:03

目录

  • 一.Winform入门
    • 1.WinForm项目结构
    • 2.窗口设计与控件布局
    • 3.窗口事件
    • 4.时间显示器小练习
  • 二.WinForm布局开发
    • 1.手动布局解决自适应问题
    • 2.WinForm布局属性
    • 3.WinForm布局器
  • 三.WinForm常用控件
    • 1.界面展示
    • 2.实体类 Student(封装信息)
    • 3.逻辑事件代码Form.cs
  • 四.图片框与项目资源
    • 1.添加资源
    • 2.图片框控件展示

一.Winform入门

WinForm 是 Windows Form 的简称,是基于 .NET Framework 平台的客户端(PC软件)开发技术,一般使用 C# 编程。在VS2019中,C# WinForm 编程需要创建「Windows窗体应用程序」项目。Windows 窗体应用程序是 C# 语言中的一个重要应用,也是 C# 语言最常见的应用。使用C#语言编写的 Windows 应用程序与 Windows 操作系统的界面类似,每个界面都是由窗体构成的,并且能通过鼠标单击、键盘输入等操作完成相应的功能。WinForm支持可视化设计,简单易上手,并可以接入大量的第三方UI库或自定义控件,给桌面应用开发带来了无限可能。

1.WinForm项目结构

在这里插入图片描述

1.WinForm项目结构
(1)引用:包括所有的系统库文件的引用依赖
(2)App.config:当前项目的配置文件
(3)Forml.cs:当前窗体的事件逻辑源码

  • Form1.Designer.cs:当前窗体的控件布局源码
  • Forml.resx:当前窗体的资源文件(图片、图标、资源等)
  • 注意:
    a.Form1.cs和Form1.Designer.cs都定义了Form1类,该类使用了 Partial关键词声明,其定义的类可以在多个地方被定义,最后编译的时候会被当作一个类来处理。因此两个文件各司其职,最后合并为一个类编译。
    b.要手动实现自定义窗体,可以添加自己的类,然后继承Form类即可

(4)Program.cs:当前项目程序的主入口Main,启动项目,运行初始窗口

namespace WindowsFormsApplearning
{//Program.cs 入口程序解读
    static class Program
    {
        /// <summary>
        /// 应用程序的主入口点。
        /// </summary>
        [STAThread]//1.[STAThread]Attributes语法,修饰Main方法。表示应用程序的默认线程模型是单线程单元
        static void Main()
        {
            Application.EnableVisualStyles();
            Application.SetCompatibleTextRenderingDefault(false);
            Application.Run(new Form1());//2.开启窗口的消息循坏,初始化并启动Form1窗口
        }
    }
}

2.窗口设计与控件布局

2.窗体控件布局文件

(1)操作:在设计界面拖押控件,可以完成界面布局(控件大小、名称、类型、样式等)
(2)原理:设计界面自动关联Form1.Desioner.cs文件,在InitializeComponent()方法中会自动生成相关代码
(3)设计原则:

  • Form1.Designer.cs文件:窗体控件布局文件,一般【不需要我们修改】,只要通过设计界面代码就会自动生成。
  • Forml.cs文件:窗体事件逻辑代码的实现,一般【需要我们手动书写】,包括触发事件、回调、数据交互、跳转等等

3.手动添加控件:不通过设计界面,有两种方式
(1)在Form1.Designer.cs中添加:

private System.Windows.Forms.Button btn_design;//声明控件 //默认的控件初始化方法
InitializeComponent():
{
	this.btn_design = new System.Windows.Forms.Button();//定义控件
	this.btn_desion.Text="自定义控件";//设置Text属性 
	this.btn_desion.Location = new Point(40.40);//设置布局位置 Point(xy)
	this.btn_design.Size=new Size(100,40);//设置尺寸大小 Size(width,height) 
	this.Controls.Add(this.btn_design);//注册控件到窗体
}

(2)在Form1.cs中添加:

private Button btn_design;//声明控件 
public Form1()
{
	//先调用Designer.cs中的控件初始化方法
	InitializeComponent(); 
	this.btn_design=new System.Windows.Forms.Button();//定义控件
	this.btn_desion.Text="自定义控件";//设置Text属性 
	this.btn_desion.Location = new Point(40,40);//设置布局位置 Point(x,y)
	this.btn_desion.Size = new Size(100,40);//设置尺寸大小 Size(width,height)
	this.Controls.Add(this.btn_desion);//注册控件到窗体
}

(3)注意:
1.一般我们都使用拖拽添加控件,当然也有特殊情况需要我们手动添加(比如自定义控件)
2.窗体GUI中,左上角为原点(0,0),竖直向下为y轴,水平向右为x轴(宽度表示x轴上长度,高度表示y轴上长度),单位为像素。

3.窗口事件

4.WinForm 自动添加事件处理
(1)操作:在设计界面-控件属性-闪电符号(事件)-添加事件,就会在Form1.cs中自动生成该控件相应方法名称的事件触发函数
(2)MessageBox.Show0:显示弹出消息提示框
(3)GUI界面下Console.WriteLine不显示,需要使用调试模式

5.手动添加事件处理(以Btn_design为例)
(1)步骤:
添加按钮控件到布局
书写事件处理函数,必须符合 void function name(object paraml,EventArgse){}的形式
添加注册事件,this.Btn_design.Click += new EventHandler(this.showTip);
(2)注意:事件处理机制用到了委托和事件的C#基础,有时间可以看一下

4.时间显示器小练习

设计一个能获取本地时间并显示在文本框的时间查看器,设计思路就是:
1.在UI设计界面添加一个按钮Button和一个用来显示时间的文本框TextBox
2.给按钮Button添加点击事件,在事件中获取系统时间,并赋值给TextBox显示
(1)界面设计
在这里插入图片描述

(2)逻辑代码

namespace WindowsFormsApp Demol 
{
	public partial class Form1 : Form 
	{ 
		public Form1()
		{
			InitializeComponent();
		}
		//点击事件:获取当前时间赋值给TextBox 
		private void ShowTime(object sender, EventArgs e)
		{ 
			string time = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
			this.Time_filed.Text=time;
		}
	}
}

二.WinForm布局开发

1.常见的WinForm 自动界面布局(设计界面拖搜布局)
(1)操作:拖拽控件,放置在UI设 计界面上布局
(2)技巧:通过ctrl+多个控件选定,可以在上方工具栏进行细节的对齐微调,比如居中对齐、左对齐等。
(3)本质:每次拖拽添加一个布局控件,就会在窗口相应的Designer.cs设计布局代码文件中的InitializeComponent()方法中自动生成布局代码(比如Location、Size等),来实现布局。
(4)存在的问题:自动布局虽然方便灵活,但是当窗口大小拉伸改变时,布局控件不能实现自动适应,仍会保持原大小,因此自动布局只适用于窗口大小不变的情况

1.手动布局解决自适应问题

2.WinForm界面手动布局(并解决自适应问题)
(1)步骤:

  • 通过设计界面拖拽/手动注册组件的方式,初始化初始界面布局(此时属于自动布局)
  • 在Form.cs逻辑代码中重写Form父类的 OnLayout 方法,在方法内实现手动布局。OnLayout方法会在窗口大小变化时自动被回调调用,来重新设置组件的位置大小等属性实现自适应。
    a.调用父类的OnLayout(),不是必须的。
    b.获取当前窗口大小 CilentSize(仅客户区,不含标题栏)
    c.计算和设置每一个控件新的的大小和位置,实现动态布局

(2)注意:

  • Size属性指窗口大小(包括工具栏),ClientSize指客户区大小(不包含工具栏)
  • 本质:OnLayout方法会在窗口大小变化时自动被调用,来设置组件的位置实现自适应
namespace WindowsFormsApp_learning 
{
	public partial class Forml : Form 
	{ 
		public Form1() 
		{
			InitializeComponent();
		} 
		//重写父类的OnLayout方法,实现手动布局自适应 
		protected override void OnLayout(LayoutEventArgs levent)
		{
			//1.调用父类的OnLayout(),不是必须的
			base.OnLayout(levent);
			//2.获取当前客户窗口大小 ClientSize 
			int w=this.ClientSize.Width; 
			int h=this.ClientSize.Height; 
			//3.计算并设置每一个控件的大小和位置
			int yoff=0;
			yoff=4;
			this.text_box.Location = new Point(0, yoff);//坐标(0.4) 
			this.text_box.Size= new Size(w-80. 30);//尺寸(w-80.30) 
			this.btn_click.Location = new Point(w-80,yoff);//坐标(w-80,4) 
			this.btn_click.Size = new Size(80, 30);//尺寸(80,30) 
			yoff+=30;//第一行的高度 yoff+=4;//间隔 
			this.panel1.Location = new Point(0, yoff); 
			this.panel1.Size = new Size(w, h-yoff-4);
		}
	}
}

2.WinForm布局属性

3.WinForm布局属性(控件与布局相关的属性,设计界面可见)

(1)Anchor:固定、锚定(无论窗口怎么变化,控件的相对位置都不变)
-含义:固定控件与父窗口的【上下左右边距】不变,实现控件的锚定

  • 左上角固定:选定 Top.Left(默认)
  • 顶部固定,水平拉伸:选定 Top,Left,Right t
  • 居中固定:None(取消所有)

-注意:Anchor效果的好坏取决于控件的初始位置,因为控件的初始位置决定了控件的边距!所以要让控件固定右上角,就要初始设计时就放在右上角!

(2)Dock:停靠属性,将控件停靠在父窗口的一侧或者中央
-Top:上,控件停靠在容器上侧,宽度填满容器,高度可以调节
-Bottom:下,控件停靠在容器下侧,宽度填满容器,高度可以调节
-Left:左,控件停靠在容器左侧,高度填满容器,宽度可以调节
-Right:右,控件停靠在容器右侧,高度填满容器,宽度可以调节
-Fill: 中,控件填满容器中间 剩余 部分(所以说与控件添加顺序有关)。
-None: 无,不使用Dock属性
注意:
a.容器之间可以嵌套,使用布局属性(容器就是存放组件的,比如Panel)
b.Dock属性与Anchor属性不能同时使用
c.Dock属性不是固定边距了,就是相对位置填充

3.WinForm布局器

4.布局器 LayoutEngine
(1)含义:布局器就是容器内部组件的默认排列方式,所有的容器都带有一个默认的布局器

(2)自定义控件如何加入设计界面:

  • 工具 ->选项 ->Windows窗体设计器->常规 ->自动填充工具箱 ->True
  • 添加自定义的控件类源码到项目下
  • 生成/重新生成解决方案
  • 重新打开设计界面,在工具箱就可以看到自己的控件

(3)系统提供的布局器
-FlowLayoutPanel(流式布局):
-含义:普通的Panel面板容器控件,使用了FlowLayout流式布局,即所有内部组件按照顺序从左到右从上到下依次排列
-FlowLayoutPanel也可以使用 Anchor、Dock等属性,因为他也是窗体容器内的一个组件
-控件的选择技巧: 多个控件叠加到一起时,可以右键最上层控件,来进行重叠控件的选择

(4)系统提供的布局器
-TableLayoutPanel(表格布局):
-含义:普通的Panel面板容器,使用了TableLayout表格布局,即所有内部组件可以放置到不同的表格中(每个表格只能放置一个控件)
TableLayoutPanel也可以使用Anchor、Dock等属性,因为他也是窗体容器内的一个组件。搭配布局与布局属性,可以实现很多不同的布局效果。
-删除/添加行、列:右键表格Panel,可以添加、删除行/列
-调整表格大小:表格属性Columns可以通过绝对值、百分比、自动调整等方式来调整单元格的大小
a.绝对:固定像素值大小
b.百分比:除去绝对大小后,单元格占剩余大小的百分比
c.自动调整:根据内部控件的大小生成
-跨行/列控件:在控件的ColumnSpan/RowSpan调整控件可以跨行/跨列布局
注意:TableLayoutPanel控件每个单元格只能包含一个子控件。

(5)系统提供的布局工具
-默认布局:默认布局可以通过控件拖拽放置,并可以使用Anchor、Dock来调整

(6)自定义布局器:用户可以自己设计实现布局器,
这属于WinForm高级的内容,后面学习。

三.WinForm常用控件

1.Winform 组件的使用
(1)TextBox:输入文本框
-常用属性:尺寸Size、单行/多行 Multiline、密码输入PasswordChar、只读ReadOnly、显示/获取文本Text等
-常用事件:KeyPress按下按键(常用于输出完成点击回车,box.Text取输入值,事件e.keyChar取按下哪个键)
(2)CheckBox:复选框
-常用属性:尺寸Size、显示文本Text、Checked是否勾选
-常用事件:Click点击事件、CheckedChanged勾选状态改变事件
(3)ComboBox:下拉列表(只能单选)
-常用属性:
a.添加数据项:设计器编辑添加(属性->数据->Items,一行表示一个数据项)、程序手工添加(comboBox.Items.Add(“some”)😉
b.其他设置:Size尺寸、Text提示文本等
-常用事件:
a.获取选中的项:SelectedItem(选中项的值)、 SelectedIndex(选中项的索引,-1表示未选中)
b.选项改变事件:SelectedIndexChanged

  • 注意:Item可以添加字符串,也可以添加任意object类型(比如自定义对象),对象会以object.toString显示

(4)ListBox:列表框(展示数据、可单选/多选) -常用属性:SelectionMode(单选/多选模式)
a.单选模式获取选项:SelectedItem/SelectedIndex(选中项的值/索引)
b.多选模式获取选项:SelectedIndices/SelectedItems(选中项的索引集合/值集合)
c.添加数据项:设计器编辑添加(属性->数据->Items)、程序手工添加(listBox.Items.Add(“some”)😉
-常用事件:SelectedIndexChanged(选项改变)
-注意:Item可以添加字符串,也可以添加任意object 类型(比如自定义对象),对象会以object.toString显示

1.界面展示

2.实体类 Student(封装信息)

1.C# 类的属性与字段
(1)字段: 字段是类的成员变量,用于类内特征的数据存储(静态)比如private int Id;
(2)属性:属性是对字段特征的动态描述,用于向外界提供数据,本质上就是get、set方法。

  • 完整属性用法:

private string sdu_name;//声明字段 
public string StudentName
{
//声明属性 
	get
	{ 
		return sdu_name; 
	} 
	set 
	{
		if(value==null)
			sdu_name = "admin"; 
		sdu_name = value; 
	}
}

-get访问器:get访问器必须包含return语句,返回字段’realValue’。用于获取数据,如果没有get则字段为只写的
-set访问器:set访问器接受它的输入参数–value,并把它赋给字段,value 是隐式参数。用于设置数据,如果没有set则字段为只读的
(3)使用方式:直接使用
Class.StudentName来获取和设置数据,就像是直接使用公开的属性一样
(4)自动属性:简化字
段和属性的关系

  • 用法:public 数据类型 属性名{ get; set;}
  • 原理:c# 允许只声明属性而不声明后备字段,编译器会创建隐藏的后备字段。并且自动挂接到get,set访问器上。

(5)注意:
-属性也可以不与字段关联,可以当作函数进行复杂计算,比较自由灵活
-属性也可不用显示声明相应的字段,直接用于存贮数据。(自动属性)
-也可以通定义其他set、get函数来实现访问private字段的功能

namespace WindowsFormsApp_learning
{
	class Student
	{
		//属性访问器 
		public int SduId 
		{
			get; 
			set; 
		}
		public string SduName 
		{
			get; 
			set;
		}
		public bool SduSex
		{
			get; 
			set; 
		} 
		public string SduPhone 
		{
			get; 
			set;
		}
		public Student(int sduId, string sduName, bool sduSex, string sduPhone) 
		{ 
			SduId = sduId; 
			SduName = sduName; 
			SduSex = sduSex; 
			SduPhone = sduPhone; 
		} 
		public Student()
		{
		}
	} 
}

3.逻辑事件代码Form.cs

namespace WindowsFormsApp learning 
{
	public partial class Form4: Form { public Form4()
	{
		InitializeComponent();//初始化数据LoadData();
	}/***保存按钮触发事件-保存学生信息到本地文件*/ 
	private void save student(object sender, EventArgs e)
	{ 
		Student student = new Student(); 
		student.SduId=Convert.ToInt32(sduId.Text.Trim);//Convert格式转换 
		student.SduName=sdu Name.Text.Trim();
		student.SduSex=(sdu sex.SelectedIndex ==1); 
		student.SduPhone = sdu phone.Text.Trim();//以Json格式保存到本地文件 string JsonStr=JsonConvert.SerializeObject(student,Formatting.Indented);
		AfTextFile.Write("student.txt",JsonStr,AfTextFile.UTF8);
		MessageBox.Show("操作成功");} //读取文件,加载数据 
		private void LoadData
		{
			string JsonStr=AfTextFile.Read("student.txt".AfTextFile.UTF8);
			if(JsonStr == null) 
				return; 
			Student student = JsonConvert.DeserializeObject<Student>(JsonStr);
			sdu Id.Text=Convert.ToString(student.SduId); 
			sdu Name.Text= student.SduNames;
			sdu sex.SelectedIndex=student.SduSex?1:0;
			sdu phone.Text = student.SduPhone; 
		}
	} 
}

四.图片框与项目资源

1.图片框与资源
(1)添加资源来源:

  • 本地文件: 本地资源路径,比如"DllResources l\123.jpg"(注意使用Windows路径格式)
  • 项目资源文件:Properties/Resources.resx(项目资 源文件夹下)
    a.如何添加项目资源文件:双击Properties/Resources.resx->添加资源->添加现有文件->选择本地图片->重命名(规范化,以后使用时直接调用名字使用资源)
    b.能添加什么类型的资源:字符串、文本文档、图片、视频、音频等
    c.原理:Resources.resx 将添加的资源整合到了项目exe当中,因此就算删除源文件也不影响项目运行。在调用资源时,是通过自动生成的方法来获取资源。
    d.优点:将资源统一到项目中来,并且可以通过规范化的命名直接调用资源。
    e.使用:通过 Properties.Resources.资源名称;来直接调用你的资 源,方便快捷
  • 网络资源:比如"http://baidu/image/meinvjpg"

(2)图片资源加载类:
-C# 提供了Image抽象类,作为所有图片资源的总称
-C# 提供了 Image抽象类的具体实现类 Bitmap(位图、像素图),来具体加载读取图像。
a.比如 Bitmap img = new Bitmap(“D:\Resources\123.jpg”);
b.比如Bitmap img=Properties.Resources.img Conv;

(3)图片框控件:PictureBox - Size、Location属性:尺寸、 位置
-Image属性:图片资源(可以通过本地/项目资源文件导入)
-SizeMode属性:图片 的适应模式(StretchImage拉伸图片和图片框相同尺寸、Zoom缩放等)
-ErrorImage、 InitialImage属性:加载失败、加载图片显示之前所显示的图片

(4)图片框控件可视化配置:
在设计里拖动PictureBox并配置属性即可。

(5)图片框代码手动配置:
Bitmap img=Properties.Resources.imgConv;//读取图片资源
pictureBox.Image=img;//手动设置图片框控件 Image来源
pictureBox.SizeMode=PictureBoxSizeMode.Zoom;//手动设置图片格式

1.添加资源

2.图片框控件展示

界面设计就是简单的放置了一个 PictureBox控件,没有过多的设计。图片来源的设置使用代码方式,原因是在以后开发中图片往往不是固定的,需要动态变化,因此使用代码方式动态设置图片来源是比较推荐的

namespace WindowsFormsApp_learning 
{
	public partial class Form2 : Form 
	{ 
		public Form2()
		{
			//初始化所有组件 
			InitializeComponent;//初始化PictureBox控件-图片资源 
			Bitmapimg=Properties.Resources.img_Conv;
			pictureBox.Image=img;
			pictureBox.SizeMode = PictureBoxSizeMode.Zoom;
		}
	}
}

http://xunbibao.cn/article/58357.html

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

大数据电商数仓相关脚本

文章目录 前言一、群起集群1. sc 脚本2. cluster 脚本3. myhadoop 脚本4. zk.sh 脚本5. kf.sh 脚本6. f1.sh 脚本7. f2.sh 脚本 二、简便使用脚本1. xsync 脚本2. jpsall 脚本3. xcall.sh 脚本4. lg.sh 脚本 三、数据传输相关脚本1. mysql_to_hdfs.sh 脚本2. hdfs_to_ods_db.sh…

《JavaEE初阶》HTTP协议和HTTPS

《JavaEE初阶》HTTP协议和HTTPS 文章目录 《JavaEE初阶》HTTP协议和HTTPSHTTP协议是应用层协议:使用Fiddler抓取HTTP请求和响应:Fiddler的下载和基本使用:Fiddler的中间代理人身份:其他抓包工具: 先简单认识HTTP请求与HTTP响应:HTTP请求:HTTP响应: HTTP请求详解:首行&#xff1…

分享10个精美可视化模板,解决95%的大屏需求!

前段时间和朋友一起喝茶&#xff0c;我吐槽着excel表格做报表的繁琐&#xff0c;他惊讶的问我竟然不知道大屏模板这种东西&#xff0c;说是直接套用数据就可以&#xff0c;我震惊的同时吃下了这个安利。 回来之后&#xff0c;我好好研究了一番这个叫可视化大屏的“新鲜玩意儿”…

模块化编程原理示意图--CommonJS 模块编程--ES6 模块编程思路分析/图解--三种导出形式--全部代码示例

目录 模块化编程 基本介绍 模块化编程原理示意图 模块化编程分类 CommonJS 模块编程 介绍 应用实例 1. 需求说明 2. 思路分析/图解 3. 代码实现 function.js use.html use.js ES6 模块编程 介绍 需求说明 思路分析/图解 代码实现 common.js use_common.js …

MySQL入门到精通——进阶篇(基础篇——进阶篇——运维篇)本文以MySQL8.0版本以上为例

文章目录 前言MySQL——进阶篇一、存储引擎1.存储引擎-MySQL体系结构2.存储引擎-简介3.存储引擎-InnoDB介绍4.存储引擎-MyISAM和Memory5.存储引擎-选择 二、索引1.索引-概述2.索引-结构2.1.索引-结构-介绍2.2.索引-结构-Btree2.3.索引-结构-Btree2.4.索引-结构-hash 3.索引-分类…

【Java-02】深入理解关键字和代码块

1 关键字 2 代码块 1 Java中的关键字 1.1 static关键字 static关键字 : 静态的意思 , 可以修饰变量 , 也可以修饰方法 , 被static修饰的成员 , 我们叫做静态成员 static特点 : 静态成员被所类的所有对象共享随着类的加载而加载 , 优先于对象存在可以通过对象调用 , 也可以通…

学习系统编程No.23【信号实战】

引言&#xff1a; 北京时间&#xff1a;2023/4/23&#xff0c;最近学习状态不怎么好&#xff0c;总是犯困&#xff0c;没精力的感觉&#xff0c;可能是病没有好彻底的原因&#xff0c;也可能是我内心因为生病而认为摆烂理所应当&#xff0c;反正最后导致摆烂&#xff0c;课现在…

JetpackCompose从入门到实战学习笔记14——Coli的简单使用

JetpackCompose从入门到实战学习笔记14——Coli的简单使用 1.简介&#xff1a; Coil 是一个 Android官方出的配合Jetpack的图片加载库&#xff0c;通过 Kotlin 协程的方式加载图片。 优点如下&#xff1a; 更快: Coil 在性能上有很多优化&#xff0c;包括内存缓存和磁盘缓存…

体验了多款国产类ChatGPT产品后,我选择了道合顺的【ChatIC】

&#x1f482;作者简介&#xff1a; THUNDER王&#xff0c;一名热爱财税和SAP ABAP编程以及热爱分享的博主。目前于江西师范大学本科在读&#xff0c;同时任汉硕云&#xff08;广东&#xff09;科技有限公司ABAP开发顾问。在学习工作中&#xff0c;我通常使用偏后端的开发语言A…

springboot实用配置

springboot实用配置 &#xff08;一&#xff09;打包与运行&#xff08;二&#xff09;配置高级1.临时属性设置2.配置文件分类3.自定义配置文件 &#xff08;三&#xff09;多环境开发&#xff08;四&#xff09;日志1.日志基础2.日志输出格式控制3.日志文件 &#xff08;一&am…

什么是OpenVino?以及如何使用OpenVino运行yolo

目录 Openvino简介 如何使用它&#xff1f; 构建源代码 Openvino IR模型 第一个Openvino示例 C语言示例 C示例 使用OpenVino跑Yolo模型 Openvino简介 Openvino是由Intel开发的专门用于优化和部署人工智能推理的半开源的工具包&#xff0c;主要用于对深度推理做优化。 …

开源,点云处理及三维重建软件(Point Cloud Viewer, PCV)的设计与实现

GitHub地址&#xff1a;point-cloud-viewer GitCode地址&#xff1a;point-cloud-viewer 文章目录 使用教程以及相关工具库Step 1 搭建环境Step 2 使用Cmake构建工程Step3 使用VS 编写code并编译执行 点云处理及三维重建软件(PCV)的设计与实现一&#xff0c; 软件总体设计1.1 软…

C++ LinuxWebServer 2万7千字的面经长文(下)

⭐️我叫忆_恒心,一名喜欢书写博客的在读研究生👨‍🎓。 如果觉得本文能帮到您,麻烦点个赞👍呗! Linux Web Server项目虽然是现在C++求职者的人手一个的项目,但是想要吃透这个项目,还是需要一定的基础的,以项目为导向,进行基础的学习。 涵盖了计算机网络(网络编程…

springboot网上商城项目(一)

springboot网上商城项目&#xff08;一&#xff09; &#xff08;一&#xff09;项目分析1.项目分析2.开发顺序3.前端资源测试 &#xff08;二&#xff09;用户注册1.创建数据库2.实体类编写3.注册&#xff08;持久层&#xff09;4.注册&#xff08;业务层&#xff09;5.注册&a…

类ChatGPT的部署与微调(下):从ChatGLM-6b到ChatDoctor、可商用

前言 随着『GPT4多模态/Microsoft 365 Copilot/Github Copilot X/ChatGPT插件』的推出&#xff0c;绝大部分公司的技术 产品 服务&#xff0c;以及绝大部分人的工作都将被革新一遍 类似iPhone的诞生 大家面向iOS编程 有了App Store现在有了ChatGPT插件/GPT应用商店&#xff…

国产CMS61850那些事-服务端

前面两篇文章国产CMS61850那些事-总述_LinuxZQ的博客-CSDN博客&#xff0c;cms61850那些事-实现_LinuxZQ的博客-CSDN博客分别对国产61850做了一些简单介绍和相关实现。本文接着给大家提供一款服务端demo&#xff0c;可以用来进行抓包等相关学习。 与之前分享的mms 61850一样&am…

如此这般,好吗?

让我们回顾一下 Linux 社区最新的愿景——推动去中心化的应用来解决发行版的碎片化。继上周的文章&#xff1a;“Snap、Flatpak 这种通吃所有发行版的打包方式真的有用吗&#xff1f;” 之后&#xff0c;一系列新观点浮出水面&#xff0c;其中可能包含关于这样应用是否有用的重…

Vmware安装Ubuntu出现 unable to find a medium containing a live file system

一、前言 由于未知的原因&#xff0c;使用Vmware安装Ubuntu的时候&#xff0c;总是遇到奇怪的问题。&#xff08;忘记截图了…&#xff09; 大致是&#xff1a; unable to find a medium containing a live file system找了几个帖子&#xff0c;参考1、参考2&#xff0c;但都…

GPT模型成功的背后用到了哪些以数据为中心的人工智能(Data-centric AI)技术?

人工智能&#xff08;Artificial Intelligence, AI&#xff09;最近取得了巨大的进展&#xff0c;特别是大语言模型&#xff08;Large Language Models, LLMs&#xff09;&#xff0c;比如最近火爆全网的ChatGPT和GPT-4。GPT模型在各项自然语言处理任务上有着惊人的效果。至于具…

JAVA Future类详解及Thread线程是如何运行Future类的

一、Future基本介绍 Future(java.util.concurrent Interface Future<V>)表示异步计算的结果。Future接口提供了检查计算是否完成、检查计算是否被取消、等待计算完成并获取计算结果等方法。 在并发编程中&#xff0c;我们经常用到非阻塞的模型&#xff0c;但继承thread类…