PHP实现中文圆形印章特效

方法一:

<?php
/*
 * 中文圆形印章类
 * @author lkk/lianq.net
 * @create on 10:03 2012-5-29
 * @example:
 * $seal = new circleSeal('你我他坐站走东西南北中',75,6,24,0,0,16,40);
 * $seal->doImg();
 */

class circleSeal {
  private $sealString;  //印章字符
  private $strMaxLeng;  //最大字符长度
  private $sealRadius;  //印章半径
  private $rimWidth;   //边框厚度
  private $innerRadius;  //内圆半径
  private $startRadius;  //五角星半径
  private $startAngle;  //五角星倾斜角度
  private $backGround;  //印章颜色
  private $centerDot;   //圆心坐标
  private $img;      //图形资源句柄
  private $font;     //指定的字体
  private $fontSize;   //指定字体大小
  private $width;     //图片宽度
  private $height;    //图片高度
  private $points;    //五角星各点坐标
  private $charRadius;  //字符串半径
  private $charAngle;   //字符串倾斜角度
  private $spacing;    //字符间隔角度

  //构造方法
  public function __construct($str ='', $rad = 75, $rmwidth = 6, $strad = 24, $stang = 0, $crang = 0, $fsize = 16, $inrad =0){
    $this->sealString  = empty($str) ? '印章测试字符串' : $str;
    $this->strMaxLeng  = 12;
    $this->sealRadius  = $rad;
    $this->rimWidth   = $rmwidth;
    $this->startRadius = $strad;
    $this->startAngle  = $stang;
    $this->charAngle  = $crang;
    $this->centerDot  = array('x'=>$rad, 'y'=>$rad);
    $this->font     = dirname(__FILE__) .'/simkai.ttf';
    $this->fontSize   = $fsize;
    $this->innerRadius = $inrad;  //默认0,没有
    $this->spacing   = 1;
  }

  //创建图片资源
  private function createImg(){
    $this->width    = 2 * $this->sealRadius;
    $this->height    = 2 * $this->sealRadius;
    $this->img     = imagecreate($this->width, $this->height);
    imagecolorresolvealpha($this->img,255,255,255,127);
    $this->backGround  = imagecolorallocate($this->img,255,0,0);
  }

  //画印章边框
  private function drawRim(){
    for($i=0;$i<$this->rimWidth;$i++){
      imagearc($this->img,$this->centerDot['x'],$this->centerDot['y'],$this->width - $i,$this->height - $i,0,360,$this->backGround);
    }
  }

  //画内圆
  private function drawInnerCircle(){
    imagearc($this->img,$this->centerDot['x'],$this->centerDot['y'],2*$this->innerRadius,2*$this->innerRadius,0,360,$this->backGround);
  }

  //画字符串
  private function drawString(){
    //编码处理
    $charset = mb_detect_encoding($this->sealString);
    if($charset != 'UTF-8'){
      $this->sealString = mb_convert_encoding($this->sealString, 'UTF-8', 'GBK');
    }

    //相关计量
    $this->charRadius = $this->sealRadius - $this->rimWidth - $this->fontSize; //字符串半径
    $leng  = mb_strlen($this->sealString,'utf8'); //字符串长度
    if($leng > $this->strMaxLeng) $leng = $this->strMaxLeng;
    $avgAngle  = 360 / ($this->strMaxLeng);  //平均字符倾斜度

    //拆分并写入字符串
    $words = array(); //字符数组
    for($i=0;$i<$leng;$i++){
      $words[] = mb_substr($this->sealString,$i,1,'utf8');
      $r = 630 + $this->charAngle + $avgAngle*($i - $leng/2) + $this->spacing*($i-1);   //坐标角度
      $R = 720 - $this->charAngle + $avgAngle*($leng-2*$i-1)/2 + $this->spacing*(1-$i);  //字符角度
      $x = $this->centerDot['x'] + $this->charRadius * cos(deg2rad($r)); //字符的x坐标
      $y = $this->centerDot['y'] + $this->charRadius * sin(deg2rad($r)); //字符的y坐标
      imagettftext($this->img, $this->fontSize, $R, $x, $y, $this->backGround, $this->font, $words[$i]);
    }
  }  

  //画五角星
  private function drawStart(){
    $ang_out = 18 + $this->startAngle;
    $ang_in = 56 + $this->startAngle;
    $rad_out = $this->startRadius;
    $rad_in = $rad_out * 0.382;
    for($i=0;$i<5;$i++){
      //五个顶点坐标
      $this->points[] = $rad_out * cos(2*M_PI/5*$i - deg2rad($ang_out)) + $this->centerDot['x'];
      $this->points[] = $rad_out * sin(2*M_PI/5*$i - deg2rad($ang_out)) + $this->centerDot['y'];

      //内凹的点坐标
      $this->points[] = $rad_in * cos(2*M_PI/5*($i+1) - deg2rad($ang_in)) + $this->centerDot['x'];
      $this->points[] = $rad_in * sin(2*M_PI/5*($i+1) - deg2rad($ang_in)) + $this->centerDot['y'];
    }
    imagefilledpolygon($this->img, $this->points, 10, $this->backGround);
  }

