是否可以使用快速操场创建PDF文件?
我正在写一个应用程序,它会自动从所选对象的数组中生成一个应用程序,但通过该过程检查我所做的每个更改都很快就会变得非常痛苦。PDF格式在Swift Playground中生成
我不确定Playground是如何在文档目录或任何东西方面工作的,因为我只用它来做文档。
可以做到这一点吗?
编辑:
所以我已经设法通过使用目录NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)
我已经把Web视图到操场去尝试和预览,但没有结果得到一个PDF从生成操场。在操场上有实时的另一种方式吗?
Web视图加载正确的URL请求为我所用的相同的URL导航到它在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)
谢谢埃里克。查看更新后的问题 – Sawyer05
不客气。帮助我们通过显示一些相关的代码来帮助你。人们可能会提供帮助,但现在这个问题有点模糊的国际海事组织。 – Moritz
之前打算粘贴在Playground文件中,现在就做! – Sawyer05