iOS How to resize image at table view cell Swift












0















I work with multi platform application, and i have issues, i want that when app is load in iPad for that i want to change image size at tableview cell.



Now i have auto-layout:



https://i.stack.imgur.com/yMeGN.png



I detect at which device app run use this code:



public extension UIDevice {

static let modelName: String = {
var systemInfo = utsname()
uname(&systemInfo)
let machineMirror = Mirror(reflecting: systemInfo.machine)
let identifier = machineMirror.children.reduce("") { identifier, element in
guard let value = element.value as? Int8, value != 0 else { return identifier }
return identifier + String(UnicodeScalar(UInt8(value)))
}

func mapToDevice(identifier: String) -> String { // swiftlint:disable:this cyclomatic_complexity
#if os(iOS)
switch identifier {
case "iPod5,1": return "iPod Touch 5"
case "iPod7,1": return "iPod Touch 6"
case "iPhone3,1", "iPhone3,2", "iPhone3,3": return "iPhone 4"
case "iPhone4,1": return "iPhone 4s"
case "iPhone5,1", "iPhone5,2": return "iPhone 5"
case "iPhone5,3", "iPhone5,4": return "iPhone 5c"
case "iPhone6,1", "iPhone6,2": return "iPhone 5s"
case "iPhone7,2": return "iPhone 6"
case "iPhone7,1": return "iPhone 6 Plus"
case "iPhone8,1": return "iPhone 6s"
case "iPhone8,2": return "iPhone 6s Plus"
case "iPhone9,1", "iPhone9,3": return "iPhone 7"
case "iPhone9,2", "iPhone9,4": return "iPhone 7 Plus"
case "iPhone8,4": return "iPhone SE"
case "iPhone10,1", "iPhone10,4": return "iPhone 8"
case "iPhone10,2", "iPhone10,5": return "iPhone 8 Plus"
case "iPhone10,3", "iPhone10,6": return "iPhone X"
case "iPhone11,2": return "iPhone XS"
case "iPhone11,4", "iPhone11,6": return "iPhone XS Max"
case "iPhone11,8": return "iPhone XR"
case "iPad2,1", "iPad2,2", "iPad2,3", "iPad2,4":return "iPad 2"
case "iPad3,1", "iPad3,2", "iPad3,3": return "iPad 3"
case "iPad3,4", "iPad3,5", "iPad3,6": return "iPad 4"
case "iPad4,1", "iPad4,2", "iPad4,3": return "iPad Air"
case "iPad5,3", "iPad5,4": return "iPad Air 2"
case "iPad6,11", "iPad6,12": return "iPad 5"
case "iPad7,5", "iPad7,6": return "iPad 6"
case "iPad2,5", "iPad2,6", "iPad2,7": return "iPad Mini"
case "iPad4,4", "iPad4,5", "iPad4,6": return "iPad Mini 2"
case "iPad4,7", "iPad4,8", "iPad4,9": return "iPad Mini 3"
case "iPad5,1", "iPad5,2": return "iPad Mini 4"
case "iPad6,3", "iPad6,4": return "iPad Pro (9.7-inch)"
case "iPad6,7", "iPad6,8": return "iPad Pro (12.9-inch)"
case "iPad7,1", "iPad7,2": return "iPad Pro (12.9-inch) (2nd generation)"
case "iPad7,3", "iPad7,4": return "iPad Pro (10.5-inch)"
case "iPad8,1", "iPad8,2", "iPad8,3", "iPad8,4":return "iPad Pro (11-inch)"
case "iPad8,5", "iPad8,6", "iPad8,7", "iPad8,8":return "iPad Pro (12.9-inch) (3rd generation)"
case "AppleTV5,3": return "Apple TV"
case "AppleTV6,2": return "Apple TV 4K"
case "AudioAccessory1,1": return "HomePod"
case "i386", "x86_64": return "Simulator (mapToDevice(identifier: ProcessInfo().environment["SIMULATOR_MODEL_IDENTIFIER"] ?? "iOS"))"
default: return identifier
}
#elseif os(tvOS)
switch identifier {
case "AppleTV5,3": return "Apple TV 4"
case "AppleTV6,2": return "Apple TV 4K"
case "i386", "x86_64": return "Simulator (mapToDevice(identifier: ProcessInfo().environment["SIMULATOR_MODEL_IDENTIFIER"] ?? "tvOS"))"
default: return identifier
}
#endif
}

return mapToDevice(identifier: identifier)
}()
}


My idea is, at table view




if modelName.range(of:"iPad") != nil




i want to change image size, for example 200x200;










