思路
使用图层的方法设计,共需要创建3个图像层
1.底层:最后生成的图像
2.真实用户头像:作为中间层,用户上传的真实头像图片
3.圆形蒙版:作为最上层,在蒙版中绘制圆形,并设置为透明
如图:
代码如下:
主功能类 avatar.class.php
<"无法读取图像文件"); } if(!in_array($this->imgInfo[2], array(2,3))){ //仅允许jpg和png throw Exception("图像格式不支持"); } } /** * 显示图像 * Enter description here ... */ public function show() { header("content-type:image/png"); $shadow = $this->createshadow(); //遮罩图片 //创建一个方形图片 $imgbk = imagecreatetruecolor($this->size, $this->size); //目标图片 switch ($this->imgInfo[2]){ case 2: $imgfk = imagecreatefromjpeg($this->fileName); //原素材图片 break; case 3: $imgfk = imagecreatefrompng($this->fileName); //原素材图片 default: return ; break; } $realSize = $this->imgInfo[0]<$this->imgInfo[1]? $this->imgInfo[0] : $this->imgInfo[1]; imagecopyresized($imgbk, $imgfk, 0, 0, 0, 0, $this->size, $this->size, $realSize, $realSize); imagecopymerge($imgbk, $shadow, 0, 0, 0, 0, $this->size, $this->size, 100); //创建图像 imagepng($imgbk); //销毁资源 imagedestroy($imgbk); imagedestroy($imgfk); imagedestroy($shadow); } /** * 创建一个圆形遮罩 * Enter description here ... * @param array 10进制颜色数组 */ private function createshadow() { $img = imagecreatetruecolor($this->size, $this->size); imageantialias($img, true); //开启抗锯齿 $color_bg = imagecolorallocate($img, $this->rgb[0], $this->rgb[1], $this->rgb[2]); //背景色 $color_fg = imagecolorallocate($img, 0, 0, 0); //前景色,主要用来创建圆形 imagefilledrectangle($img, 0, 0, 200, 200, $color_bg); imagefilledarc($img, 100, 100, 200, 200, 0, 0, $color_fg, IMG_ARC_PIE); imagecolortransparent($img, $color_fg); //将前景色转换为透明 return $img; } /** * 将字符形式16进制串转为10进制 * Enter description here ... * @param $str */ private function getIntFromHexStr($str) { $format = '0123456789abcdef'; $sum = 0; for($i=strlen($str)-1, $c=0, $j=0; $i>=$c; $i--,$j++){ $index = strpos($format, $str[$i]);//strpos从0计算 $sum+=$index * pow(16,$j); } return $sum; } /** * 将16进制颜色转为10进制颜色值数组(RGB) * Enter description here ... * @param $str 16进制串(如:ff9900) */ private function createRGB($str) { $rgb = array(); if(strlen($str) != 6){ $rgb[] = 0xff; $rgb[] = 0xff; $rgb[] = 0xff; return $rgb; //默认白色 } $rgb[] = $this->getIntFromHexStr(substr($str, 0, 2)); $rgb[] = $this->getIntFromHexStr(substr($str, 2, 2)); $rgb[] = $this->getIntFromHexStr(substr($str, 4, 2)); return $rgb; } }
以上这篇php制作圆形用户头像的实例_自定义封装类源代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月16日
2024年11月16日
- 林隆璇.1989-愤怒的情歌【巨石】【WAV+CUE】
- 勤琴《海上花》[DTS-WAV分轨]
- 群星《歌声有故事》[DTS-WAV分轨]
- [发烧人声]群星《邂逅》DTS-WAV
- 艻打绿《夏/狂热(苏打绿版)》[320K/MP3][106.42MB]
- 艻打绿《夏/狂热(苏打绿版)》[FLAC分轨][574.2MB]
- 黄雨勳《魔法列车首部曲》[320K/MP3][33.1MB]
- 李蕙敏.2014-记得·销魂新歌+精丫乐意唱片】【WAV+CUE】
- 谢金燕.1995-含泪跳恰蔷冠登】【WAV+CUE】
- 于文文.2024-天蝎座【华纳】【FLAC分轨】
- 黄雨勳《魔法列车首部曲》[FLAC/分轨][173.61MB]
- 群星《歌手2024 第13期》[320K/MP3][50.09MB]
- 群星《歌手2024 第13期》[FLAC/分轨][325.93MB]
- 阿木乃《爱情买卖》DTS-ES【NRG镜像】
- 江蕾《爱是这样甜》DTS-WAV