#swift #swiftui #pdfdocument
#swift #swiftui #pdfdocument
Вопрос:
Я пытаюсь объединить два файла URL-адресов PDF в один PDFView.
import Foundation
import PDFKit
protocol PdfViewDelegate: class {
func heightDidReccived(height:CGFloat)
}
class PdfView: YITStoryboardCustomXibView {
weak var delegate: PdfViewDelegate?
@IBOutlet weak var pageNumbersLabel: UILabel!
@IBOutlet weak var showThumbnailButton: UIButton!
@IBOutlet weak var pdfViewContainer: UIView!
@IBOutlet weak var thumbnailViewContainer: UIView!
@IBOutlet weak var pageNumbersView: UIView!
@IBOutlet weak var pdfViewContainerHeight: NSLayoutConstraint!
@IBOutlet weak var thumbnailViewHeightConstraint: NSLayoutConstraint!
var pdfView = PDFView()
var subData = Data()
let pageCount = 1
var pageReturnCount = 0
override func awakeFromNib() {
super.awakeFromNib()
}
override func layoutSubviews() {
pdfScaleFactor()
}
override func xibName() -> String {
return "PdfView"
}
func openPdf(url: String) {
let webService = WebService()
webService.delegate = self
webService.getRequestFor(url: "http://www.orimi.com/pdf-test.pdf")
let webService1 = WebService()
webService1.delegate = self
webService1.getRequestFor(url: "http://www.pdf995.com/samples/pdf.pdf")
}
func getUrl(name:String) -> URL{
let resourceDocPath = (FileManager.default.urls(for: .documentDirectory, in: .userDomainMask)).last! as URL
return resourceDocPath.appendingPathComponent("(name).pdf")
}
func configurPdfView(data:Data){
self.pdfView = PDFView()
if let document = PDFDocument(data: subData) {
pdfView.autoresizesSubviews = true
pdfView.autoresizingMask = [.flexibleWidth, .flexibleHeight, .flexibleTopMargin, .flexibleLeftMargin]
pdfView.displayDirection = .horizontal
pdfView.autoScales = true
pdfView.displaysRTL = true
pdfView.displayMode = .singlePageContinuous
pdfView.document = document
pdfView.backgroundColor = .clear
pdfViewContainer.addViewWithConstraint(view: pdfView, toView: pdfViewContainer)
pdfView.usePageViewController(true, withViewOptions:["interPageSpacing": -50])
pdfViewContainer.layer.masksToBounds = false
pdfViewContainer.layer.shadowOffset = CGSize(width: 0, height: 7)
pdfViewContainer.layer.shadowRadius = 10
pdfViewContainer.layer.shadowOpacity = 0.16
}
}
@IBAction func showThumbnailView(_ sender: Any) {
}
private func pdfScaleFactor(){
pdfView.minScaleFactor = pdfView.scaleFactorForSizeToFit
}
@objc func updatePageChange() {
if let pageNumber = pdfView.currentPage?.pageRef?.pageNumber,let total = pdfView.document?.pageCount {
pageNumbersLabel.text = "(pageNumber) מתוך (total)"
}
}
}
extension PdfView : WebServiceDelegate {
func didReceiveData(data: Data) {
print("subData 1(data.count)n")
print("subData 2(subData.count)n")
subData.append(data)
if pageCount != pageReturnCount {
pageReturnCount = pageReturnCount 1
}else{
DispatchQueue.main.async {
self.configurPdfView(data: self.subData)
}
}
}
}
класс WebService
class WebService: NSObject {
weak var delegate: WebServiceDelegate?
func getRequestFor(url:String) {
print("getRequestFor : (url) n")
if WebService.isConectedToInternet(){
AF.request(url,method:.get)
.response { response in
if let data = response.data {
DispatchQueue.global(qos: .background).async {
self.delegate?.didReceiveData(data: data)
}
}
}
}
}
сначала я пытаюсь :
но всегда PDFView загружает последний файл pdf и не объединяет file1 и file2, я видел, что данные больше после объединения data1 и data2.
второй :
Я пытаюсь объединить два PdfDocument, но все еще не работаю.
что я делаю не так? возможно ли сделать что-то подобное?
Комментарии:
1. вы правильно берете данные 1 и данные 2 с сервера, верно? если проблема просто вызывает слияние, я оставлю ответ
2. да, я пытаюсь объединить data1 и data2 и увидел, что все в порядке, но после загрузки данных в PdfDocument вижу только второй файл, который он пытается загрузить.
3. не могли бы вы попробовать мой ответ?
Ответ №1:
После того, как вы возьмете data1
и data2
конвертируете его в экземпляры PDF, вы можете использовать эту функцию :
func combinePdf(data1: Data, data2: Data) -> PDFDocument {
let pdfDocument = PDFDocument(data: data1)!
let otherPdfDocument = PDFDocument(data: data2)!
let newPdfDocument = PDFDocument()
for p in 0..<pdfDocument.pageCount {
let page = pdfDocument.page(at: p)!
newPdfDocument.insert(page, at: newPdfDocument.pageCount)
}
for q in 0..<otherPdfDocument.pageCount {
let page = otherPdfDocument.page(at: q)!
newPdfDocument.insert(page, at: newPdfDocument.pageCount)
}
return newPdfDocument
}