share|improve this question

























  • Possible duplicate of Resize UIImage to 200x200pt/px

    – excitedmicrobe
    Nov 21 '18 at 6:35
















0















I work with multi platform application, and i have issues, i want that when app is load in iPad for that i want to change image size at tableview cell.



Now i have auto-layout:



https://i.stack.imgur.com/yMeGN.png



I detect at which device app run use this code:



public extension UIDevice {

static let modelName: String = {
var systemInfo = utsname()
uname(&systemInfo)
let machineMirror = Mirror(reflecting: systemInfo.machine)
let identifier = machineMirror.children.reduce("") { identifier, element in
guard let value = element.value as? Int8, value != 0 else { return identifier }
return identifier + String(UnicodeScalar(UInt8(value)))
}

func mapToDevice(identifier: String) -> String { // swiftlint:disable:this cyclomatic_complexity
#if os(iOS)
switch identifier {
case "iPod5,1": return "iPod Touch 5"
case "iPod7,1": return "iPod Touch 6"
case "iPhone3,1", "iPhone3,2", "iPhone3,3": return "iPhone 4"
case "iPhone4,1": return "iPhone 4s"
case "iPhone5,1", "iPhone5,2": return "iPhone 5"
case "iPhone5,3", "iPhone5,4": return "iPhone 5c"
case "iPhone6,1", "iPhone6,2": return "iPhone 5s"
case "iPhone7,2": return "iPhone 6"
case "iPhone7,1": return "iPhone 6 Plus"
case "iPhone8,1": return "iPhone 6s"
case "iPhone8,2": return "iPhone 6s Plus"
case "iPhone9,1", "iPhone9,3": return "iPhone 7"
case "iPhone9,2", "iPhone9,4": return "iPhone 7 Plus"
case "iPhone8,4": return "iPhone SE"
case "iPhone10,1", "iPhone10,4": return "iPhone 8"
case "iPhone10,2", "iPhone10,5": return "iPhone 8 Plus"
case "iPhone10,3", "iPhone10,6": return "iPhone X"
case "iPhone11,2": return "iPhone XS"
case "iPhone11,4", "iPhone11,6": return "iPhone XS Max"
case "iPhone11,8": return "iPhone XR"
case "iPad2,1", "iPad2,2", "iPad2,3", "iPad2,4":return "iPad 2"
case "iPad3,1", "iPad3,2", "iPad3,3": return "iPad 3"
case "iPad3,4", "iPad3,5", "iPad3,6": return "iPad 4"
case "iPad4,1", "iPad4,2", "iPad4,3": return "iPad Air"
case "iPad5,3", "iPad5,4": return "iPad Air 2"
case "iPad6,11", "iPad6,12": return "iPad 5"
case "iPad7,5", "iPad7,6": return "iPad 6"
case "iPad2,5", "iPad2,6", "iPad2,7": return "iPad Mini"
case "iPad4,4", "iPad4,5", "iPad4,6": return "iPad Mini 2"
case "iPad4,7", "iPad4,8", "iPad4,9": return "iPad Mini 3"
case "iPad5,1", "iPad5,2": return "iPad Mini 4"
case "iPad6,3", "iPad6,4": return "iPad Pro (9.7-inch)"
case "iPad6,7", "iPad6,8": return "iPad Pro (12.9-inch)"
case "iPad7,1", "iPad7,2": return "iPad Pro (12.9-inch) (2nd generation)"
case "iPad7,3", "iPad7,4": return "iPad Pro (10.5-inch)"
case "iPad8,1", "iPad8,2", "iPad8,3", "iPad8,4":return "iPad Pro (11-inch)"
case "iPad8,5", "iPad8,6", "iPad8,7", "iPad8,8":return "iPad Pro (12.9-inch) (3rd generation)"
case "AppleTV5,3": return "Apple TV"
case "AppleTV6,2": return "Apple TV 4K"
case "AudioAccessory1,1": return "HomePod"
case "i386", "x86_64": return "Simulator (mapToDevice(identifier: ProcessInfo().environment["SIMULATOR_MODEL_IDENTIFIER"] ?? "iOS"))"
default: return identifier
}
#elseif os(tvOS)
switch identifier {
case "AppleTV5,3": return "Apple TV 4"
case "AppleTV6,2": return "Apple TV 4K"
case "i386", "x86_64": return "Simulator (mapToDevice(identifier: ProcessInfo().environment["SIMULATOR_MODEL_IDENTIFIER"] ?? "tvOS"))"
default: return identifier
}
#endif
}

return mapToDevice(identifier: identifier)
}()
}


My idea is, at table view




if modelName.range(of:"iPad") != nil




i want to change image size, for example 200x200;










