news 2026/5/27 9:05:44

C#表格与定时器实战技巧

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C#表格与定时器实战技巧

一,表格:

1,AutoGenerateColumns是否自动生成列,设置为false 需要自己通过界面绑定类的属性(自己设置列的标题、自己设置列显示哪个属性) 设置为true,表格自动显示列的标题为绑定类的属性

2,dataGridView1 表格 可以通过DataSource属性进行绑定数据源,但是后续添加的新的数据不会立即显示到控件上,需要 再次对 dataGridView1.DataSource=null之后 再重新赋值

3,SelectedRows 选中的行 可以选择多个

4,DataBoundItem 获取选中行绑定对象,as 强制转换成Student对象

5,MessageBox.Show是有返回值的,为DialogResult对象(对话结果对象),

6,获取单元格的内容, Cells["Name1"] 获取name属性为Name1单元格的内容

7,dataGridView1.Font; //表格的默认字体

8,格式化字符串 字符串的对齐方式
StringFormat sf = new StringFormat()
{
Alignment = StringAlignment.Center,// 水平对齐方式居中
LineAlignment = StringAlignment.Center, //竖直对齐方式居中
};

9,Brushes.Black 画笔的颜色

10,Graphics 图形类

11,DrawString 绘制一个文本 参数1是绘制的字符串,参数2是绘制字体,参数3绘制的笔刷颜色 ,参数4 绘制的区域 , 参数5绘制字符串对齐方式

e.Graphics.DrawString(s,dataGridView1.Font,Brushes.Black, rect,sf);

二,自定义表格样式

1,DatagridviewStyle 关于表格样式的一个类文件,DgvStyle1()和 DgvStyle2() 设计表格样式

2,DgvRowCount() 绘制行标题

三,定时器

1,this.timer1.Stop();// 关闭定时器

2,this.timer1.Start();//开启定时器

3,this.timer1.Enabled = true; //设置定时器为激活状态的

4, this.timer1.Interval = 10;//触发定时器函数时间间隔 ms为单位

5,Color.FromArgb(255, 255, 255) 通过三原色取值合成一个颜色 三个值分别为红绿蓝 值的范围0-255,哪个值越大,越接近该颜色,255,255,255 白色;0,0,0 黑色,

6,label1.Left label的左边的距离 label1.Right label的右边的距离

四,使用代码创建定时器

1,创建定时器

timer = new Timer() { Enabled=true,Interval=10};

2,绑定定时器事件

timer.Tick += Timer_Tick;

3,进行循环添加label

for (int i = 0; i < 10; i++)
{
Label label = new Label()
{
Text = i.ToString(),
Location = new Point(100 * i, 200),
BackColor = Color.Aqua,
Size = new Size(50, 50),
TextAlign = ContentAlignment.MiddleCenter
};
this.Controls.Add(label);

4,创建随机数

}

}
Random rnd = new Random();
private void Timer_Tick(object sender, EventArgs e)
{
//MessageBox.Show(this.Controls.Count + "");
for (int i = 0;i<this.Controls.Count;i++) //this.Controls.Count。控件的个数
{
if (this.Controls[i] is Label) // 判断控件是不是Label,
{
this.Controls[i].BackColor = Color.FromArgb(rnd.Next(256), rnd.Next(256), rnd.Next(256));
this.Controls[i].ForeColor = Color.FromArgb(rnd.Next(256), rnd.Next(256), rnd.Next(256));
}
}

}

5, override 重写OnPaint方法 当绘制窗体的时候触发
protected override void OnPaint(PaintEventArgs e)
{
base.OnPaint(e);// base调用基类的重新绘制方法
// 自定义绘图逻辑
Graphics g = e.Graphics;
Rectangle rect = new Rectangle(10, 10, 300, 50); //窗户一个矩形区域
Font font = new Font("Arial", 32, FontStyle.Bold);
LinearGradientBrush brush = new LinearGradientBrush(rect, Color.Red, Color.Yellow, 45f);// 创建一个线性渐变的笔刷
g.DrawString("渐变文本", font, brush, new PointF(10, 10));

}

}
}

运行结果:

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/22 20:00:27

解决GLM-TTS生成慢问题:优化参数配置提升GPU利用率

解决GLM-TTS生成慢问题&#xff1a;优化参数配置提升GPU利用率 在智能语音应用日益普及的今天&#xff0c;用户对语音合成质量的要求越来越高——不仅要“像人”&#xff0c;还要“快得及时”。然而&#xff0c;许多开发者在部署 GLM-TTS 这类基于大模型的端到端语音克隆系统时…

作者头像 李华
网站建设 2026/5/22 0:37:22

中文多音字发音难题终结者:GLM-TTS音素模式深度使用技巧

中文多音字发音难题终结者&#xff1a;GLM-TTS音素模式深度使用技巧 在智能语音助手朗读新闻时&#xff0c;突然把“央行&#xff08;yn hng&#xff09;”念成“shng xng”&#xff1b;医学课程里&#xff0c;“血小板&#xff08;xu xiǎo bǎn&#xff09;”被读成了口语化的…

作者头像 李华
网站建设 2026/5/21 23:12:12

Java程序调用:通过HTTP客户端连接GLM-TTS服务

Java程序调用&#xff1a;通过HTTP客户端连接GLM-TTS服务 在智能语音内容需求爆发的今天&#xff0c;越来越多的应用场景要求系统不仅能“说话”&#xff0c;还要说得像人、说得有感情。从虚拟主播到个性化有声读物&#xff0c;再到企业级客服播报&#xff0c;传统的文本转语音…

作者头像 李华
网站建设 2026/5/23 15:28:39

数字频率计设计核心要点:闸门时间设定技巧解析

数字频率计设计核心&#xff1a;闸门时间设定的工程智慧你有没有遇到过这样的情况&#xff1f;用频率计测一个信号&#xff0c;显示值一直在跳&#xff0c;不知道是真实波动还是仪器不准&#xff1b;或者测量低频信号时&#xff0c;明明输入变化明显&#xff0c;读数却纹丝不动…

作者头像 李华
网站建设 2026/5/19 5:16:15

HuggingFace镜像网站推荐:快速拉取大模型提升TTS训练效率

HuggingFace镜像网站推荐&#xff1a;快速拉取大模型提升TTS训练效率 在语音合成技术飞速演进的今天&#xff0c;GLM-TTS 这类基于大语言模型&#xff08;LLM&#xff09;架构的零样本语音克隆系统正逐步从实验室走向实际应用。只需一段几秒的参考音频&#xff0c;就能精准复刻…

作者头像 李华
网站建设 2026/5/1 11:58:24

镜像站点维护:定期同步更新GLM-TTS最新版本内容

镜像站点维护&#xff1a;定期同步更新GLM-TTS最新版本内容 在语音合成技术飞速演进的今天&#xff0c;企业对个性化、高保真语音生成的需求正以前所未有的速度增长。从智能客服到有声读物&#xff0c;从虚拟主播到无障碍阅读&#xff0c;越来越多的应用场景要求系统不仅能“说…

作者头像 李华