C#使用迭代器实现文字的动态效果

这篇具有很好参考价值的文章主要介绍了C#使用迭代器实现文字的动态效果。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

一、涉及到的知识点

1.GDI+

2.Thread类

3.使用IEnumerable()迭代器

二、实例

1.源码

2.生成效果:


一、涉及到的知识点

1.GDI+

        GDI+主要用于在窗体上绘制各种图形图像。

        GDI+的核心是Graphics类,该类表示GDI+绘图表面,它提供将对象绘制到显示设备的方法。Graphics类封装了绘制直线、曲线、图形、图像和文本的方法,它是进行一切GDI+操作的基础类。

        本实例使用Graphics类的DrawString方法来绘制动态的文字,该方法常用的语法格式如下:

public void DrawString(string s,Font font,Brush brush,PointF point)

参数说明
s:要绘制的字符串。
font:定义字符串的文本格式。
brush:确定所绘制文本的颜色和纹理。
point:指定所绘制文本的左上角。

2.Thread类

        运行C#程序时,如果一个任务执行时间过长,会导致程序主窗体处于“假死”状态。为了避免这种情况发生,可以使用Thread类来创建多线程,即每一个线程完成一个功能,这样就可以有效地避免程序出现“假死”现象。

        本例中使用了Thread thread; //定义线程,thread = new Thread()方法、thread.Start()、thread.Interrupt()、Thread.Sleep()方法。

        其中,thread.Abort();  //已经废弃,用thread.Interrupt();代替。   

3.使用IEnumerable()迭代器

        详见本文作者写的其他文章, C#字符串倒序遍历:Reverse() vs for循环 vs IEnumerable迭代器 vs List<T> vs List<T>迭代器 vs IList<T> vs IList<T>迭代器-CSDN博客  https://wenchm.blog.csdn.net/article/details/136120594

二、实例

        为了使界面具有动态效果,可以在界面中实现一些特殊文字的动态效果。使用迭代器遍历文本字符串中的每一个文字,然后使用GDI+技术在窗体上以不同的字体样式依次绘制每一个文字,以便实现文字的动态效果。

1.源码

// 使用迭代器实现文字的动态效果
// 给窗体添加背景图
using System.Resources;

namespace _123
{
    public partial class Form1 : Form
    {
        private Panel? panel1;

        public Form1()
        {
            InitializeComponent();
            BackgroundImage = Properties.Resources.GetObject("bc");
            BackgroundImageLayout = ImageLayout.Stretch;
            StartPosition = FormStartPosition.CenterScreen;
            Load += Form1_Load;
        }

        private void Form1_Load(object? sender, EventArgs e)
        {
            // 
            // panel1
            // 
            panel1 = new Panel
            {
                Location = new Point(321, 12),
                Name = "panel1",
                Size = new Size(250, 83),
                TabIndex = 0
            };
            // 
            // Form1
            // 
            AutoScaleDimensions = new SizeF(7F, 17F);
            AutoScaleMode = AutoScaleMode.Font;
            ClientSize = new Size(600, 416);
            Controls.Add(panel1);
            Name = "Form1";
            Text = "使用迭代器实现文字的动态效果";

            //Graphics Car_Paint = panel1.CreateGraphics();//实例化绘图对象
            string CartoonString = "编程词典网";            //定义要绘制的动态文字
            Character character = new();                   //实例化自定义类对象
            character.CartoonEffect(panel1, CartoonString);//在窗体上显示动态文字
        }
    }

    class Character
    {
        Graphics? graphics;                           //定义Graphics对象
        static readonly int[] FSize = [20, 25, 30];   //设置字体的大小
        readonly int Str_block = 5;                   //字体间的间隔
        readonly Font Str_Font = new("宋体", FSize[0], FontStyle.Bold);//定义字体样式
        readonly Color Str_Color = Color.Orange;      //定义字体颜色
        float Str_Width = 0;    //获取字符串的位置
        float Str_Height = 0;
        float Panel_W = 0;      //获取控件的宽度
        float Panel_H = 0;      //获取控件的高度
        Color Panel_C;          //记录控件的背景颜色
        float Str_Odd_Width = 0;//获取单个文字的宽度
        Thread? thread;         //定义线程