share|improve this question

























  • Possible duplicate of Resize UIImage to 200x200pt/px

    – excitedmicrobe
    Nov 21 '18 at 6:35














0












0








0








I work with multi platform application, and i have issues, i want that when app is load in iPad for that i want to change image size at tableview cell.



Now i have auto-layout:



https://i.stack.imgur.com/yMeGN.png



I detect at which device app run use this code:



public extension UIDevice {

static let modelName: String = {
var systemInfo = utsname()
uname(&systemInfo)
let machineMirror = Mirror(reflecting: systemInfo.machine)
let identifier = machineMirror.children.reduce("") { identifier, element in
guard let value = element.value as? Int8, value != 0 else { return identifier }
return identifier + String(UnicodeScalar(UInt8(value)))
}

func mapToDevice(identifier: String) -> String { // swiftlint:disable:this cyclomatic_complexity
#if os(iOS)
switch identifier {
case "iPod5,1": return "iPod Touch 5"
case "iPod7,1": return "iPod Touch 6"
case "iPhone3,1", "iPhone3,2", "iPhone3,3": return "iPhone 4"
case "iPhone4,1": return "iPhone 4s"
case "iPhone5,1", "iPhone5,2": return "iPhone 5"
case "iPhone5,3", "iPhone5,4": return "iPhone 5c"
case "iPhone6,1", "iPhone6,2": return "iPhone 5s"
case "iPhone7,2": return "iPhone 6"
case "iPhone7,1": return "iPhone 6 Plus"
case "iPhone8,1": return "iPhone 6s"
case "iPhone8,2": return "iPhone 6s Plus"
case "iPhone9,1", "iPhone9,3": return "iPhone 7"
case "iPhone9,2", "iPhone9,4": return "iPhone 7 Plus"
case "iPhone8,4": return "iPhone SE"
case "iPhone10,1", "iPhone10,4": return "iPhone 8"
case "iPhone10,2", "iPhone10,5": return "iPhone 8 Plus"
case "iPhone10,3", "iPhone10,6": return "iPhone X"
case "iPhone11,2": return "iPhone XS"
case "iPhone11,4", "iPhone11,6": return "iPhone XS Max"
case "iPhone11,8": return "iPhone XR"
case "iPad2,1", "iPad2,2", "iPad2,3", "iPad2,4":return "iPad 2"
case "iPad3,1", "iPad3,2", "iPad3,3": return "iPad 3"
case "iPad3,4", "iPad3,5", "iPad3,6": return "iPad 4"
case "iPad4,1", "iPad4,2", "iPad4,3": return "iPad Air"
case "iPad5,3", "iPad5,4": return "iPad Air 2"
case "iPad6,11", "iPad6,12": return "iPad 5"
case "iPad7,5", "iPad7,6": return "iPad 6"
case "iPad2,5", "iPad2,6", "iPad2,7": return "iPad Mini"
case "iPad4,4", "iPad4,5", "iPad4,6": return "iPad Mini 2"
case "iPad4,7", "iPad4,8", "iPad4,9": return "iPad Mini 3"
case "iPad5,1", "iPad5,2": return "iPad Mini 4"
case "iPad6,3", "iPad6,4": return "iPad Pro (9.7-inch)"
case "iPad6,7", "iPad6,8": return "iPad Pro (12.9-inch)"
case "iPad7,1", "iPad7,2": return "iPad Pro (12.9-inch) (2nd generation)"
case "iPad7,3", "iPad7,4": return "iPad Pro (10.5-inch)"
case "iPad8,1", "iPad8,2", "iPad8,3", "iPad8,4":return "iPad Pro (11-inch)"
case "iPad8,5", "iPad8,6", "iPad8,7", "iPad8,8":return "iPad Pro (12.9-inch) (3rd generation)"
case "AppleTV5,3": return "Apple TV"
case "AppleTV6,2": return "Apple TV 4K"
case "AudioAccessory1,1": return "HomePod"
case "i386", "x86_64": return "Simulator (mapToDevice(identifier: ProcessInfo().environment["SIMULATOR_MODEL_IDENTIFIER"] ?? "iOS"))"
default: return identifier
}
#elseif os(tvOS)
switch identifier {
case "AppleTV5,3": return "Apple TV 4"
case "AppleTV6,2": return "Apple TV 4K"
case "i386", "x86_64": return "Simulator (mapToDevice(identifier: ProcessInfo().environment["SIMULATOR_MODEL_IDENTIFIER"] ?? "tvOS"))"
default: return identifier
}
#endif
}

return mapToDevice(identifier: identifier)
}()
}


My idea is, at table view




if modelName.range(of:"iPad") != nil




