【发布时间】:2015-11-01 11:43:47
【问题描述】:
是否可以使用 Swift Playground 创建 PDF 文件?
我正在编写一个应用程序,它可以从一组选定的对象中自动生成一个,但是通过该过程检查我所做的每一个更改很快就会变得很痛苦。
我不确定 Playground 在文档目录或其他方面是如何工作的,因为我只将它用于文档。
可以这样做吗?
编辑:
所以我设法通过使用目录NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true) 从 Playground 生成 PDF
我已将网络视图放入 Playground 以尝试预览它,但没有结果。在操场上还有其他实时方式吗?
Web 视图正在使用正确的 URL 加载请求,因为我在 Finder 中使用相同的 url 导航到它,但它只显示在 Playground 中预览的空白页面,尽管图像出现在 Finder 的 PDF 中
游乐场文件
import UIKit
// Properties
var documentDirectories : NSArray = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)
var documentDirectory : String = documentDirectories[0] as! String
var pdfFileName : String = "bill.pdf"
var pdfPathWithFileName : String = (documentDirectory as NSString).stringByAppendingPathComponent(pdfFileName)
let pageSize : CGSize = CGSize(width: 200, height: 1000)
// Graphics Context
UIGraphicsBeginPDFContextToFile(pdfPathWithFileName, CGRectZero, nil)
UIGraphicsBeginPDFPageWithInfo(CGRect(x: 0, y: 0, width: 850, height: 1000), nil)
let context : CGContextRef = UIGraphicsGetCurrentContext()!
let rect : CGRect = CGRect(x: 0, y: 0, width: pageSize.width, height: pageSize.height)
// Fill background
CGContextSetFillColorWithColor(context, UIColor.whiteColor().CGColor)
CGContextFillRect(context, rect)
// Products
CGContextSetFillColorWithColor(context, UIColor.blackColor().CGColor)
for var i = 0; i < 10; i++ {
let rect : CGRect = CGRect(x: 100, y: (i * 50), width: 300, height: 50)
let productName : NSString = "ProductNo\(i)"
productName.drawWithRect(rect, options: .UsesFontLeading, attributes: nil, context: NSStringDrawingContext.init())
let imageRect : CGRect = CGRect(x: 20, y: (i*50), width: 50, height: 50)
let image = UIImage(named: "testImage.png")
image?.drawInRect(imageRect)
}
// End PDF Context
UIGraphicsEndPDFContext()
// PDF Web Request
let pdfURL = NSURL(string: pdfPathWithFileName)
let request = NSURLRequest(URL: pdfURL!)
// Web View
let webSize = CGRect(x: 0, y: 0, width: pageSize.width, height: pageSize.height)
let webView = UIWebView(frame: webSize)
webView.loadRequest(request)
let scroll : UIScrollView = webView.scrollView
let zoom = webView.bounds.size.width/scroll.contentSize.width
scroll.setZoomScale(zoom, animated: true)
【问题讨论】:
-
谢谢埃里克。查看更新的问题
-
不客气。通过显示一些相关代码来帮助我们帮助您。人们或许可以提供帮助,但目前 IMO 的问题有点模糊。
-
之前是要粘贴到 Playground 文件中的,现在就完成了!
标签: swift pdf-generation swift-playground