        /// <summary>
        /// 在Panel控件中绘制动画文字
        /// </summary>
        /// <param Panel="C_Panel">显示文字的容器控件</param>
        /// <param string="C_Str">文字字符串</param>
        public void CartoonEffect(Panel C_Panel, string C_Str)
        {
            graphics = C_Panel.CreateGraphics();//为控件创建Graphics对象
            Panel_H = C_Panel.Height;           //获取控件的高度
            Panel_W = C_Panel.Width;            //获取控件的宽度
            Panel_C = C_Panel.BackColor;        //获取控件背景颜色
            GetTextInfo(C_Str);                 //获取文字的大小及位置
            graphics.FillRectangle(             //用控件背景填充控件
                new SolidBrush(Panel_C), 0, 0, Panel_W, Panel_H);
            DrawFullText(C_Str, 0);             //绘制文字
            //实例化ParameterizedThreadStart委托线程
            thread = new Thread(new ParameterizedThreadStart(DynamicText!));
            thread.Start(C_Str);                //传递一个字符串的参数
        }

        /// <summary>
        /// 获取文字的大小及绘制位置
        /// </summary>
        /// <param string="C_Str">文字字符串</param>
        public void GetTextInfo(string C_Str)
        {
            SizeF TitSize = graphics!.MeasureString(C_Str, Str_Font); //将绘制的字符串进行格式化
            Str_Width = TitSize.Width;                           //获取字符串的宽度
            Str_Height = TitSize.Height;                         //获取字符串的高度
            Str_Odd_Width = Str_Width / C_Str.Length;            //获取单个文字的宽度
            Str_Width = (Str_Odd_Width + Str_block) * C_Str.Length; //获取文字的宽度
            Str_Width = (Panel_W - Str_Width) / 2F;              //使文字居中
            Str_Height = Panel_H - Str_Height;                   //使文字显示在控件底端
        }

        /// <summary>
        /// 绘制全部文字
        /// </summary>
        /// <param string="C_Str">绘制的文字字符串</param>
        public void DrawFullText(string C_Str, int n)
        {
            float Str_Place = Str_Width;          //单个字符的位置
            for (int i = 0; i < C_Str.Length; i++)//遍历字符串中的文字
            {
                if (i != n)
                    DrawText(C_Str[i].ToString(), Str_Font, Str_Place, Str_Height); //绘制单个文字
                Str_Place += Str_Odd_Width + Str_block;                             //获取下一个文字的位置
            }
        }

        /// <summary>
        /// 绘制单个文字
        /// </summary>
        /// <param name="C_Odd_Str">单个文字字符串</param>
        /// <param name="S_Font">文本样式</param>
        /// <param name="left"></param>
        /// <param name="top"></param>
        public void DrawText(string C_Odd_Str, Font S_Font, float left, float top)
        {
            graphics!.DrawString(C_Odd_Str, S_Font, new SolidBrush(Str_Color), new PointF(left, top));//绘制字符串中单个文字
        }

        /// <summary>
        /// 通过迭代器实现字符串的遍历
        /// </summary>
        /// <param string="n">文字字符串</param>
        /// <returns>返回单个文字</returns>
        public static IEnumerable<object> Transpose(string n)
        {
            if (n.Length > 0)
            {
                foreach (object i in n)
                    yield return i;
            }
        }

        /// <summary>
        /// 绘制动态文字
        /// </summary>
        /// <param string="C_Str">绘制的文字字符串</param>
        public void DynamicText(Object C_Str)
        {
            float tem_left = 0;             //获取当前文字的左端位置
            float tem_top = 0;              //获取当前文字的顶端位置
            float tem_width = 0;            //获取文字的宽度
            float tem_high = 0;             //获取文字的高度
            float tem_place = Str_Width;    //获取起始文字的位置
            Font Tem_Font = new("黑体", FSize[0], FontStyle.Bold);//定义字体样式
            int p = 0;                      //记录字符串中文字的索引号
            int Str_Index = 0;
            try
            {
                foreach (object s in Transpose(C_Str.ToString()!))//遍历字符串
                {
                    for (int i = 1; i < 5; i++)
                    {
                        if (i >= 3)
                            p = Convert.ToInt16(Math.Floor(i / 2F));
                        else
                            p = i;
                        DrawFullText(C_Str.ToString()!, Str_Index);
                        Tem_Font = new Font("黑体", FSize[p], FontStyle.Bold);//定义字体样式            
                        SizeF TitSize = graphics!.MeasureString(s.ToString(),Str_Font);//将绘制的单个文字进行格式化 
                        tem_width = TitSize.Width;//获取文字的宽度
                        tem_high = TitSize.Height;//获取文字串的高度
                        tem_left = tem_place - (tem_width - Str_Odd_Width) / 2F;//获取文字改变大小后的左端位置       
                        tem_top = Str_Height - (Str_Height - tem_high) / 2F;  //获取文字改变大小后的顶端位置              
                        DrawText(s.ToString()!, Tem_Font, tem_left, tem_top); //绘制单个文字             
                        Thread.Sleep(200);         //待待0.2秒
                        graphics.FillRectangle(new SolidBrush(Panel_C), 0, 0, Panel_W,Panel_H);//清空绘制的文字
                    }
                    tem_place += Str_Odd_Width + Str_block;//计算下一个文字的左端位置                               
                    Str_Index += 1;                 //将索引号定位到下一个文字
                }
                DrawFullText(C_Str.ToString()!, -1);//恢复文字的原始绘制样式
                //实例化ParameterizedThreadStart委托线程
                thread = new Thread(new ParameterizedThreadStart(DynamicText!));
                thread.Start(C_Str);                 //传递一个字符串的参数
            }
            catch//这里之所以用异常语句,是在关闭窗体时关闭线程
            {
                //thread.Abort();   //已经废弃
                thread!.Interrupt(); //关闭线程
            }
        }
    }
}