i want to change image size, for example 200x200;










share|improve this question
















I work with multi platform application, and i have issues, i want that when app is load in iPad for that i want to change image size at tableview cell.



Now i have auto-layout:



https://i.stack.imgur.com/yMeGN.png



I detect at which device app run use this code:



public extension UIDevice {

static let modelName: String = {
var systemInfo = utsname()
uname(&systemInfo)
let machineMirror = Mirror(reflecting: systemInfo.machine)
let identifier = machineMirror.children.reduce("") { identifier, element in
guard let value = element.value as? Int8, value != 0 else { return identifier }
return identifier + String(UnicodeScalar(UInt8(value)))
}

func mapToDevice(identifier: String) -> String { // swiftlint:disable:this cyclomatic_complexity
#if os(iOS)
switch identifier {
case "iPod5,1": return "iPod Touch 5"
case "iPod7,1": return "iPod Touch 6"
case "iPhone3,1", "iPhone3,2", "iPhone3,3": return "iPhone 4"
case "iPhone4,1": return "iPhone 4s"
case "iPhone5,1", "iPhone5,2": return "iPhone 5"
case "iPhone5,3", "iPhone5,4": return "iPhone 5c"
case "iPhone6,1", "iPhone6,2": return "iPhone 5s"
case "iPhone7,2": return "iPhone 6"
case "iPhone7,1": return "iPhone 6 Plus"
case "iPhone8,1": return "iPhone 6s"
case "iPhone8,2": return "iPhone 6s Plus"
case "iPhone9,1", "iPhone9,3": return "iPhone 7"
case "iPhone9,2", "iPhone9,4": return "iPhone 7 Plus"
case "iPhone8,4": return "iPhone SE"
case "iPhone10,1", "iPhone10,4": return "iPhone 8"
case "iPhone10,2", "iPhone10,5": return "iPhone 8 Plus"
case "iPhone10,3", "iPhone10,6": return "iPhone X"
case "iPhone11,2": return "iPhone XS"
case "iPhone11,4", "iPhone11,6": return "iPhone XS Max"
case "iPhone11,8": return "iPhone XR"
case "iPad2,1", "iPad2,2", "iPad2,3", "iPad2,4":return "iPad 2"
case "iPad3,1", "iPad3,2", "iPad3,3": return "iPad 3"
case "iPad3,4", "iPad3,5", "iPad3,6": return "iPad 4"
case "iPad4,1", "iPad4,2", "iPad4,3": return "iPad Air"
case "iPad5,3", "iPad5,4": return "iPad Air 2"
case "iPad6,11", "iPad6,12": return "iPad 5"
case "iPad7,5", "iPad7,6": return "iPad 6"
case "iPad2,5", "iPad2,6", "iPad2,7": return "iPad Mini"
case "iPad4,4", "iPad4,5", "iPad4,6": return "iPad Mini 2"
case "iPad4,7", "iPad4,8", "iPad4,9": return "iPad Mini 3"
case "iPad5,1", "iPad5,2": return "iPad Mini 4"
case "iPad6,3", "iPad6,4": return "iPad Pro (9.7-inch)"
case "iPad6,7", "iPad6,8": return "iPad Pro (12.9-inch)"
case "iPad7,1", "iPad7,2": return "iPad Pro (12.9-inch) (2nd generation)"
case "iPad7,3", "iPad7,4": return "iPad Pro (10.5-inch)"
case "iPad8,1", "iPad8,2", "iPad8,3", "iPad8,4":return "iPad Pro (11-inch)"
case "iPad8,5", "iPad8,6", "iPad8,7", "iPad8,8":return "iPad Pro (12.9-inch) (3rd generation)"
case "AppleTV5,3": return "Apple TV"
case "AppleTV6,2": return "Apple TV 4K"
case "AudioAccessory1,1": return "HomePod"
case "i386", "x86_64": return "Simulator (mapToDevice(identifier: ProcessInfo().environment["SIMULATOR_MODEL_IDENTIFIER"] ?? "iOS"))"
default: return identifier
}
#elseif os(tvOS)
switch identifier {
case "AppleTV5,3": return "Apple TV 4"
case "AppleTV6,2": return "Apple TV 4K"
case "i386", "x86_64": return "Simulator (mapToDevice(identifier: ProcessInfo().environment["SIMULATOR_MODEL_IDENTIFIER"] ?? "tvOS"))"
default: return identifier
}
#endif
}

return mapToDevice(identifier: identifier)
}()
}


My idea is, at table view




if modelName.range(of:"iPad") != nil




i want to change image size, for example 200x200;







