摘要:圖片縮放函數(shù)可設(shè)置高度固定,寬度固定或者最大寬高,支持三種類型源圖片目標(biāo)寬度目標(biāo)高度鎖定寬高可選參數(shù)或者空值寬度固定高度固定最大寬或最大高用法最大寬高寬度固定高度固定剪切圖片為固定大小源圖過(guò)高源圖過(guò)寬源圖適中裁剪縮放
/** * 圖片縮放函數(shù)(可設(shè)置高度固定,寬度固定或者最大寬高,支持gif/jpg/png三種類型) * Author : Specs * * @param string $source_path 源圖片 * @param int $target_width 目標(biāo)寬度 * @param int $target_height 目標(biāo)高度 * @param string $fixed_orig 鎖定寬高(可選參數(shù) width、height或者空值) * @return string */ function myImageResize($source_path, $target_width = 200, $target_height = 200, $fixed_orig = ""){ $source_info = getimagesize($source_path); $source_width = $source_info[0]; $source_height = $source_info[1]; $source_mime = $source_info["mime"]; $ratio_orig = $source_width / $source_height; if ($fixed_orig == "width"){ //寬度固定 $target_height = $target_width / $ratio_orig; }elseif ($fixed_orig == "height"){ //高度固定 $target_width = $target_height * $ratio_orig; }else{ //最大寬或最大高 if ($target_width / $target_height > $ratio_orig){ $target_width = $target_height * $ratio_orig; }else{ $target_height = $target_width / $ratio_orig; } } switch ($source_mime){ case "image/gif": $source_image = imagecreatefromgif($source_path); break; case "image/jpeg": $source_image = imagecreatefromjpeg($source_path); break; case "image/png": $source_image = imagecreatefrompng($source_path); break; default: return false; break; } $target_image = imagecreatetruecolor($target_width, $target_height); imagecopyresampled($target_image, $source_image, 0, 0, 0, 0, $target_width, $target_height, $source_width, $source_height); //header("Content-type: image/jpeg"); $imgArr = explode(".", $source_path); $target_path = $imgArr[0] . "_new." . $imgArr[1]; imagejpeg($target_image, $target_path, 100); }
用法:
myImageResize($filename, 200, 200); //最大寬高 myImageResize($filename, 200, 200, "width"); //寬度固定 myImageResize($filename, 200, 200, "height"); //高度固定
剪切圖片為固定大?。?/p>
function imagecropper($source_path, $target_width, $target_height){ $source_info = getimagesize($source_path); $source_width = $source_info[0]; $source_height = $source_info[1]; $source_mime = $source_info["mime"]; $source_ratio = $source_height / $source_width; $target_ratio = $target_height / $target_width; // 源圖過(guò)高 if ($source_ratio > $target_ratio){ $cropped_width = $source_width; $cropped_height = $source_width * $target_ratio; $source_x = 0; $source_y = ($source_height - $cropped_height) / 2; }elseif ($source_ratio < $target_ratio){ // 源圖過(guò)寬 $cropped_width = $source_height / $target_ratio; $cropped_height = $source_height; $source_x = ($source_width - $cropped_width) / 2; $source_y = 0; }else{ // 源圖適中 $cropped_width = $source_width; $cropped_height = $source_height; $source_x = 0; $source_y = 0; } switch ($source_mime){ case "image/gif": $source_image = imagecreatefromgif($source_path); break; case "image/jpeg": $source_image = imagecreatefromjpeg($source_path); break; case "image/png": $source_image = imagecreatefrompng($source_path); break; default: return false; break; } $target_image = imagecreatetruecolor($target_width, $target_height); $cropped_image = imagecreatetruecolor($cropped_width, $cropped_height); // 裁剪 imagecopy($cropped_image, $source_image, 0, 0, $source_x, $source_y, $cropped_width, $cropped_height); // 縮放 imagecopyresampled($target_image, $cropped_image, 0, 0, 0, 0, $target_width, $target_height, $cropped_width, $cropped_height); $dotpos = strrpos($source_path, "."); $imgName = substr($source_path, 0, $dotpos); $suffix = substr($source_path, $dotpos); $imgNew = $imgName . "_small" . $suffix; imagejpeg($target_image, $imgNew, 100); imagedestroy($source_image); imagedestroy($target_image); imagedestroy($cropped_image); }
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/21347.html
摘要:由于在端,不能直接處理本地文件,因此可以在后臺(tái)裁剪圖片,或者利用的來(lái)處理。通過(guò)來(lái)訪問(wèn)生成的步驟獲取裁剪坐標(biāo)參照方法中的步驟步驟利用重繪圖片首先要設(shè)置剪截后的圖片大小相等的。 由于在Web端,JavaScript不能直接處理本地文件,因此可以在后臺(tái)裁剪圖片,或者利用html5的canvas來(lái)處理。 方法1:傳送到后臺(tái)剪切 步驟1:上傳圖片到后臺(tái),向前端返回圖片URL 利用input標(biāo)簽,...
摘要:讀設(shè)備寬度,動(dòng)態(tài)設(shè)置標(biāo)簽的屬性中的值網(wǎng)易的做法網(wǎng)易的做法現(xiàn)在的設(shè)計(jì)稿都是寬度的寬,那要想實(shí)現(xiàn)樣式設(shè)計(jì)圖這種比較方便的折算方式,就要設(shè)置成也就是說(shuō)總結(jié)總結(jié)是為了實(shí)現(xiàn)移動(dòng)端自適應(yīng)布局。適配問(wèn)題 怎么適配iphone6 1px問(wèn)題 為什么頁(yè)面與設(shè)計(jì)稿會(huì)出現(xiàn)偏差? dpr=設(shè)備像素/ css像素,只有dpr等于1的時(shí)候,實(shí)際效果和設(shè)計(jì)稿的尺寸比例才是1:1。 因?yàn)閕Phone6的DPR(設(shè)備像素比)...
閱讀 3627·2021-11-24 09:39
閱讀 2567·2021-11-15 11:37
閱讀 2222·2021-11-11 16:55
閱讀 5244·2021-10-14 09:43
閱讀 3716·2021-10-08 10:05
閱讀 3019·2021-09-13 10:26
閱讀 2337·2021-09-08 09:35
閱讀 3548·2019-08-30 15:55