news 2026/4/15 10:34:59

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/4/12 12:06:01

Rust 生命周期,三巨头之一

在 Rust 编程中&#xff0c;所有权&#xff08;Ownership&#xff09;、借用&#xff08;Borrowing&#xff09;和生命周期&#xff08;Lifetime&#xff09;是三大核心特性&#xff0c;它们共同构成了 Rust 内存安全的基石。其中&#xff0c;生命周期相对抽象&#xff0c;却是…

作者头像 李华
网站建设 2026/4/14 19:23:39

KAN:为什么以及它是如何工作的?深入探讨

原文&#xff1a;towardsdatascience.com/kan-why-and-how-does-it-work-a-deep-dive-1adab4837fa3 https://github.com/OpenDocCN/towardsdatascience-blog-zh-2024/raw/master/docs/img/770c93e12c8c2a5af60c4fd3c1ed6ddc.png 神经网络能否发现新的物理学&#xff1f;(由作者…

作者头像 李华
网站建设 2026/4/15 4:44:54

保持梯度流动

原文&#xff1a;towardsdatascience.com/keep-the-gradients-flowing-5b9bf0098e3d https://github.com/OpenDocCN/towardsdatascience-blog-zh-2024/raw/master/docs/img/bb0a649375c5f67394c1f6a552ec4101.png AI 图像生成&#xff0c;描绘神经网络中的梯度流动 近年来&am…

作者头像 李华
网站建设 2026/4/8 20:49:39

电机齿轮拉马

拉马太贵了&#xff0c;想自己做一个&#xff0c;这是别人做的&#xff1a;没有机床做不出&#xff0c;画个设计图先&#xff1a;difference(){ cube([24,20,24]);translate([2,-1,2]) cube([20,22,20]);translate([10,-1,-1]) cube([4,12,4]); }translate([12,10,5]) differen…

作者头像 李华
网站建设 2026/4/14 22:07:53

效果对比demo:提供原始语音与合成语音试听选择

效果对比demo&#xff1a;提供原始语音与合成语音试听选择 在语音合成技术飞速发展的今天&#xff0c;我们早已不再满足于“能说话”的机器。真正打动用户的&#xff0c;是那些听起来像真人、有情感、自然流畅的语音输出。尤其是在虚拟主播、有声书生成、个性化助手等场景中&a…

作者头像 李华
网站建设 2026/4/15 4:23:46

Sublime Text配置:自定义快捷键触发语音合成

Sublime Text 集成 GLM-TTS&#xff1a;打造“写完即听”的语音创作工作流 在内容创作日益依赖 AI 的今天&#xff0c;我们不再满足于“写完再读”&#xff0c;而是追求更即时的反馈——比如&#xff0c;刚敲下一段文字&#xff0c;就能立刻听到它被朗读出来的声音。这种“所写…

作者头像 李华