ios swift uitableview uiimageview






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 21 '18 at 9:09









Ketan Odedra

13616




13616










asked Nov 21 '18 at 6:31









qunzorqunzor

104




104













  • Possible duplicate of Resize UIImage to 200x200pt/px

    – excitedmicrobe
    Nov 21 '18 at 6:35



















  • Possible duplicate of Resize UIImage to 200x200pt/px

    – excitedmicrobe
    Nov 21 '18 at 6:35

















Possible duplicate of Resize UIImage to 200x200pt/px

– excitedmicrobe
Nov 21 '18 at 6:35





Possible duplicate of Resize UIImage to 200x200pt/px

– excitedmicrobe
Nov 21 '18 at 6:35












2 Answers
2






active

oldest

votes


















0














You can use Auto layout for the same. Just create IBOutlet for the height and width constraint of ImageView.



public func tableView(tableView: UITableView, willDisplayCell cell: UITableViewCell, forRowAtIndexPath indexPath: NSIndexPath) {

//check for iPad and set the constraint values to 200*200
if modelName.range(of:"iPad") != nil
{
cell.imageViewHeightConstraint.constant = 200
cell.imageViewWidthConstraint.constant = 200
}
else
{
cell.imageViewHeightConstraint.constant = 100
cell.imageViewWidthConstraint.constant = 100
}
}


You can even do the same from storyboard by just selecting the height or width constraint and add another constant for iPad.



----Please check the below screenshots on how to add constant for iPad in storyboard.
1. Select the constraint. Click on + icon from right properties menu.
2. Select Compact compact for all types of iPad and add variation.
3. Set the constant value for iPad.
enter image description here



enter image description here






share|improve this answer


























  • How i can add another constant for iPad?

    – qunzor
    Nov 21 '18 at 6:54











  • @qunzor I have updated my answer, please check. Also you need to increase the size of cell (if required).

    – Nupur Gupta
    Nov 21 '18 at 7:05



















0














Resizing your image will not affect your constraints. So you may want to update them aswell. for now-- you can resize images by doing so:



import UIKit
extension UIImage {

/// Returns a image that fills in newSize

func resizedImage(newSize: CGSize) -> UIImage {

guard self.size != newSize else { return self }
UIGraphicsBeginImageContextWithOptions(newSize, false, 0.0);
self.draw(in: CGRect(x: 0, y: 0, width: newSize.width, height: newSize.height))
let newImage: UIImage = UIGraphicsGetImageFromCurrentImageContext()!
UIGraphicsEndImageContext()
return newImage
}

/// Returns a resized image that fits in rectSize, keeping it's aspect ratio
/// Note that the new image size is not rectSize, but within it.
func resizedImageWithinRect(rectSize: CGSize) -> UIImage {
let widthFactor = size.width / rectSize.width
let heightFactor = size.height / rectSize.height

var resizeFactor = widthFactor
if size.height > size.width {
resizeFactor = heightFactor
}
let newSize = CGSize(width: size.width/resizeFactor, height: size.height/resizeFactor)
let resized = resizedImage(newSize)
return resized
}

}


I'm still using this code in my apps. So rest assured



// Tests
guard let url = NSURL(string: "http://placehold.it/300x150") else { fatalError("Bad URL") }
guard let data = NSData(contentsOfURL: url) else { fatalError("Bad data") }
guard let img = UIImage(data: data) else { fatalError("Bad data") }

let outImageFit = img.resizedImageWithinRect(CGSize(width: 200, height: 200))
let outImageFill = img.resizedImage(CGSize(width: 200, height: 200))





share|improve this answer


























  • 'CGRectMake' is unavailable in Swift

    – qunzor
    Nov 21 '18 at 6:42











  • Updating that in a sec

    – excitedmicrobe
    Nov 21 '18 at 6:43











  • @qunzor done, thanks for bringing that to my attention

    – excitedmicrobe
    Nov 21 '18 at 6:45











Your Answer






StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");

StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53406416%2fios-how-to-resize-image-at-table-view-cell-swift%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























2 Answers
2






active

oldest

votes








2 Answers
2






active

oldest

votes









active

oldest

votes






active

oldest

votes









0














You can use Auto layout for the same. Just create IBOutlet for the height and width constraint of ImageView.



public func tableView(tableView: UITableView, willDisplayCell cell: UITableViewCell, forRowAtIndexPath indexPath: NSIndexPath) {

//check for iPad and set the constraint values to 200*200
if modelName.range(of:"iPad") != nil
{
cell.imageViewHeightConstraint.constant = 200
cell.imageViewWidthConstraint.constant = 200
}
else
{
cell.imageViewHeightConstraint.constant = 100
cell.imageViewWidthConstraint.constant = 100
}
}


