zoukankan      html  css  js  c++  java
  • 这些年我收集的GDI+代码2

    这些年我收集的GDI+代码2

      这些年在工作中有空的时候经常拿VS出来画个图玩玩,还是蛮有意思的事情。下面我们就来看看用GDI+是如何实现验证码功能的吧。

      首先,我们先来看看如何在winform上面写文字,以此来做个铺垫。

    图一、文字效果图

     

    图二、验证码

      当我们看到了一个验证码的时候,我们有什么思路呢?是不是看到了数字长的很奇怪呢?是不是单击的时候字会改变呢?是不是字体的颜色也不一样呢?是不是一眼看不清呢?这样做的目的都是为了防止某些邪恶的人用机器来注册。

      思路1:里面的数是随机生成的

      下面进入正式的部分。

    1. 验证码得到随机数

    我们在网上点击的时候,是不是点击的是一张图片呢?所以应该在窗体上拖一个图片控件,而且用的是图片的点击事件。

     

    图三、验证码得到随机数

    我在代码上的注释非常清晰,大家可以参见我上面的注释。

    到这步,我们面临两个问题,一个是字体,一个是颜色。那么,我们需要两个数组,一个放字体,一个放颜色。

     

    图四、给验证码改变颜色和字体

     

    图五、完善验证码的颜色和字体

    每画一次上一个颜色,所以上面的代码中用for循环。当我们实现到这一步的时候就差最后数字上面的噪点了,大家想一想,是不是就差一些线呢?这些线的长度最常到哪儿?比如:画十条线的话,就是一个for循环。

     

    图六、画噪点

      最终,经过我们的努力来看看最后的效果图吧。

     

    图七、最后的效果图

      当我们逐渐的接触到aspdot.net的时候,我们会发现这样的验证码是不用我们手工绘制的,然而,在画验证码时我们用的基础的编程思路是需要掌握的。很多精美的GDI+图都是这么做出来的。


    作者近期文章:

  • 相关阅读:
    [css]继承关系(一)
    Trie树-提高海量数据的模糊查询性能
    [C]struct结构化数据的一些要点
    [C]表达式结合规律和运算符优先级
    [C]副作用和序列点
    [C]链接和生存周期
    [PHP]关于连接MySQL的问题
    IT网址大全
    VUE 生命周期
    Vue 组件间传值
  • 原文地址:https://www.cnblogs.com/zysbk/p/2613361.html
Copyright © 2011-2022 走看看