iOS中UIImage根据屏宽调整size的实例代码

软件编程 IOS 分类:[default] 更新日期: 2017-02-09
最近做项目遇到这样一个需求,要求UIImage根据屏幕宽度按照自己本身比例改变高度,下面通过本文给大家分享iOS UIImage根据屏宽调整size的实例代码,需要的朋友参考下吧

iOS中UIImage根据屏宽调整size的实例代码
iOS中UIImage根据屏宽调整size的实例代码

需求:UIImage根据屏幕宽度按照自己本身比例改变高度

上代码,为UIImage创建一个Category

#import "UIImage+UIImageExtras.h" 
@implementation UIImage (UIImageExtras) 
- (UIImage *)imageByScalingToSize:(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; 
 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: 
 UIGraphicsBeginImageContext(targetSize); 
 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 

在需要使用的地方import然后使用

CGSize size = image.size; 
image = [image imageByScalingToSize:CGSizeMake([UIScreen mainScreen].bounds.size.width,[UIScreen mainScreen].bounds.size.width * (size.height / size.width))]; 
self.imageview.image = image; 

以上所述是小编给大家介绍的iOS UIImage根据屏宽调整size的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


> 本站内容系网友提交或本网编辑转载,其目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。如涉及作品内容、版权和其它问题,请及时与本网联系,我们将在第一时间删除内容!

相关文章
  • Flex输出文件到本地的两种方法
    flex中输出文件到本地有两种方法分别是File和FielRefreence,下面的实例代码,大家可以看看在flex中输出文件到本地目前我用到两种方法,分别是File和FielRefreence 例子: var exportString:String = "这就是一个测试" 1.File输出 代码如下:var ff:File = File ...
  • Swift中内置的集合类型学习笔记
    Swift中内置的集合类型学习笔记
    Swift中自带数组.set.字典三大集合类型,这里将学习过程中的基础的Swift中内置的集合类型学习笔记进行整理,需要的朋友可以参考下一.引言 Swift中提供了3种集合类型,Array数据类型,Set集合类型,Dictionary字典类型.Array用于存放一组有序的数据,数据角标从0开始一次递增:Set用于存放一组无序的数据,数据不可以重复:Dicti ...
  • Bootstrap中文本框的宽度变窄并且加入一副验证码图片的实现方法
    Bootstrap中文本框的宽度变窄并且加入一副验证码图片的实现方法
    这篇文章主要介绍了Bootstrap中文本框的宽度变窄并且加入一副验证码图片的实现方法的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下今天项目经理刚交给一个活儿,要我实现这样一个功能:要实现的是验证码文本框变窄一点,然后右边加入一副验证码图片,并且在响应式布局的情况下在移动端访问的时候验证码图片能保持和验证码文本框在同一行,这个怎么做?难为了半天 ...
  • JavaScript中的正则表达式(推荐)
    正则表达式通常用于在文本中查找匹配的字符串,js正则表达式在程序开发中应用非常广泛,本文给大家介绍JavaScript 中的正则表达式推荐,感兴趣的朋友一起学习吧正则表达式的大致匹配过程是:依次拿出表达式和文本中的字符比较,如果每一个字符都能匹配,则匹配成功:一旦有匹配不成功的字符则匹配失败. 正则表达式通常用于在文本中查找匹配的字符串.Python里数量词 ...
  • Python中在脚本中引用其他文件函数的实现方法
    下面小编就为大家带来一篇Python中在脚本中引用其他文件函数的实现方法.小编觉得挺不错的,现在就分享给大家,也给大家做个参考.一起跟随小编过来看看吧在导入文件的时候,Python只搜索当前脚本所在的目录,加载(entry-point)入口脚本运行目录和sys.path中包含的路径例如包的安装地址.所以如果要在当前脚本引用其他文件,除了将文件放在和脚本同一目 ...
  • 将PHP的session数据存储到数据库中的代码实例
    这里我们将分享两个将PHP的session数据存储到数据库中的代码实例,分别针对PostgreSQL与MySQL,需要的朋友可以参考下一个开发环境有多个网站,需要使用不同的session,解决方案很多.不过这次也高大上一把,用数据库存,方便以后扩展. PostgreSQL版首先是数据库的部分 --drop table php_session create u ...
猜你喜欢