You can even do the same from storyboard by just selecting the height or width constraint and add another constant for iPad.



----Please check the below screenshots on how to add constant for iPad in storyboard.
1. Select the constraint. Click on + icon from right properties menu.
2. Select Compact compact for all types of iPad and add variation.
3. Set the constant value for iPad.
enter image description here



enter image description here






share|improve this answer


























  • How i can add another constant for iPad?

    – qunzor
    Nov 21 '18 at 6:54











  • @qunzor I have updated my answer, please check. Also you need to increase the size of cell (if required).

    – Nupur Gupta
    Nov 21 '18 at 7:05
















0














You can use Auto layout for the same. Just create IBOutlet for the height and width constraint of ImageView.



public func tableView(tableView: UITableView, willDisplayCell cell: UITableViewCell, forRowAtIndexPath indexPath: NSIndexPath) {

//check for iPad and set the constraint values to 200*200
if modelName.range(of:"iPad") != nil
{
cell.imageViewHeightConstraint.constant = 200
cell.imageViewWidthConstraint.constant = 200
}
else
{
cell.imageViewHeightConstraint.constant = 100
cell.imageViewWidthConstraint.constant = 100
}
}


You can even do the same from storyboard by just selecting the height or width constraint and add another constant for iPad.



----Please check the below screenshots on how to add constant for iPad in storyboard.
1. Select the constraint. Click on + icon from right properties menu.
2. Select Compact compact for all types of iPad and add variation.
3. Set the constant value for iPad.
enter image description here



enter image description here






share|improve this answer


























  • How i can add another constant for iPad?

    – qunzor
    Nov 21 '18 at 6:54











  • @qunzor I have updated my answer, please check. Also you need to increase the size of cell (if required).

    – Nupur Gupta
    Nov 21 '18 at 7:05














0












0








0







You can use Auto layout for the same. Just create IBOutlet for the height and width constraint of ImageView.



public func tableView(tableView: UITableView, willDisplayCell cell: UITableViewCell, forRowAtIndexPath indexPath: NSIndexPath) {

//check for iPad and set the constraint values to 200*200
if modelName.range(of:"iPad") != nil
{
cell.imageViewHeightConstraint.constant = 200
cell.imageViewWidthConstraint.constant = 200
}
else
{
cell.imageViewHeightConstraint.constant = 100
cell.imageViewWidthConstraint.constant = 100
}
}


You can even do the same from storyboard by just selecting the height or width constraint and add another constant for iPad.



----Please check the below screenshots on how to add constant for iPad in storyboard.
1. Select the constraint. Click on + icon from right properties menu.
2. Select Compact compact for all types of iPad and add variation.
3. Set the constant value for iPad.
enter image description here



enter image description here






share|improve this answer















You can use Auto layout for the same. Just create IBOutlet for the height and width constraint of ImageView.



public func tableView(tableView: UITableView, willDisplayCell cell: UITableViewCell, forRowAtIndexPath indexPath: NSIndexPath) {

//check for iPad and set the constraint values to 200*200
if modelName.range(of:"iPad") != nil
{
cell.imageViewHeightConstraint.constant = 200
cell.imageViewWidthConstraint.constant = 200
}
else
{
cell.imageViewHeightConstraint.constant = 100
cell.imageViewWidthConstraint.constant = 100
}
}


You can even do the same from storyboard by just selecting the height or width constraint and add another constant for iPad.



----Please check the below screenshots on how to add constant for iPad in storyboard.
1. Select the constraint. Click on + icon from right properties menu.
2. Select Compact compact for all types of iPad and add variation.
3. Set the constant value for iPad.
enter image description here



enter image description here







share|improve this answer














share|improve this answer



share|improve this answer








edited Nov 21 '18 at 7:05

























answered Nov 21 '18 at 6:39









Nupur GuptaNupur Gupta

261111




261111













  • How i can add another constant for iPad?

    – qunzor
    Nov 21 '18 at 6:54











  • @qunzor I have updated my answer, please check. Also you need to increase the size of cell (if required).

    – Nupur Gupta
    Nov 21 '18 at 7:05



















  • How i can add another constant for iPad?

    – qunzor
    Nov 21 '18 at 6:54











  • @qunzor I have updated my answer, please check. Also you need to increase the size of cell (if required).

    – Nupur Gupta
    Nov 21 '18 at 7:05

















How i can add another constant for iPad?

– qunzor
Nov 21 '18 at 6:54





How i can add another constant for iPad?

– qunzor
Nov 21 '18 at 6:54