  //输出
  private function outPut(){
    header('Content-type:image/png');
    imagepng($this->img);
    imagedestroy($this->img);
  }

  //对外生成
  public function doImg(){
    $this->createImg();
    $this->drawRim();
    $this->drawInnerCircle();
    $this->drawString();
    $this->drawStart();
    $this->outPut();
  }
}

方法二:

<?php
@$hos=iconv("GBK", "UTF-8", $_GET["hos"]);
if(!isset($hos))
exit;

$im=ImageCreate(150,150);
$gray=ImageColorResolveAlpha($im,200,200,200,127);
$red=ImageColorAllocate($im,230,150,150);

for($i=0;$i<6;$i++)
ImageArc($im,75,75,148-$i,148-$i,0,360,$red);

$stock='C:\WINDOWS\Fonts\simkai.ttf';
$point="★";
$size=30;
ImageTTFText($im,$size,0,72-$size/2,72+$size/2,$red,$stock,$point);

$a=75;$b=-75;//中心点坐标
$r=65;$m=40;//半径,角度
$size=16;//字体大小
$r=$r-$size;

$word=array();
$max=18;
$count=mb_strlen($hos,'utf8');
if($count>$max)$count=$max;
if($count>12)
$m=floor(360/$count);
else if($count>5)
$m-=$count;

for($i=0;$i<$count;$i++)
$word[]=mb_substr($hos,$i,1,'utf8');

$j=floor($count/2);
if($j!=$count/2)
{
 for($i=$j;$i>=0;$i--)
 {
 $arc=$m*($j-$i)+$size/2;
 $x=round($r*cos((90+$arc)*M_PI/180))+$a;
 $y=-1*(round($r*sin((90+$arc)*M_PI/180))+$b);
 if($arc<10)$arc=0;
 ImageTTFText($im,$size,$arc,$x,$y,$red,$stock,$word[$i]);
 $arc=$m*($j-$i)-$size/2;
 $x=round($r*cos((90-$arc)*M_PI/180))+$a;
 $y=-1*(round($r*sin((90-$arc)*M_PI/180))+$b);
 if($arc<10)$arc=0;
 ImageTTFText($im,$size,-$arc,$x,$y,$red,$stock,$word[$j+$j-$i]);
 }
}
else
{
 $j=$j-1;
 for($i=$j;$i>=0;$i--)
 {
 $arc=$m/2+$m*($j-$i)+$size/2;
 $x=round($r*cos((90+$arc)*M_PI/180))+$a;
 $y=-1*(round($r*sin((90+$arc)*M_PI/180))+$b);
 ImageTTFText($im,$size,$arc,$x,$y,$red,$stock,$word[$i]);
 $arc=$m/2+$m*($j-$i)-$size/2;
 $x=round($r*cos((90-$arc)*M_PI/180))+$a;
 $y=-1*(round($r*sin((90-$arc)*M_PI/180))+$b);
 ImageTTFText($im,$size,-$arc,$x,$y,$red,$stock,$word[$j+$j+1-$i]);
 }
}

header('Content-Type:image/png');
ImagePNG($im);
?>

以上所述就是本文的全部内容了,希望大家能够喜欢

(0)

