php - php img 拇指未调整大小
问题描述
我有代码可以从原始图像表单用户中制作拇指。我需要拇指的核心宽度和高度,它是 160 x 160。我的问题不是完美的图片。我的意思是当用户想要添加的 img 女巫比更高时,我的缩略图看起来很糟糕并且被拉伸 - 当原始 img 高于更宽时会发生类似情况 - 然后拇指被严重压缩。我认为我必须使用函数 imagecopyresampled() 进行操作,但我认为这是一个糟糕的选择。我的问题是:如何使拇指不被压缩或拉伸并从原始图像的中心切割它们?我的代码现在看起来像这样:
$imgOrginalsize = getimagesize($file);
$ratio = $imgOrginalsize[0] / $imgOrginalsize[1];
$h = 160;
$w = 160;
$file_name = basename($file);
switch (strtolower($imgOrginalsize['mime'])) {
case 'image/jpeg':
$img = imagecreatefromjpeg($file);
$new = imagecreatetruecolor($w, $h);
imagecopyresampled($new, $img, 0, 0, 0, 0, $w, $h, $imgOrginalsize[0], $imgOrginalsize[1]);
imagejpeg($new, $pathToSave . $file_name, 100);
imagedestroy($new);
break;
case 'image/png':
$img = imagecreatefrompng($file);
$new = imagecreatetruecolor($w, $h);
imagecopyresampled($new, $img, 0, 0, 0, 0, $w, $h, $imgOrginalsize[0], $imgOrginalsize[1]);
imagepng($new, $pathToSave . $file_name, 100);
imagedestroy($new);
break;
default:
var_dump('error default');
exit();
}
现在拇指看起来很糟糕,例如被压缩 - 原始 img 要高得多 oyu 知道我的意思是我不需要在缩略图中的所有图片 - 我可以从左上角(或原始 img 的中心)裁剪,但我没有'不想压缩或拉伸它:
解决方案
尝试 imagecrop($img, ['x' => 0, 'y' => 0, 'width' => $size, 'height' => $size ]);
见http://php.net/manual/en/function.imagecrop.php
将 $size 替换为您想要的宽度/高度
该链接还有一个如何将其居中的示例。
推荐阅读
- javascript - Fullpage.js:我可以使用哪个功能重新启动 ScrollOverflow 插件?
- partition - 如何在 slurm 中发现当前分区?
- angular5 - 重新排序 ngx-datatable 中的列
- javascript - 如何正确设置标签和文本框填充?
- android - 无法在图像视图中看到我拍摄的原始照片
- node.js - 在 NodeJS 中放置函数来操作 MongoDB 不起作用
- angular - Karma Runner 找不到从 tsconfig.json 到 ES6 模块的路径
- reactjs - GraphQL 订阅不会监听所有新的创作 - react-apollo
- angularjs - 跨域发布请求Angular js
- python - 在 pandas.DataFrame.query() 表达式中使用负数