前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >GDI+ 不求人之-自己画个验证码

GDI+ 不求人之-自己画个验证码

作者头像
用户9857551
发布2022-06-28 08:51:26
3810
发布2022-06-28 08:51:26
举报
文章被收录于专栏:Angular学习规划

GDI+ 不求人之-自己画个验证码

😃😃😃😃😃😃🤔🤔🤔🤔🤔🤔 简单来说就是画图的 先小试牛刀画个小图形

在这里插入图片描述
在这里插入图片描述

在点击事件里写下几行画正方形:

代码语言:javascript
复制
			Graphics g = this.CreateGraphics();
            Pen pen = new Pen(Brushes.Black);
            Rectangle rec = new Rectangle(50,50,80,80);
            g.DrawRectangle(pen,rec);

在点击事件里写下几行画扇形:

代码语言:javascript
复制
            Graphics g = this.CreateGraphics();
            Pen pen = new Pen(Brushes.Red);
            Rectangle rec = new Rectangle(300, 150, 180, 180);
            g.DrawPie(pen, rec, 160, 60);

😁😁😁😁😁😁😁😁😁😁😁😁😁😁😁😁😁😁😁😁😁分割线 简单图形练手已经结束,让我们开始

自己画验证码

准备材料 1.一个pictureBox放验证码 先展示结果:

结果展示

第一张图片

第二图,每次都不一样

在这里插入图片描述
在这里插入图片描述

先解释一下步骤

  1. 创建一个随机数组等待输出
  2. 开始画图片,建GDI对象,FromImage(bmp)里边要一个image 但是Bitmap是继承与image的所以可行(里氏转换)
  3. g.DrawString(str[i].ToString(), new Font(fonts[r.Next(0, 5)], 15, FontStyle.Bold), new SolidBrush(colors[r.Next(0, 5)]), p);画图,提前写好字体,颜色画的时候随机调用
  4. 画捣乱的(不让你看清的)线
  5. 加点像素颗粒继续让你看不清
  6. 将图片镶嵌到PictBox里边

那么开始看源码:

代码语言:javascript
复制
private void pictureBox1_Click(object sender, EventArgs e)
        {
            Random r = new Random();
            string str = null;
            for (int i = 0; i < 5; i++)
            {
                int rNumber = r.Next(0, 10);
                str += rNumber;
            }
            //MessageBox.Show(str);
            //开始画图片
            //创建GDI对象 
            Bitmap bmp = new Bitmap(120, 25);
            //FromImage(bmp)里边要一个image 但是Bitmap是继承与image的所以可行(里氏转换)
            Graphics g = Graphics.FromImage(bmp);

            for (int i = 0; i < 5; i++)
            {
                Point p = new Point(i * 20, 0);
                string[] fonts = { "微軟雅黑", "宋體", "黑體", "隸書", "仿宋" };
                Color[] colors = { Color.Blue, Color.Red, Color.Yellow, Color.Salmon, Color.Green };
                g.DrawString(str[i].ToString(), new Font(fonts[r.Next(0, 5)], 15, FontStyle.Bold), new SolidBrush(colors[r.Next(0, 5)]), p);
            }
            //画捣乱的(不让你看清的)线
            for (int i = 0; i < 20; i++)
            {
                Point p1 = new Point(r.Next(r.Next(0, bmp.Width)), r.Next(0, bmp.Height));
                Point p2 = new Point(r.Next(r.Next(0, bmp.Width)), r.Next(0, bmp.Height));
                g.DrawLine(new Pen(Brushes.Green), p1, p2);
            }
            //加点像素颗粒继续让你看不清
            for (int i = 0; i < 200; i++)
            {
                Point p = new Point(r.Next(r.Next(0, bmp.Width)), r.Next(0, bmp.Height));
                bmp.SetPixel(p.X, p.Y, Color.Black);
            }
            //将图片镶嵌到PictBox里边
            pictureBox1.Image = bmp;
        }
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-12-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • GDI+ 不求人之-自己画个验证码
  • 自己画验证码
相关产品与服务
验证码
腾讯云新一代行为验证码(Captcha),基于十道安全栅栏, 为网页、App、小程序开发者打造立体、全面的人机验证。最大程度保护注册登录、活动秒杀、点赞发帖、数据保护等各大场景下业务安全的同时,提供更精细化的用户体验。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档