我的编程空间,编程开发者的网络收藏夹
学习永远不晚

C#如何实现自定义屏保

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

C#如何实现自定义屏保

这篇文章主要介绍“C#如何实现自定义屏保”,在日常操作中,相信很多人在C#如何实现自定义屏保问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C#如何实现自定义屏保”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

效果

C#如何实现自定义屏保

代码

public partial class Form1 : Form{    public Form1()    {        InitializeComponent();    }    Control FrmContainer = new Control(); //实例化Control类    bool isbool = true; //是否开启了屏保    int fontSize = 0; //字休大小    public Point mouse = new Point(0, 0); //记录鼠标的位置    private void button1_Click(object sender, EventArgs e)    {        preview(); //对预览进行初始化    }    /// <summary>    /// 对预览进行初始化    /// </summary>    public void preview()    {        this.FormBorderStyle = FormBorderStyle.Sizable; //使窗体有边框        this.WindowState = FormWindowState.Normal; //使窗体恢复默认大小        this.BackColor = Color.Gainsboro; //设设置窗体的背景颜色        panel1.Visible = true; //显示该控件        multimedia(panel1); //设置窗体中各控件的样式        timer1.Start(); //启动计时器    }    /// <summary>    /// 隐藏或显示Label类的控件    /// </summary>    /// <param n ="bool">要改变图片的对象</param>    public void LabelVisible(bool n)    {        label1.Visible = n; //隐藏或显示该控件        label2.Visible = n;        label3.Visible = n;        label4.Visible = n;    }    /// <summary>    /// 在显示预览和屏保前,对窗体中的各控件进行设置    /// </summary>    /// <param panel ="Control">设置父级控件</param>    public void multimedia(Control panel)    {        LabelVisible(true); //显示要移动的文本        if (panel.Name == "form1") //如果父级窗体是当前窗体        {            isbool = false; //隐藏            fontSize = 20; //设置字体大小        }        else        {            isbool = true; //显示            fontSize = 10; //设置字体大小        }        label1.Text = "字幕滚动"; //设置文本        label1.Parent = panel; //设置父级控件        label1.Font = new Font("宋体", fontSize, FontStyle.Bold); //设置字体样式        label2.Parent = panel; //设置父级控件        label2.Text = "字" + "\n" + "幕" + "\n" + "滚" + "\n" + "动"; //设置纵向文本        label2.Font = new Font("宋体", fontSize, FontStyle.Bold); //设置字体样式        label3.Text = "动滚幕字"; //设置文本        label3.Parent = panel; //设置父级控件        label3.Font = new Font("宋体", fontSize, FontStyle.Bold); //设置字体样式        label4.Text = "动" + "\n" + "滚" + "\n" + "幕" + "\n" + "字"; //设置纵向文本        label4.Parent = panel; //设置父级控件        label4.Font = new Font("宋体", fontSize, FontStyle.Bold); //设置字体样式        panel.Visible = isbool; //隐藏或显示        button1.Visible = isbool; //隐藏或显示        button2.Visible = isbool; //隐藏或显示        label1.Top = panel.Height / 4; //设置当前控件的显示位置        label3.Top = (panel.Height / 4) * 3; //设置当前控件的显示位置        label3.Left = 0 - label2.Width; //设置当前控件的显示位置        label4.Left = (panel.Width / 4) * 3; //设置当前控件的显示位置        label4.Top = 0 - label2.Height; //设置当前控件的显示位置        label2.Left = panel.Width / 4; //设置当前控件的显示位置        FrmContainer = panel; //记录父级控件    }    private void timer1_Tick(object sender, EventArgs e)    {        //文字从右到左滚动        label1.Left = label1.Left - 2; //向左移动        if ((label1.Left + label1.Width) < 1) //当超出左边界时            label1.Left = FrmContainer.Width; //在右边出现        //文字从下到上滚动        label2.Top = label2.Top - 1; //向上移动        if ((label2.Top + label2.Height) < 1) //当超出上边界时            label2.Top = FrmContainer.Height; //在下边出现        //文字从左到右滚动        if (label3.Left > FrmContainer.Width) //如果超出右边界            label3.Left = 0 - label2.Width; //在左边出现        else            label3.Left = label3.Left + 2; //向右移动        //文字从上到下滚动        if (label4.Top > FrmContainer.Height) //如果超出下边界            label4.Top = 0 - label4.Height; //在上边出现        else            label4.Top = label4.Top + 1; //向下移动        //如果在屏保情况下,鼠标移动        if ((mouse.X != Control.MousePosition.X || mouse.Y != Control.MousePosition.Y) && panel1.Visible == false)            preview(); //恢复预览状态    }    private void button2_Click(object sender, EventArgs e)    {        this.FormBorderStyle = FormBorderStyle.None; //窗体无边框        this.WindowState = FormWindowState.Maximized; //窗体最大化        this.BackColor = Color.Black; //设置窗体背景为黑色        multimedia(this); //设置窗体中各控件的样式        timer1.Start(); //启动计时器        button1.Visible = false; //隐藏        button2.Visible = false; //隐藏        panel1.Visible = false; //隐藏        mouse = Control.MousePosition; //获取鼠标的屏幕坐标    }    private void Form1_Load(object sender, EventArgs e)    {        LabelVisible(false); //隐藏要移动的文本    }}

到此,关于“C#如何实现自定义屏保”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

C#如何实现自定义屏保

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

C#如何实现自定义屏保

这篇文章主要介绍“C#如何实现自定义屏保”,在日常操作中,相信很多人在C#如何实现自定义屏保问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C#如何实现自定义屏保”的疑惑有所帮助!接下来,请跟着小编一起来学习吧
2023-07-04

C#实现自定义屏保的示例代码

这篇文章主要为大家详细介绍了如何利用C#实现自定义屏保的功能,文中的示例代码讲解详细,对我们学习C#有一定的帮助,感兴趣的小伙伴可以跟随小编一起了解一下
2022-12-31

C#如何实现自定义圆角按钮

这篇文章给大家分享的是有关C#如何实现自定义圆角按钮的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Winform中自带的button没有圆角属性,所以我们继承Button类,重写OnPaint事件来绘制圆角按钮。
2023-06-25

React如何自定义视频全屏按钮实现全屏功能

本篇内容介绍了“React如何自定义视频全屏按钮实现全屏功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、绘制全屏按钮绘制全屏按钮,并绑
2023-07-04

C#中如何实现自定义类型的转换

在C#中,我们可以通过实现类型转换运算符(conversion operators)来自定义类型的转换。具体步骤如下:创建一个自定义类型,例如一个类或结构体。public class MyType{public int Value { g
C#中如何实现自定义类型的转换
2024-04-03

C语言如何实现自定义扫雷游戏

这篇“C语言如何实现自定义扫雷游戏”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C语言如何实现自定义扫雷游戏”文章吧。实现过
2023-06-29

php如何实现自定义url

这篇文章将为大家详细讲解有关php如何实现自定义url,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。php实现自定义url的方法:1、通过mod_rewrite配置htaccess文件实现URL重写;2、
2023-06-20

Android Compose自定义TextField如何实现自定义的输入框

这篇文章主要介绍Android Compose自定义TextField如何实现自定义的输入框,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!简单自定义BasicTextField示例1.代码 var text by r
2023-06-29

Docker如何实现自定义网络

小编给大家分享一下Docker如何实现自定义网络,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1、自定义网络实现容器互联四类网络模式,使用docker netwo
2023-06-22

java如何实现自定义zip包

java如何实现自定义zip包?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1.配置pom.xml文件,添加build节点