因为个人不是对PS熟悉,不清楚如何在PS中生成一张横向有序的spirte图片,使用了"css sprite V4.3"版本,生成的图片会出现压缩图片大小的情况,本想修改原作者开发的程序,但是不懂C#,只好使用PHP gd库进行生成css spirte图片。
<?php
header("Content-type: image/png");
$path = "output";//建议这个文件目录下放入所有需要生成css spirte的图片 //循环源文件目录
$handle = opendir($path);
$files = array();
//读入源目录下的所有文件
while(false !== ($file = readdir($handle))) {
if ($file != '.' && $file != '..') {
$filename = $path . "/" . $file;
if(is_file($filename)) {
//$files[] = $filename;
$files[] = str_replace(".png","",$file);
}else {
//$files = array_merge($files, get_files($filename));
//$files = array_merge($files, str_replace(".png","",$file));
}
}
} // end while
closedir($handle); sort($files); //图片裁剪
// 缩略后的大小
/*$xx = 79;
$yy = 214;
foreach($files as $key=>$value){
//var_dump(getimagesize($value));
$src = $path.'/' . $value.'.png';
list($src_w,$src_h)=getimagesize($src);
$img = imagecreatefrompng($src);
imagesavealpha($img,true);
//很重要;
$newImg = imagecreatetruecolor($xx ,$yy);
imagealphablending($newImg,false);
//很重要,意思是不合并颜色,直接用$img图像颜色替换,包括透明色;
imagesavealpha($newImg,true);
//很重要,意思是不要丢了$newImg图像的透明色;
imagecopy($newImg,$img,0,0,0,0,$src_w,$src_h);
imagepng($newImg,$path.'/test/'.$value.'.png');
//imagedestroy($newImg); }
exit();*/ foreach($files as $key=>&$value){
//var_dump(getimagesize($value));
$value = $path.'/' . $value.'.png';
}
unset($value);
$bgImageSize = 0; //透明背景的宽度
$bgImageHeight = 0; //透明底的高度
foreach($files as $key=>$value){
//var_dump(getimagesize($value));
$source[$key]['source'] = imagecreatefrompng($value);
$source[$key]['size'] = getimagesize($value);
$imageInfo = $source[$key]['size'];
$bgImageSize += $imageInfo[0];
if($imageInfo[1] > $bgImageHeight){
$bgImageHeight = $imageInfo[1];
}
} $img = imagecreatetruecolor($bgImageSize, $bgImageHeight);
imagesavealpha($img,true);
imagealphablending($img,false);//这里很重要,意思是不合并颜色,直接用$img图像颜色替换,包括透明色;
imagesavealpha($img,true);//这里很重要,意思是不要丢了$thumb图像的透明色; $source = array(); foreach($files as $key=>$value){
//var_dump(getimagesize($value));
$source[$key]['source'] = imagecreatefrompng($value);
$source[$key]['size'] = getimagesize($value);
} $dst_y = 0; //图片之间的间距 foreach($source as $key=>$value){
//bool imagecopy ( resource $dst_im , resource $src_im , int $dst_x , int $dst_y , int $src_x , int $src_y , int $src_w , int $src_h )
$sourceInfo = $source[$key]['size'];
$dst_x = $key * $sourceInfo[0];
imagecopy($img, $source[$key]['source'], $dst_x, $dst_y, 0, 0, $sourceInfo[0], $sourceInfo[1]);
}
//定为文件名
$date = date("ymd_His").'_'.mt_rand(0,10);
imagepng($img,'image'.$date.'.png');
imagedestroy($img);
随笔参考
注:
1. 我的output目录下是,我放的是手动修改成文件名有序的文件,故code中没有文件名排序部分,图片是从Flash cs6中编辑fla"导出Sprite"获取到的。
----2016-03-13 更新
处理了剪切图片部分,剪切部分参考了: