ThinkPHP水印功能实现修复PNG透明水印并增加JPEG图片质量可调整
本文实例讲述了ThinkPHP水印功能实现修复PNG透明水印并增加JPEG图片质量可调整的方法。分享给大家供大家参考。具体实现方法如下:
TP自带有图片类,有给图片加水印的功能。
这里完善了:
1. png水印透明
2. 加水印后质量调整(只限于JPG格式)
代码如下:
/**
+———————————————————-
* 为图片添加水印
+———————————————————-
* @static public
+———————————————————-
* @param string $source 原文件名
* @param string $water 水印图片
* @param string $$savename 添加水印后的图片名
* @param string $alpha 水印的透明度
+———————————————————-
* @return string
+———————————————————-
* @throws ThinkExecption
+———————————————————-
*/
static public function water($source, $water, $savename=null, $alpha=80) {
//检查文件是否存在
if (!file_exists($source) || !file_exists($water))
return false;//图片信息
$sInfo = self::getImageInfo($source);
$wInfo = self::getImageInfo($water);//如果图片小于水印图片,不生成图片
if ($sInfo["width"] < $wInfo["width"] || $sInfo['height'] < $wInfo['height'])
return false;//建立图像
$sCreateFun = "imagecreatefrom" . $sInfo['type'];
$sImage = $sCreateFun($source);
$wCreateFun = "imagecreatefrom" . $wInfo['type'];
$wImage = $wCreateFun($water);//设定图像的混色模式
imagealphablending($wImage, true);//图像位置,默认为右下角右对齐
$posY = $sInfo["height"] – $wInfo["height"];
$posX = $sInfo["width"] – $wInfo["width"];/* 为了保持PNG的透明效果 使用imagecopy 此处为修改过的*/
imagecopy($sImage, $wImage, $posX, $posY, 0, 0, $wInfo['width'], $wInfo['height']);
//生成混合图像,这是系统的
// imagecopymerge($sImage, $wImage, $posX, $posY, 0, 0, $wInfo['width'],$wInfo['height'], $alpha);
//输出图像
$ImageFun = 'Image' . $sInfo['type'];
//如果没有给出保存文件名,默认为原图像名
if (!$savename) {
$savename = $source;
@unlink($source);
}
//保存图像,如果是jpg,则设置一下水印质量 此处为修改过的:
if ($sInfo['type'] == "jpg" || $sInfo['type'] == "jpeg") {
imagejpeg($sImage, $savename, 90);//第3个参数即使质量大小,因为只有imagejpeg支持这个参数
} else {
$ImageFun($sImage, $savename);
}
//$ImageFun($sImage, $savename);//这是系统的
imagedestroy($sImage);
}
希望本文所述对大家的ThinkPHP框架程序设计有所帮助。
您可能感兴趣的文章:
- ThinkPHP水印功能实现修复PNG透明水印并增加JPEG图片质量可调整
- ThinkPHP水印功能,修复PNG透明水印增加JPEG图片质量可调整
- metinfo 5.0图片水印bug修改和支持透明背景png水印功能的增加
- Nodejs跨平台轻量级图片编解码库【增加Jpeg质量调整】
- Nodejs跨平台轻量级图片编解码库【增加Jpeg质量调整】
- png图片IE6下实现透明
- ie6下png图片背景不透明的解决办法使用js实现
- 纯win32实现PNG图片透明窗体
- 用 javascript 修复 IE 下 PNG 图片不能透明显示的方法
- HTML+CSS----IE6下背景透明实现-css/js--png图片
- C# :实现水印与图片合成,并利用Graphics 压缩图像质量 , (委托实现listBox的动态添加提示)
- 图片质量压缩 与 图片格式 JPEG PNG
- JS模拟实现图片添加水印功能
- jQuery实现简单的图片轮播(二)-增加左右(或上下)翻页功能
- 用AspJpeg调整文字水印透明,生成图片水印的效果
- IE6实现PNG图片透明
- 使用mac OS自带预览功能制作透明背景的PNG图片
- Java调整图片大小合并PNG图片生成ICON(保持背景透明)
- 使用分层窗口及透明png图片实现一个异形窗口