我有一个按钮,可以将背景图像上传到文件夹,并将文件名保存到数据库中,但是我无法确定如何在上传之前重新调整图像大小。其实我面临两个问题。 1 - 如何调整图像大小并上传。 2 - 如何将图像显示为具有不同尺寸的div的背景图像。
到目前为止我做了什么:
Html
<div class="image_load_div">
<form id="imageform" enctype="multipart/form-data" method="post" action="upload.php">
<input name="photoimg" id="photoimg" type="file"/>
</form>
</div>
的javascript
$("#imageform").ajaxForm().submit();
php - 上传文件
$valid_formats = array("jpg", "png", "gif", "bmp");
if(isset($_POST) and $_SERVER['REQUEST_METHOD'] == "POST") {
name = $_FILES['photoimg']['name'];
$size = $_FILES['photoimg']['size'];
if(strlen($name)) {
list($txt, $ext) = explode(".", $name);
if(in_array($ext,$valid_formats)) {
if($size<(1024*1024)) {
session_start();
$id = $_SESSION['QuestionId'];
$path = "/images/Img/".$id."_bg.".$ext;
if( move_uploaded_file($_FILES["photoimg"]["tmp_name"],$path) ) {
// Save the file name into database
}
else { echo "<script>alert('Upload failed');</script>"; }
else { echo "<script>alert('Image file size max 1 MB');</script>"; }
else { echo "<script>alert('Invalid file format..');</script>"; }
else { echo "<script>alert('Please select image..!');</script>"; exit; }
我想将图片保存为高度:408px;宽度:490px; 当显示图像时,我想显示此图像宽度:174px;高度:108px; IMP!在上传和显示期间,需要考虑宽高比; 目前正在上传。
请帮我解决这个问题。感谢。
答案 0 :(得分:1)
这是经过良好测试的代码。希望它对你有用。
调用方法:
$newname="xyz";
$filename=$_FILES['featured-img']['name'];
$extension=strtolower(substr(strrchr($filename, '.'), 1)); //Get extension
$extension=trim($extension);
$newfilename=$newname.$extension;
$newfilename=preg_replace('/\s+/', '_',$newfilename);
$target1 = "directory_path".$newfilename;
if(move_uploaded_file($_FILES['featured-img']['tmp_name'],$target1));
scaleImage($target1,500, 350, $target1);
方法定义:
function scaleImage($source_image_path, $maxWidth, $maxHeight, $thumbnail_image_path){
list($source_image_width, $source_image_height, $source_image_type) = getimagesize($source_image_path);
switch ($source_image_type) {
case IMAGETYPE_GIF:
$source_gd_image = imagecreatefromgif($source_image_path);
break;
case IMAGETYPE_JPEG:
$source_gd_image = imagecreatefromjpeg($source_image_path);
break;
case IMAGETYPE_PNG:
$source_gd_image = imagecreatefrompng($source_image_path);
break;
}
if ($source_gd_image === false) {
return false;
}
$thumbnail_image_width=$maxWidth;
$thumbnail_image_height=$maxHeight;
$thumbnail_gd_image = imagecreatetruecolor($thumbnail_image_width, $thumbnail_image_height);
imagecopyresampled($thumbnail_gd_image, $source_gd_image, 0, 0, 0, 0, $thumbnail_image_width, $thumbnail_image_height, $source_image_width, $source_image_height);
imagejpeg($thumbnail_gd_image, $thumbnail_image_path, 90);
imagedestroy($source_gd_image);
imagedestroy($thumbnail_gd_image);
return true;
}
答案 1 :(得分:0)
你可以使用CSS来保持比例。
<img src="image.png" style="max-width: 400px;">
然后你可以使用php将图像的较小尺寸作为捕获所有最大尺寸,然后使用CSS来微调它的大小