0

サムネイルを作成し、同時に画像のサイズを変更しようとしているので、より明確にするために、トリミングしようとしている画像を次に示します。

ここに画像の説明を入力

そして、その赤い部分を切り取りたいと思います。

今私の問題は、トリミングする前にhtmlで画像のサイズを変更しているため、データをphpに送信すると、実際にそうy = 100である可能性がある場合y = 200のように、値を計算する方法を見つける必要があることです。

を使用してimagecopyresampledいますが、このコマンドよりも優れたものがあるのではないでしょうか?

また、私の最も近い解決策はこれでした:

imagecopyresampled(
    $thumb, //Destination image link resource.
    $src,   //Source image link resource.
    0,      //x-coordinate of destination point.
    0,      //y-coordinate of destination point.
    0,      //x-coordinate of source point.
    0,      //y-coordinate of source point.
    120,    //Destination width.
    160,    //Destination height.
    $image_width/2, //Source width.
    $image_height/2  //Source height.
);

この場合、左隅が切り取られますが、サイズは私の赤いボックスと同じではありません。だから私は正しいことをする必要があると思いますsource widthsource heightそして他のすべては完全に収まるはずです、とにかく私はここで何か意味があることを願っています:)

編集申し訳ありませんが、言及するのを忘れていまし$image_width$image_height。元の画像サイズです

EDIT 2より明確にするために、これは私がこのコードでサイズを変更したときに得られるものです

$dimensions = getimagesize('testas.jpg');

$img = imagecreatetruecolor(120, 160); 
$src = imagecreatefromjpeg('testas.jpg');

imagecopyresampled($img, $src, 0, 0, 0, 0, 120, 160, $dimensions[0]/2, $dimensions[1]/2); 

imagejpeg($img, 'test.jpg');

ここに画像の説明を入力

サイズ変更された画像サイズは正しいですが、できる限り正しく見えません。

4

3 に答える 3

1

私は次のようなものを使用して画像を拡大縮小します。

public static function scaleProportional($img_w,$img_h,$max=50)
{
    $w = 0;
    $h = 0;

    $img_w > $img_h ? $w = $img_w / $img_h : $w = 1;
    $img_h > $img_w ? $h = $img_h / $img_w : $h = 1;

    $ws = $w > $h ? $ws = ($w / $w) * $max : $ws = (1 / $h) * $max;
    $hs = $h > $w ? $hs = ($h / $h) * $max : $hs = (1 / $w) * $max;

    return array(
        'width'=>$ws,
        'height'=>$hs
    );
}

利用方法:

            $getScale = Common::scaleProportional($prevWidth,$prevHeight,$scaleArray[$i][1]);
            $targ_w = $getScale['width'];
            $targ_h = $getScale['height'];
            $jpeg_quality = 100;

            $src = $prevdest;

            $img_r = imagecreatefromjpeg($src);
            $dst_r = ImageCreateTrueColor( $targ_w, $targ_h );
            //imagecopyresampled(dest_img,src_img,dst_x,dst_y,src_x,src_y,dst_w,dst_h,src_w,src_h);
            imagecopyresampled($dst_r,$img_r,0,0,0,0,$targ_w,$targ_h,$prevWidth,$prevHeight);
            imagejpeg($dst_r, 'assets/images/'.$scaleArray[$i][0].'/'.$filename, $jpeg_quality);
            $complete[] = $scaleArray[$i][0];
于 2012-02-20T15:19:40.537 に答える
0

しばらくして、友人の助けを借りてそれを行うことができました。これは私が使用したスクリプトです。将来、誰かがそれを必要とするかもしれません:)

private function crop($user, $post){
    //get original image size
    $dimensions = getimagesize($post['image_src']);

    //get crop box dimensions
    $width = $post['w'] * ($dimensions[0] / $post['img_width']);
    $height = $post['h'] * ($dimensions[1] / $post['img_height']);

    //get crop box offset
    $y = $post['y'] * ($dimensions[1] / $post['img_height']);
    $x = $post['x'] * ($dimensions[0] / $post['img_width']);

    //create image 120x160
    $img = imagecreatetruecolor(120, 160); 
    $src = imagecreatefromjpeg($post['image_src']);

    imagecopyresampled($img, $src, 0, 0, $x, $y, 120, 160, $width, $height);

    //and save the image 
    return imagejpeg($img, 'uploads/avatars/'.$user->id.'/small/'.$post['image_name'].".jpg" , 100);
}
于 2012-02-19T19:43:59.943 に答える
0

「HTMLでリサイズ」というのは、要素の属性widthheight属性を使ってサイズを指定するということですか?imgその場合、これはサーバー上のファイルのサイズに影響を与えず、getimagesize.

次のようなものは、画像のソースの幅と高さを返します。

function get_source_size($the_file_path)
{
    $imagesize = getimagesize($the_file_path);
    return array('width' => $imagesize[0], 'height' => $imagesize[1]);
}
于 2012-02-18T23:06:23.903 に答える