@qunzor I have updated my answer, please check. Also you need to increase the size of cell (if required).

– Nupur Gupta
Nov 21 '18 at 7:05





@qunzor I have updated my answer, please check. Also you need to increase the size of cell (if required).

– Nupur Gupta
Nov 21 '18 at 7:05













0














Resizing your image will not affect your constraints. So you may want to update them aswell. for now-- you can resize images by doing so:



import UIKit
extension UIImage {

/// Returns a image that fills in newSize

func resizedImage(newSize: CGSize) -> UIImage {

guard self.size != newSize else { return self }
UIGraphicsBeginImageContextWithOptions(newSize, false, 0.0);
self.draw(in: CGRect(x: 0, y: 0, width: newSize.width, height: newSize.height))
let newImage: UIImage = UIGraphicsGetImageFromCurrentImageContext()!
UIGraphicsEndImageContext()
return newImage
}

/// Returns a resized image that fits in rectSize, keeping it's aspect ratio
/// Note that the new image size is not rectSize, but within it.
func resizedImageWithinRect(rectSize: CGSize) -> UIImage {
let widthFactor = size.width / rectSize.width
let heightFactor = size.height / rectSize.height

var resizeFactor = widthFactor
if size.height > size.width {
resizeFactor = heightFactor
}
let newSize = CGSize(width: size.width/resizeFactor, height: size.height/resizeFactor)
let resized = resizedImage(newSize)
return resized
}

}


I'm still using this code in my apps. So rest assured



// Tests
guard let url = NSURL(string: "http://placehold.it/300x150") else { fatalError("Bad URL") }
guard let data = NSData(contentsOfURL: url) else { fatalError("Bad data") }
guard let img = UIImage(data: data) else { fatalError("Bad data") }

let outImageFit = img.resizedImageWithinRect(CGSize(width: 200, height: 200))
let outImageFill = img.resizedImage(CGSize(width: 200, height: 200))





share|improve this answer


























  • 'CGRectMake' is unavailable in Swift

    – qunzor
    Nov 21 '18 at 6:42











  • Updating that in a sec

    – excitedmicrobe
    Nov 21 '18 at 6:43











  • @qunzor done, thanks for bringing that to my attention

    – excitedmicrobe
    Nov 21 '18 at 6:45
















0














Resizing your image will not affect your constraints. So you may want to update them aswell. for now-- you can resize images by doing so:



import UIKit
extension UIImage {

/// Returns a image that fills in newSize

func resizedImage(newSize: CGSize) -> UIImage {

guard self.size != newSize else { return self }
UIGraphicsBeginImageContextWithOptions(newSize, false, 0.0);
self.draw(in: CGRect(x: 0, y: 0, width: newSize.width, height: newSize.height))
let newImage: UIImage = UIGraphicsGetImageFromCurrentImageContext()!
UIGraphicsEndImageContext()
return newImage
}

/// Returns a resized image that fits in rectSize, keeping it's aspect ratio
/// Note that the new image size is not rectSize, but within it.
func resizedImageWithinRect(rectSize: CGSize) -> UIImage {
let widthFactor = size.width / rectSize.width
let heightFactor = size.height / rectSize.height

var resizeFactor = widthFactor
if size.height > size.width {
resizeFactor = heightFactor
}
let newSize = CGSize(width: size.width/resizeFactor, height: size.height/resizeFactor)
let resized = resizedImage(newSize)
return resized
}

}


I'm still using this code in my apps. So rest assured



// Tests
guard let url = NSURL(string: "http://placehold.it/300x150") else { fatalError("Bad URL") }
guard let data = NSData(contentsOfURL: url) else { fatalError("Bad data") }
guard let img = UIImage(data: data) else { fatalError("Bad data") }

let outImageFit = img.resizedImageWithinRect(CGSize(width: 200, height: 200))
let outImageFill = img.resizedImage(CGSize(width: 200, height: 200))





share|improve this answer


























  • 'CGRectMake' is unavailable in Swift

    – qunzor
    Nov 21 '18 at 6:42











  • Updating that in a sec

    – excitedmicrobe
    Nov 21 '18 at 6:43











  • @qunzor done, thanks for bringing that to my attention

    – excitedmicrobe
    Nov 21 '18 at 6:45














0












0








0







Resizing your image will not affect your constraints. So you may want to update them aswell. for now-- you can resize images by doing so:



