4
A
答えて
4
、そのことができますMarkによって説明されているように、UIImageViewのUIViewContentModeを変更することによって、次のUIImage拡張子(これはsourceから取得)を使って実際の画像のサイズを変更することができます
- (UIImage*)imageByScalingAndCroppingForSize:(CGSize)targetSize
{
UIImage *sourceImage = self;
UIImage *newImage = nil;
CGSize imageSize = sourceImage.size;
CGFloat width = imageSize.width;
CGFloat height = imageSize.height;
CGFloat targetWidth = targetSize.width;
CGFloat targetHeight = targetSize.height;
CGFloat scaleFactor = 0.0;
CGFloat scaledWidth = targetWidth;
CGFloat scaledHeight = targetHeight;
CGPoint thumbnailPoint = CGPointMake(0.0,0.0);
if (CGSizeEqualToSize(imageSize, targetSize) == NO)
{
CGFloat widthFactor = targetWidth/width;
CGFloat heightFactor = targetHeight/height;
if (widthFactor > heightFactor)
scaleFactor = widthFactor; // scale to fit height
else
scaleFactor = heightFactor; // scale to fit width
scaledWidth = width * scaleFactor;
scaledHeight = height * scaleFactor;
// center the image
if (widthFactor > heightFactor)
{
thumbnailPoint.y = (targetHeight - scaledHeight) * 0.5;
}
else
if (widthFactor < heightFactor)
{
thumbnailPoint.x = (targetWidth - scaledWidth) * 0.5;
}
}
UIGraphicsBeginImageContext(targetSize); // this will crop
CGRect thumbnailRect = CGRectZero;
thumbnailRect.origin = thumbnailPoint;
thumbnailRect.size.width = scaledWidth;
thumbnailRect.size.height = scaledHeight;
[sourceImage drawInRect:thumbnailRect];
newImage = UIGraphicsGetImageFromCurrentImageContext();
if(newImage == nil)
NSLog(@"could not scale image");
//pop the context to get back to the default
UIGraphicsEndImageContext();
return newImage;
}
2
可能デュープてください:私も受け入れ答えのテキストをコピーします How to scale a UIImageView proportionally?
を。フレームがuiviewであると仮定します。
imageView.contentMode = UIViewContentModeScaleAspectFit;
はあなたが望むことを行います。ドキュメントから
、ここでは他のスケーリングオプションが
UIViewContentMode
Specifies how a view adjusts its content when its size changes.
typedef enum {
UIViewContentModeScaleToFill,
UIViewContentModeScaleAspectFit,
UIViewContentModeScaleAspectFill,
UIViewContentModeRedraw,
UIViewContentModeCenter,
UIViewContentModeTop,
UIViewContentModeBottom,
UIViewContentModeLeft,
UIViewContentModeRight,
UIViewContentModeTopLeft,
UIViewContentModeTopRight,
UIViewContentModeBottomLeft,
UIViewContentModeBottomRight,
} UIViewContentMode;
リンゴのドキュメントここにある:あなたが実際にだけ表示枠を変更するUIImageを変更していない話をしている場合は http://developer.apple.com/library/ios/#documentation/UIKit/Reference/UIImageView_Class/Reference/Reference.html
+0
彼はUIImageの話をしています - これは画像を拡大するのではなく、ビューによって描画されるものだけです –
関連する問題
- 1. イメージがUIImageViewのフレームに合わない
- 2. 背景イメージを画面に合わせる方法は?
- 3. イメージの正確なサイズにオーバーレイを合わせる方法は?
- 4. 背景イメージを画面サイズに合わせる方法は?
- 5. イメージを隣り合わせに配置する方法
- 6. Androidデバイスの画面に背景イメージを合わせる方法
- 7. イメージをジャンボトロンのサイズに合わせる方法
- 8. ボタンのレイアウトとフレームの組み合わせ方法
- 9. イメージとテキストをテキスト表示で合わせる方法android
- 10. イメージをハンバーガーメニューに合わせる
- 11. イメージをデータグリッドビューの列に合わせる
- 12. イメージをウィンドウに合わせる - GTKmm
- 13. 向きが変わる場合のフレームの設定方法は?
- 14. イメージにテキストを追加し、フォントをイメージサイズに合わせる方法。
- 15. AフレームとThree.jsの組み合わせ
- 16. レスポンシブルディビジョン内のイメージを合わせる
- 17. イメージを幅に合わせてアンドロイドでアスペクト比を維持する方法
- 18. フレームに新しいイメージを作成する方法は?
- 19. イメージのサイズ変更と中心合わせ方法
- 20. Digital Micrographでイメージのフレームをマージして合計する方法は?
- 21. 画面の解像度に合わせてツールバーに合わせる方法は?
- 22. フレックスコンテナをコンテンツに合わせる方法
- 23. Python:wxPython:StaticBoxを水平に伸ばしてフレームに合わせる
- 24. 並べ替えイメージをDataTableの列ヘッダーに合わせる方法
- 25. フレームはインターフェイスの向きに合わせて
- 26. XSLはページに1枚のイメージとラベルを合わせる
- 27. は、フレームを殺す方法を尋ねる代わりに、キルフレーム
- 28. pngの画像に合わせる画像(フレーム)
- 29. イメージをフレームに表示するには?
- 30. イメージを印刷するときにページに合わせる
どのフレーム?どうか明らかにしてください。 –