Масштаб изображения в UIButton в AspectFit?
Я хочу добавить изображение в UIButton, а также хочу масштабировать свое изображение в соответствии с UIButton (сделать изображение меньше). Пожалуйста, покажите мне, как это сделать.
Это то, что я пробовал, но он не работает:
- Добавление изображения к кнопке и использование
setContentMode
:
[self.itemImageButton setImage:stretchImage forState:UIControlStateNormal];
[self.itemImageButton setContentMode:UIViewContentModeScaleAspectFit];
- Создание "растягивающего изображения":
UIImage *stretchImage = [updatedItem.thumbnail stretchableImageWithLeftCapWidth:0 topCapHeight:0];
Ответы
Ответ 1
Если вы действительно хотите масштабировать изображение, сделайте это, но вы должны изменить его размер перед его использованием. Изменение размера его во время выполнения просто потеряет процессорные циклы.
Это категория, которую я использую для масштабирования изображения:
UIImage + Extra.h
@interface UIImage (Extras)
- (UIImage *)imageByScalingProportionallyToSize:(CGSize)targetSize;
@end;
UIImage + Extra.m
@implementation UIImage (Extras)
- (UIImage *)imageByScalingProportionallyToSize:(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)) {
CGFloat widthFactor = targetWidth / width;
CGFloat heightFactor = targetHeight / height;
if (widthFactor < heightFactor)
scaleFactor = widthFactor;
else
scaleFactor = heightFactor;
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;
}
}
// this is actually the interesting part:
UIGraphicsBeginImageContextWithOptions(targetSize, NO, 0);
CGRect thumbnailRect = CGRectZero;
thumbnailRect.origin = thumbnailPoint;
thumbnailRect.size.width = scaledWidth;
thumbnailRect.size.height = scaledHeight;
[sourceImage drawInRect:thumbnailRect];
newImage = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();
if(newImage == nil) NSLog(@"could not scale image");
return newImage ;
}
@end
Вы можете использовать его в нужном вам размере. Например:
[self.itemImageButton setImage:[stretchImage imageByScalingProportionallyToSize:CGSizeMake(20,20)]];
Ответ 2
У меня была та же проблема. Просто установите ContentMode ImageView, который находится внутри UIButton.
[[self.itemImageButton imageView] setContentMode: UIViewContentModeScaleAspectFit];
[self.itemImageButton setImage:[UIImage imageNamed:stretchImage] forState:UIControlStateNormal];
Надеюсь, что это поможет.
Ответ 3
Ни один из ответов здесь не работал у меня, я решил проблему со следующим кодом:
button.contentMode = UIViewContentModeScaleToFill;
button.contentHorizontalAlignment = UIControlContentHorizontalAlignmentFill;
button.contentVerticalAlignment = UIControlContentVerticalAlignmentFill;
Вы также можете сделать это в построителе интерфейсов.
![введите описание изображения здесь]()
Ответ 4
Самый простой способ программно установить образ изображения UIButton в режиме аспект:
Swift
button.contentHorizontalAlignment = .fill
button.contentVerticalAlignment = .fill
button.imageView?.contentMode = .scaleAspectFit
Objective-C
button.contentHorizontalAlignment = UIControlContentHorizontalAlignmentFill;
button.contentVerticalAlignment = UIControlContentVerticalAlignmentFill;
button.imageView.contentMode = UIViewContentModeScaleAspectFit;
Примечание:
Вы можете изменить .scaleAspectFit(UIViewContentModeScaleAspectFit) на .scaleAspectFill(UIViewContentModeScaleAspectFill), чтобы установить формат заполнения
Ответ 5
У меня были проблемы с изображением, не изменяющим размер пропорционально, так что я исправил его с помощью кросс-вложений.
fooButton.contentEdgeInsets = UIEdgeInsetsMake(10, 15, 10, 15);
Ответ 6
Теперь это можно сделать с помощью свойств IB UIButton. Ключ должен установить ваше изображение в качестве фона, иначе оно не будет работать.
![enter image description here]()
Ответ 7
Развернувшись на ответ Дэйва, вы можете установить contentMode
кнопки imageView
все в IB без кода, используя атрибуты времени выполнения:
![введите описание изображения здесь]()
-
1
означает UIViewContentModeScaleAspectFit
,
-
2
означает
UIViewContentModeScaleAspectFill
.
Ответ 8
Если вы просто хотите уменьшить изображение своей кнопки:
yourButton.contentMode = UIViewContentModeScaleAspectFit;
yourButton.imageEdgeInsets = UIEdgeInsetsMake(10, 10, 10, 10);
Ответ 9
Самое чистое решение - использовать Auto Layout. Я снизил приоритет сжатия содержимого в моем UIButton
и установил изображение (не фоновое изображение) через Interface Builder. После этого я добавил пару ограничений, которые определяют размер моей кнопки (довольно сложный в моем случае), и это сработало как шарм.
Ответ 10
У меня есть метод, который делает это для меня.
Этот метод берет UIButton
и подгоняет аспект изображения.
-(void)makeImageAspectFitForButton:(UIButton*)button{
button.imageView.contentMode=UIViewContentModeScaleAspectFit;
button.contentHorizontalAlignment=UIControlContentHorizontalAlignmentFill;
button.contentVerticalAlignment=UIControlContentVerticalAlignmentFill;
}
Ответ 11
убедитесь, что вы установили изображение в свойство Image, но не в Background
Ответ 12
1 - очистить текст кнопки по умолчанию (важно)
2 - установить выравнивание как изображение
3 - установить режим контента как изображение
![enter image description here]()
Ответ 13
Фоновое изображение действительно может быть легко масштабировано. Просто нужно сделать что-то подобное в подклассе UIButton:
- (CGRect)backgroundRectForBounds:(CGRect)bounds
{
// you'll need the original size of the image, you
// can save it from setBackgroundImage:forControlState
return CGRectFitToFillRect(__original_image_frame_size__, bounds);
}
// Utility function, can be saved elsewhere
CGRect CGRectFitToFillRect( CGRect inRect, CGRect maxRect )
{
CGFloat origRes = inRect.size.width / inRect.size.height;
CGFloat newRes = maxRect.size.width / maxRect.size.height;
CGRect retRect = maxRect;
if (newRes < origRes)
{
retRect.size.width = inRect.size.width * maxRect.size.height / inRect.size.height;
retRect.origin.x = roundf((maxRect.size.width - retRect.size.width) / 2);
}
else
{
retRect.size.height = inRect.size.height * maxRect.size.width / inRect.size.width;
retRect.origin.y = roundf((maxRect.size.height - retRect.size.height) / 2);
}
return retRect;
}
Ответ 14
Для Xamarin.iOS(С#):
myButton.VerticalAlignment = UIControlContentVerticalAlignment.Fill;
myButton.HorizontalAlignment = UIControlContentHorizontalAlignment.Fill;
myButton.ImageView.ContentMode = UIViewContentMode.ScaleAspectFit;
Ответ 15
Swift 5.0
myButton2.contentMode = .scaleAspectFit
myButton2.contentHorizontalAlignment = .fill
myButton2.contentVerticalAlignment = .fill
Ответ 16
Вам просто нужно установить режим содержимого изображения UIButton для трех событий. -
[cell.button setImage:[UIImage imageWithData:data] forState:UIControlStateNormal];
[cell.button setImage:[UIImage imageWithData:data] forState:UIControlStateHighlighted];
[cell.imgIcon setImage:[UIImage imageWithData:data] forState:UIControlStateSelected];
У нас есть код для трех событий bcoz при подсвечивании или выборе, если размер кнопки равен SQUARE, а размер изображения - прямоугольник, тогда он отображает квадратное изображение во время выделения или выбора.
Я уверен, что это сработает для вас.