import UIKit
extension UIImage {

/// Returns a image that fills in newSize

func resizedImage(newSize: CGSize) -> UIImage {

guard self.size != newSize else { return self }
UIGraphicsBeginImageContextWithOptions(newSize, false, 0.0);
self.draw(in: CGRect(x: 0, y: 0, width: newSize.width, height: newSize.height))
let newImage: UIImage = UIGraphicsGetImageFromCurrentImageContext()!
UIGraphicsEndImageContext()
return newImage
}

/// Returns a resized image that fits in rectSize, keeping it's aspect ratio
/// Note that the new image size is not rectSize, but within it.
func resizedImageWithinRect(rectSize: CGSize) -> UIImage {
let widthFactor = size.width / rectSize.width
let heightFactor = size.height / rectSize.height

var resizeFactor = widthFactor
if size.height > size.width {
resizeFactor = heightFactor
}
let newSize = CGSize(width: size.width/resizeFactor, height: size.height/resizeFactor)
let resized = resizedImage(newSize)
return resized
}

}


I'm still using this code in my apps. So rest assured



// Tests
guard let url = NSURL(string: "http://placehold.it/300x150") else { fatalError("Bad URL") }
guard let data = NSData(contentsOfURL: url) else { fatalError("Bad data") }
guard let img = UIImage(data: data) else { fatalError("Bad data") }

let outImageFit = img.resizedImageWithinRect(CGSize(width: 200, height: 200))
let outImageFill = img.resizedImage(CGSize(width: 200, height: 200))





share|improve this answer















Resizing your image will not affect your constraints. So you may want to update them aswell. for now-- you can resize images by doing so:



import UIKit
extension UIImage {

/// Returns a image that fills in newSize

func resizedImage(newSize: CGSize) -> UIImage {

guard self.size != newSize else { return self }
UIGraphicsBeginImageContextWithOptions(newSize, false, 0.0);
self.draw(in: CGRect(x: 0, y: 0, width: newSize.width, height: newSize.height))
let newImage: UIImage = UIGraphicsGetImageFromCurrentImageContext()!
UIGraphicsEndImageContext()
return newImage
}

/// Returns a resized image that fits in rectSize, keeping it's aspect ratio
/// Note that the new image size is not rectSize, but within it.
func resizedImageWithinRect(rectSize: CGSize) -> UIImage {
let widthFactor = size.width / rectSize.width
let heightFactor = size.height / rectSize.height

var resizeFactor = widthFactor
if size.height > size.width {
resizeFactor = heightFactor
}
let newSize = CGSize(width: size.width/resizeFactor, height: size.height/resizeFactor)
let resized = resizedImage(newSize)
return resized
}

}


I'm still using this code in my apps. So rest assured



// Tests
guard let url = NSURL(string: "http://placehold.it/300x150") else { fatalError("Bad URL") }
guard let data = NSData(contentsOfURL: url) else { fatalError("Bad data") }
guard let img = UIImage(data: data) else { fatalError("Bad data") }

let outImageFit = img.resizedImageWithinRect(CGSize(width: 200, height: 200))
let outImageFill = img.resizedImage(CGSize(width: 200, height: 200))






share|improve this answer














share|improve this answer



share|improve this answer








edited Nov 21 '18 at 6:44

























answered Nov 21 '18 at 6:38









excitedmicrobeexcitedmicrobe

9821518




9821518













  • 'CGRectMake' is unavailable in Swift

    – qunzor
    Nov 21 '18 at 6:42











  • Updating that in a sec

    – excitedmicrobe
    Nov 21 '18 at 6:43











  • @qunzor done, thanks for bringing that to my attention

    – excitedmicrobe
    Nov 21 '18 at 6:45



















  • 'CGRectMake' is unavailable in Swift

    – qunzor
    Nov 21 '18 at 6:42











  • Updating that in a sec

    – excitedmicrobe
    Nov 21 '18 at 6:43











  • @qunzor done, thanks for bringing that to my attention

    – excitedmicrobe
    Nov 21 '18 at 6:45

















'CGRectMake' is unavailable in Swift

– qunzor
Nov 21 '18 at 6:42





'CGRectMake' is unavailable in Swift

– qunzor
Nov 21 '18 at 6:42













Updating that in a sec

– excitedmicrobe
Nov 21 '18 at 6:43





Updating that in a sec

– excitedmicrobe
Nov 21 '18 at 6:43













@qunzor done, thanks for bringing that to my attention

– excitedmicrobe
Nov 21 '18 at 6:45





@qunzor done, thanks for bringing that to my attention

– excitedmicrobe
Nov 21 '18 at 6:45


















draft saved

draft discarded




















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53406416%2fios-how-to-resize-image-at-table-view-cell-swift%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

MongoDB - Not Authorized To Execute Command

in spring boot 2.1 many test slices are not allowed anymore due to multiple @BootstrapWith

How to fix TextFormField cause rebuild widget in Flutter