52

image.size属性はUIImageView、元のサイズを示しUIImageます。自動スケーリングされた画像が配置されたときのサイズを知りたいUIImageView(通常は元の画像よりも小さい)。

たとえば、画像を に設定していAspect Fitます。画面上の新しい高さと幅を知りたいので、新しいスケーリングされた画像に正確に描画できます。

UIImageView のサイズと UIImage の元のサイズ (基本的にはスケーリングのリバース エンジニアリング) に基づいて自分で考えずにこれを行う方法はありますか?

4

9 に答える 9

87

目的 C:

-(CGRect)frameForImage:(UIImage*)image inImageViewAspectFit:(UIImageView*)imageView
{
    float imageRatio = image.size.width / image.size.height;
    float viewRatio = imageView.frame.size.width / imageView.frame.size.height;
    if(imageRatio < viewRatio)
    {
        float scale = imageView.frame.size.height / image.size.height;
        float width = scale * image.size.width;
        float topLeftX = (imageView.frame.size.width - width) * 0.5;
        return CGRectMake(topLeftX, 0, width, imageView.frame.size.height);
    }
    else
    {
        float scale = imageView.frame.size.width / image.size.width;
        float height = scale * image.size.height;
        float topLeftY = (imageView.frame.size.height - height) * 0.5;

        return CGRectMake(0, topLeftY, imageView.frame.size.width, height);
    }
}

スウィフト 4:

func frame(for image: UIImage, inImageViewAspectFit imageView: UIImageView) -> CGRect {
  let imageRatio = (image.size.width / image.size.height)
  let viewRatio = imageView.frame.size.width / imageView.frame.size.height
  if imageRatio < viewRatio {
    let scale = imageView.frame.size.height / image.size.height
    let width = scale * image.size.width
    let topLeftX = (imageView.frame.size.width - width) * 0.5
    return CGRect(x: topLeftX, y: 0, width: width, height: imageView.frame.size.height)
  } else {
    let scale = imageView.frame.size.width / image.size.width
    let height = scale * image.size.height
    let topLeftY = (imageView.frame.size.height - height) * 0.5
    return CGRect(x: 0.0, y: topLeftY, width: imageView.frame.size.width, height: height)
  }
}
于 2011-02-13T23:10:55.197 に答える
23

この単純な関数は、画像のサイズを計算します:-

[imageView setFrame:AVMakeRectWithAspectRatioInsideRect(image.size, imageView.frame)];

詳細については、AVMakeRectWithAspectRatioInsideRect - AVFoundationを参照してください。

于 2016-01-27T08:16:55.743 に答える
10

この単純な関数は、アスペクトフィット後の画像のサイズを計算します。

-(CGSize)imageSizeAfterAspectFit:(UIImageView*)imgview{


    float newwidth;
    float newheight;

    UIImage *image=imgview.image;

    if (image.size.height>=image.size.width){
        newheight=imgview.frame.size.height;
        newwidth=(image.size.width/image.size.height)*newheight;

        if(newwidth>imgview.frame.size.width){
            float diff=imgview.frame.size.width-newwidth;
            newheight=newheight+diff/newheight*newheight;
            newwidth=imgview.frame.size.width;
        }

    }
    else{
        newwidth=imgview.frame.size.width;
        newheight=(image.size.height/image.size.width)*newwidth;

        if(newheight>imgview.frame.size.height){
            float diff=imgview.frame.size.height-newheight;
            newwidth=newwidth+diff/newwidth*newwidth;
            newheight=imgview.frame.size.height;
        }
    }

    NSLog(@"image after aspect fit: width=%f height=%f",newwidth,newheight);


    //adapt UIImageView size to image size
    //imgview.frame=CGRectMake(imgview.frame.origin.x+(imgview.frame.size.width-newwidth)/2,imgview.frame.origin.y+(imgview.frame.size.height-newheight)/2,newwidth,newheight);

    return CGSizeMake(newwidth, newheight);

}
于 2013-01-24T10:31:10.047 に答える
9

cncool answerの適応は、UIImageView 拡張機能として迅速に、おそらく誰かに役立つ可能性があります。

extension UIImageView{
    func frameForImageInImageViewAspectFit() -> CGRect
    {
        if  let img = self.image {
            let imageRatio = img.size.width / img.size.height;

            let viewRatio = self.frame.size.width / self.frame.size.height;

            if(imageRatio < viewRatio)
            {
                let scale = self.frame.size.height / img.size.height;

                let width = scale * img.size.width;

                let topLeftX = (self.frame.size.width - width) * 0.5;

                return CGRectMake(topLeftX, 0, width, self.frame.size.height);
            }
            else
            {
                let scale = self.frame.size.width / img.size.width;

                let height = scale * img.size.height;

                let topLeftY = (self.frame.size.height - height) * 0.5;

                return CGRectMake(0, topLeftY, self.frame.size.width, height);
            }
        }

        return CGRectMake(0, 0, 0, 0)
    }
}
于 2016-04-05T14:07:28.917 に答える
4

画像ビューを Aspect Fit に設定したので、元の画像の高さと幅と共に画像ビューの高さと幅を取得し、スケーリングされた画像の高さと幅を計算するだけです。

そうは言っても、これを行うより良い方法は、UIImageView の代わりにカスタム ビューを使用することです。次に、カスタム ビューで自分で画像を描画します。そうすれば、あらゆる側面を制御できます。

于 2008-12-30T02:42:24.760 に答える
1

@MeetDoshi のフォローアップとして、これに対応する拡張機能を次に示します。

extension UIImageView {
    /// Retrieve the scaled size of the image within this ImageView.
    /// - Returns: A CGRect representing the size of the image after scaling or nil if no image is set.
    func getScaledImageSize() -> CGRect? {
        if let image = self.image {
            return AVMakeRect(aspectRatio: image.size, insideRect: self.frame);
        }

        return nil;
    }
}
于 2018-10-26T14:44:57.153 に答える
0

画像のアスペクト比を維持しながらフレームが塗りつぶされている場合、imageviewフレームは画像サイズと同じにはなりません。

于 2008-12-23T17:23:42.613 に答える
-1

フレームからUIImageViewサイズを取得するのはどうですか?つまり、imageView.frame?

于 2008-12-23T17:21:39.857 に答える