任务是调整图像的大小。
我已阅读 this post并采用了CGBitmapContextCreate & CGContextDrawImage方法。这就是我的调整大小函数的样子:
extension UIImage {
func with(maxHeight: CGFloat, maxWidth: CGFloat) -> UIImage? {
guard let image = self.cgImage else {
return nil
}
var height = CGFloat(image.height)
var width = CGFloat(image.width)
guard height > 0 && width > 0 else {
return nil
}
let maxHeight = round(maxHeight)
let maxWidth = round(maxWidth)
guard height > maxHeight || width > maxWidth else {
return nil
}
let heightProportions = height / maxHeight
let widthProportions = width / maxWidth
height = heightProportions > widthProportions ? maxHeight : round(height / widthProportions)
width = widthProportions > heightProportions ? maxWidth : round(width / heightProportions)
let size = CGSize(width: width, height: height)
let bitmapInfo = image.bitmapInfo.rawValue
let bitsPerComponent = image.bitsPerComponent
let bytesPerRow = image.bytesPerRow
let space = image.colorSpace ?? CGColorSpaceCreateDeviceRGB()
let context = CGContext(data: nil, width: Int(width), height: Int(height), bitsPerComponent: bitsPerComponent, bytesPerRow: bytesPerRow, space: space, bitmapInfo: bitmapInfo)
context?.interpolationQuality = .high
context?.draw(image, in: CGRect.init(origin: .zero, size: size))
guard let newImage = context?.makeImage() else {
return nil
}
return UIImage(cgImage: newImage)
}
}
此功能在测试期间运行良好,但我在生产线上遇到了崩溃:
context?.draw(image, in: CGRect.init(origin: .zero, size: size))
堆栈跟踪:
#11. Crashed: com.apple.root.utility-qos
0 CoreGraphics 0x184d9a59c ERROR_CGDataProvider_BufferIsNotReadable + 12
1 CoreGraphics 0x184d9a2c0 CGDataProviderRetainBytePtr + 216
2 CoreGraphics 0x184e8d06c get_image_pointer + 64
3 CoreGraphics 0x184e8d2c8 img_raw_access + 52
4 CoreGraphics 0x184e88000 img_interpolate_read + 708
5 CoreGraphics 0x184e8c14c img_data_lock + 7048
6 CoreGraphics 0x184e8a56c CGSImageDataLock + 184
7 CoreGraphics 0x184caa628 ripc_AcquireRIPImageData + 308
8 CoreGraphics 0x184e9f1b0 ripc_DrawImage + 644
9 CoreGraphics 0x184e8efac CGContextDrawImageWithOptions + 632
10 libswiftCoreGraphics.dylib 0x104781638 (Missing)
所以,我有两个问题:
最佳答案
我使用这个更简单的扩展来包装 UIImage 的 draw(in:)。我发现它质量高而且速度相当快。
extension UIImage {
public func resized(maxSize: CGSize) -> UIImage? {
let imageSize = self.size
guard imageSize.height > 0, imageSize.width > 0 else { return nil }
let ratio = min(maxSize.width/imageSize.width, maxSize.height/imageSize.height)
let newSize = CGSize(width: imageSize.width*ratio, height: imageSize.height*ratio)
let renderer = UIGraphicsImageRenderer(size: newSize)
return renderer.image(actions: { (ctx) in
self.draw(in: CGRect(origin: .zero, size: newSize))
})
}
}
用法:
let resizedImage = myImage.resized(maxSize: CGSize(width: maxWidth, height: maxHeight))
请注意,此处的大小以点为单位,这意味着基础像素数将自动乘以设备的比例因子(例如,视网膜显示器为 2x)。换句话说,此方法专为生成的 UIImage 将显示在屏幕上的情况而设计。
关于swift - Core Graphics/Quartz 2D 图像大小调整崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49429715/
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
我有带有Logo图像的公司模型has_attached_file:logo我用他们的Logo创建了许多公司。现在,我需要添加新样式has_attached_file:logo,:styles=>{:small=>"30x15>",:medium=>"155x85>"}我是否应该重新上传所有旧数据以重新生成新样式?我不这么认为……或者有什么rake任务可以重新生成样式吗? 最佳答案 参见Thumbnail-Generation.如果rake任务不适合你,你应该能够在控制台中使用一个片段来调用重新处理!关于相关公司
我正在尝试使用Ruby2.0.0和Rails4.0.0提供的API从imgur中提取图像。我已尝试按照Ruby2.0.0文档中列出的各种方式构建http请求,但均无济于事。代码如下:require'net/http'require'net/https'defimgurheaders={"Authorization"=>"Client-ID"+my_client_id}path="/3/gallery/image/#{img_id}.json"uri=URI("https://api.imgur.com"+path)request,data=Net::HTTP::Get.new(path
2022/8/4更新支持加入水印水印必须包含透明图像,并且水印图像大小要等于原图像的大小pythonconvert_image_to_video.py-f30-mwatermark.pngim_dirout.mkv2022/6/21更新让命令行参数更加易用新的命令行使用方法pythonconvert_image_to_video.py-f30im_dirout.mkvFFMPEG命令行转换一组JPG图像到视频时,是将这组图像视为MJPG流。我需要转换一组PNG图像到视频,FFMPEG就不认了。pyav内置了ffmpeg库,不需要系统带有ffmpeg工具因此我使用ffmpeg的python包装p
Region是HBase数据管理的基本单位,region有一点像关系型数据的分区。region中存储这用户的真实数据,而为了管理这些数据,HBase使用了RegionSever来管理region。Region的结构hbaseregion的大小设置默认情况下,每个Table起初只有一个Region,随着数据的不断写入,Region会自动进行拆分。刚拆分时,两个子Region都位于当前的RegionServer,但处于负载均衡的考虑,HMaster有可能会将某个Region转移给其他的RegionServer。RegionSplit时机:当1个region中的某个Store下所有StoreFile
我在一段非常简单的代码(如我所想)中得到了一个错误的值:org=4caseorgwhenorg=4val='H'endputsval=>nil请不要生气,我希望我错过了一些非常明显的东西,但我真的想不通。谢谢。 最佳答案 这是典型的Ruby错误。case有两种被调用的方法,一种是你传递一个东西作为分支的基础,另一种是你不传递的东西。如果您确实在case中指定了一个表达式语句然后评估所有其他条件并与===进行比较.在这种情况下org评估为false和org===false显然不是真的。所有其他情况也是如此,它们要么是真的,要么是假的。
有这样的事吗?我想在Ruby程序中使用它。 最佳答案 试试这个http://csl.sublevel3.org/jp2a/此外,Imagemagick可能还有一些东西 关于ruby-是否有将图像文件转换为ASCII艺术的命令行程序或库?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/6510445/
我有以下内容:text.gsub(/(lower)(upper)/,'\1\2')我可以将\2替换为大写吗?类似于:sed-e's/\(abc\)/\U\1/'这在Ruby中可行吗? 最佳答案 查看gsub文档:str.gsub(模式){|匹配|block}→new_str在block形式中,当前匹配字符串作为参数传入,$1、$2、$`、$&、$'等变量将被适当设置。block返回的值将替换为每次调用的匹配项。"alowerupperb".gsub(/(lower)(upper)/){|s|$1+""+$2.upcase}
我正在使用Dragonfly在Rails3.1应用程序上处理图像。我正在努力通过url将图像分配给模型。我有一个很好的表格:{:multipart=>true}do|f|%>RemovePicture?Dragonfly的文档指出:Dragonfly提供了一个直接从url分配的访问器:@album.cover_image_url='http://some.url/file.jpg'但是当我在控制台中尝试时:=>#ruby-1.9.2-p290>picture.image_url="http://i.imgur.com/QQiMz.jpg"=>"http://i.imgur.com/QQ
我对图像处理完全陌生。我对JPEG内部是什么以及它是如何工作一无所知。我想知道,是否可以在某处找到执行以下简单操作的ruby代码:打开jpeg文件。遍历每个像素并将其颜色设置为fx绿色。将结果写入另一个文件。我对如何使用ruby-vips库实现这一点特别感兴趣https://github.com/ender672/ruby-vips我的目标-学习如何使用ruby-vips执行基本的图像处理操作(Gamma校正、亮度、色调……)任何指向比“helloworld”更复杂的工作示例的链接——比如ruby-vips的github页面上的链接,我们将不胜感激!如果有ruby-