相关推荐

  • php绘制圆形的方法

    本文实例讲述了php绘制圆形的方法.分享给大家供大家参考.具体实现方法如下: php绘图的基本步骤,有四步(php.ini里的 extension = php_gb2.dll 组件首先需要启用) 1.创建画布: 2.画出所需要的图像(圆.直线.矩形.扇形.弧线.......): 3.输出到网页,或者另存: 4.销毁图片(目的是释放图像所占用的内存). 网站开发最常用的三种图像格式:gif.jpg/jpeg.png (1)gif格式:压缩率最高,但只能显示256色,可能造成色彩的丢失.优势:可能显

  • PHP中使用GD库创建圆形饼图的例子

    在PHP中,有一些简单的图像函数是可以直接使用的,但大多数要处理的图像,都需要在编译PHP时加上GD库.除了安装GD库之外,在PHP中还可能需要其他的库,这可以根据需要支持哪些图像格式而定.GD库可以在http://www.boutell.com/gd/免费下载,不同的GD版本支持的图像格式不完全一样,最新的GD库版本支持GIF.JPEG.PNG.WBMP.XBM等格式的图像文件,此外还支持一些如FreeType.Type 1等字体库.通过GD库中的函数,可以完成各种点.线.几何图形.文本及颜色

  • PHP实现中文圆形印章特效

    方法一: <?php /* * 中文圆形印章类 * @author lkk/lianq.net * @create on 10:03 2012-5-29 * @example: * $seal = new circleSeal('你我他坐站走东西南北中',75,6,24,0,0,16,40); * $seal->doImg(); */ class circleSeal { private $sealString; //印章字符 private $strMaxLeng; //最大字符长度 pri

  • C#实现自动生成电子印章

    网络办公正逐渐成为常态,无纸化办公也是一个潮流,这二者需要电子签章,最简单的方法就是在纸上盖一个章然后扫描成电子图片文件,最后在你的系统加载这个签章电子图片文件.但这样就会些不理想的地方,如果不是透明的,叠加在有文字等的地方会遮盖了原来的内容:如果做成透明的,图片会失真,看上去很不真实. 那就用代码画一个签章吧,本来以为是挺简单,其实不是.大小.形状.颜色这些都很受容易处理,难点就在文字按椭圆曲线排列上,涉及到字间距.倾斜角度等,实现起来还是要花一点时间的. 既然是要用代码来画,那就要用到 Gr

  • 基于jQuery实现响应式圆形图片轮播特效

    本文实例讲述了基于jQuery实现响应式圆形图片轮播特效代码.分享给大家供大家参考.具体如下: 运行效果截图如下: mislider是一款效果非常酷的jQuery响应式圆形图片轮播图特效插件,mislider轮播图插件的特点有: 使用简单 在同一个屏幕中支持多个轮播图 轮播图的内容可以是单张图片或复杂的HTML内容 轻量级 响应式设计 非常容易定制 丰富的回调函数 跨浏览器,支持IE8+浏览器 引入核心文件 mislider插依赖于一些插件,在引入之前要先引入jQuery.html5shiv.j

  • 爆炸式的JS圆形浮动菜单特效代码

    演示代码 http://demo.jb51.net/js/other/baozha.htm

  • JS实现对中文字符串进行utf-8的Base64编码的方法(使其与Java编码相同)

    本文实例讲述了JS实现对中文字符串进行utf-8的Base64编码的方法.分享给大家供大家参考,具体如下: 要进行编码的字符串:"select 用户名 from 用户" 使用JAVA进行编码,Java程序: String sql = "select 用户名 from 用户"; String encodeStr = new String(Base64.encode(sql.getBytes("UTF-8"))); // 编码 System.out.

  • JS实现含有中文字符串的友好截取功能分析

    本文实例讲述了JS实现含有中文字符串的友好截取功能.分享给大家供大家参考,具体如下: 在显示字符串的时候,避免字符串过长往往会对字符串进行截取操作,通常会用到js 的 substr 或者 substring方法, 以及 字符串的length属性 对于非中文的字符串处理是很简单的,但是中文字符的 length  属性值 是1  而不是 2 ,所以处理就不是很友好了. 例如  你有一个字符串  1234567890   和  一二三四五六七八九零, 你只想显示五位长度,往往会这样操作  str =

  • iOS实现带文字的圆形头像效果

    下面就来实现一下这种效果   圆形头像的绘制 先来看一下效果图 分析一下: 1.首先是需要画带有背景色的圆形头像 2.然后是需要画文字 3.文字是截取的字符串的一部分 4.不同的字符串,圆形的背景色是不一样的 5.对于中英文同样处理,英文的一个字符和中文的一个汉字同样算作一个字符 6.文字总是居中显示 好 有了这样几点 我们就可以开始画图了 看一下最终实现的效果图 首先 ,我们需要自定义一个view当做自定义头像,在view的drawRect方法中进行图像的绘制 @interface Round

  • JS获取中文拼音首字母并通过拼音首字母快速查找页面内对应中文内容的方法【附demo源码】

    本文实例讲述了JS获取中文拼音首字母并通过拼音首字母快速查找页面内对应中文内容的方法.分享给大家供大家参考,具体如下: 实现效果: 图一: 图二: 此例中输入的中文字符串"万万保重",有三个字是多音字,所以alert对话框中显示的是多种读音的组合: 如何实现? 如何实现通过拼音首字母快速查找页面内的中文内容呢? 过程原理是这样的:例如要对一些人名进行快速查找,当页面加载完成后,对所有人名建立一个索引,生成拼音首字母与姓名的对应关系:然后监听键盘事件,当用户按下键盘时,根据键值得到按下的

  • escape函数解决js中ajax传递中文出现乱码问题

    本文实例讲述了escape函数解决js中ajax传递中文出现乱码问题,分享给大家供大家参考.具体方法如下: 一.问题描述: 本来网页特效中的escape()是将中文按iso-8859-1字符集进行url编码的,那样通过 request.getparameter()是能直接获取到请求参数的,但后来的javascript将escape()换成了unicode字符集编 码,如此一来,在jsp教程和servlet中就没法直接拿到请求参数了,具体原因我也不知道. 二.解决办法: 1.首先对中文字符进行两次

  • JQuery的Ajax中Post方法传递中文出现乱码的解决方法

    本文实例讲述了JQuery中Post传递中文出现的解决方法,即乱码ajax与jquery.ajax中文参数post传递乱码处理方法.分享给大家供大家参考.具体分析如下: 问题一: 今天在做项目时,需要用到Ajax,之前我在用GET方式传递中文参数时,只需要在后台程序中设置页面编码为GB2312即中文能正常显示,可是这次由于表单项目较多,不适合用GET方式传递,只能用POST方式,但发现后台程序中设置编码为GB2312时中文还是显示的乱码.经过一番研究问题才最终得到解决. 解决方法: 解决此问题的

随机推荐