2.生成效果:

 C#使用迭代器实现文字的动态效果,c#,运维,开发语言文章来源地址https://www.toymoban.com/news/detail-825606.html

到了这里,关于C#使用迭代器实现文字的动态效果的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • [C#]使用OpenCvSharp实现区域文字提取

    【官方框架地址】 github.com/shimat/opencvsharp 【算法介绍】 采用opencv算法实现文字区域提取,步骤如下: (1)形态学操作 (2)查找轮廓 (3)筛选那些面积小的 (4)面积小的都筛选 (5)找到最小的矩形 【效果展示】 原图 提取结果: 【实现部分代码】 【源码下载】 https:

    2024年02月02日
    浏览(44)
  • 前端使用scale属性结合CSS动态样式实现动态的图片缩放效果

    废话不多说,直接上代码: 示例一,使用css动态样式结合scale进行src图片的缩放。 示例二,使用css动态样式结合scale进行background背景图图片的缩放。

    2024年01月15日
    浏览(63)
  • 文字效果 用背景渐变实现 波浪背景文字

    1. 实现波浪背景 原理:透明到纯色的径向渐变,然后复制该渐变背景,最后加上背景水平方向移动的无限循环动画 2. 文字波浪背景 将该渐变应用在文本标签上,并添加一下css属性 最后,在做一些适当调整,比如弧度衔接处 动画时间等 。搞定 3. 总结 波浪的本质上是一个曲

    2024年02月08日
    浏览(52)
  • 【游戏开发算法每日一记】使用随机prime算法生成错综复杂效果的迷宫(C#,C++和Unity版)

    👨‍💻个人主页 :@元宇宙-秩沅 👨‍💻 hallo 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍💻 本文由 秩沅 原创 👨‍💻 收录于专栏 :Unity基础实战 1.首先全部判定为墙,最外的为路包裹墙( 类似于防止数组越界 ) 2.红色为它的检测范围(假设检测点在如图所示的位置)—

    2024年02月05日
    浏览(42)
  • django使用ztree实现树状结构效果,子节点实现动态加载(l懒加载)

         由于最近项目中需要实现树状结构的效果,考虑到ztree这个组件大家用的比较多,因此打算在django项目中集成ztree来实现树状的效果。最终实现的示例效果如下:         点击父节点,如果有子节点,则从后台动态请求数据,然后显示出子节点的数据。             

    2024年02月14日
    浏览(52)
  • 实现ChatGPT的文字输出效果

    原文发表于zhu\\\'s Blog       阿猪是计算机业余爱好者,把网页做得美观高大上对阿猪是一种折磨和挑战,所以阿猪做出来的网页都是清一色的word文档风格。为了给low逼的网页提升点儿逼格,阿猪决定模仿一下ChatGPT的文字输出效果。       先上效果图::       以下是完整代

    2024年02月02日
    浏览(36)
  • 记录-css实现交融文字效果

    CSS是有魔法的,我们今天来实现一个CSS的动画效果,只需要几行代码就可以搞定。 以上是基础代码结构,通过调整letter-spacing的值,我们可以控制他的展开与收起。值越小为负数时文字就可以挤在一起,越大文字间距就越大。 默认值为0时正常显示的效果   小于正常值的效果

    2023年04月11日
    浏览(63)
  • CSS实现文字描边效果

    一、介绍 最近在一个项目的宣传页中,设计师使用了文字描边效果,之前我确实没有实现过文字的描边效果,然后我在查阅资料后,知道了实现方法。文字描边分为两种:内外双描边和单外描边,也就是指在给文字加上描边效果后,描边的方向是向内外同时占用文字空间还是

    2023年04月09日
    浏览(76)
  • css如何实现文字两端对齐效果

    想要实现文字两端对齐效果,可以使用CSS的text-align属性。设置text-align: justify;即可实现文字两端对齐效果。 方法1 : 给元素设置 text-align: justify; text-align-last: justify;并且加上 text-justify: distribute-all-line; 目的是兼容ie浏览器 p{             width: 130px;             te

    2024年02月01日
    浏览(60)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包