9

I'm using PDFKit to display simple PDF's. When I display them on the screen inside a UIView, I've used the code below.

Aims: - Start off with the content to fill the view - want to fill whole screen width wise

override func viewDidLoad() {
    super.viewDidLoad()

    if let path = Bundle.main.path(forResource: "Disclaimer", ofType: "pdf") {
        let url = URL(fileURLWithPath: path)
        if let pdfDocument = PDFDocument(url: url) {
            pdfView.document = pdfDocument
            pdfView.autoScales = true
            pdfView.maxScaleFactor = 4.0
            pdfView.minScaleFactor = pdfView.scaleFactorForSizeToFit
            pdfView.displayMode = .singlePageContinuous
            pdfView.displaysPageBreaks = false
        }
    }
    self.view.backgroundColor = UIColor.black
}

In storyboard I have set a constraint for UIview to fill full width of the screen - which it does.

Using autoscale sales the PDF document smaller than the width of the screen, it basically adds a margin around the pdf. I can zoom in and make he Pdf fill the whole screen, before it overflows and scroll bars come into play.

If I set the scale factor manually, I can make a single page PDF fill the screen width wise, but if the PDF has more than one page, then the width reverts to being less than the screen width with a margin present.

Ultimately I just want to fill the whole of the screen width wise with the PDF without any margin / gap.

Screenshot

Would appreciate some help.

UPDATE: Code used as per advice below -but presently not working:

if let path = Bundle.main.path(forResource: pdfObject, ofType: "pdf") {
            let url = URL(fileURLWithPath: path)
            if let pdfDocument = PDFDocument(url: url) {

            pdfView = PDFView(frame: CGRect(x: 0, y: 0, width: pdfView.frame.width, height: pdfView.frame.height))
                pdfView.document = pdfDocument

            }

        }

Note: pdfView is my UIView that is the PDFView

Nicholas Farmer
  • 773
  • 7
  • 32
  • As an addition I've tried (to no effect): pdfView.autoresizesSubviews = true pdfView.autoresizingMask = [.flexibleWidth, .flexibleHeight, .flexibleTopMargin, .flexibleLeftMargin] – Nicholas Farmer Oct 27 '18 at 08:12

5 Answers5

12

Right, firstly many thanks to Mahesh. While his answer didn't directly answer my question, two things they said did provide a route to solving this.

Overall to set the pdf to fill the view, I needed to set autoresizing and autoscales BEFORE

pdfView.document = pdfDocument

And to then control the zoom, set these AFTER

pdfView.document = pdfDocument

Thus my final code is:

func pdfDisplay() {

    if let path = Bundle.main.path(forResource: pdfObject, ofType: "pdf") {
        let url = URL(fileURLWithPath: path)
        if let pdfDocument = PDFDocument(url: url) {

            pdfView.autoresizesSubviews = true
            pdfView.autoresizingMask = [.flexibleWidth, .flexibleHeight, .flexibleTopMargin, .flexibleLeftMargin]
            pdfView.displayDirection = .vertical

            pdfView.autoScales = true
            pdfView.displayMode = .singlePageContinuous
            pdfView.displaysPageBreaks = true
            pdfView.document = pdfDocument

            pdfView.maxScaleFactor = 4.0
            pdfView.minScaleFactor = pdfView.scaleFactorForSizeToFit

        }
    } 
}

Not going to lie, I'm not sure why this works in this order, I would appreciate a comment from a wiser mind than mine but I hope this helps others

Nicholas Farmer
  • 773
  • 7
  • 32
4

I have been struggling with a similar issue, and very weird and inconsistent behavior of autoScales. In my case, the automatic scaling worked either on the first loaded document, but not on any subsequent loaded documents in the same pdfView, or it only worked from the second loaded document.

I have embedded the pdfView in a UIScrollView, in order to gain more control over the gesture behavior.

The ordering of the commands seems to indeed be key. After a lot of trial and error, this is the order that worked for me best:

  1. Load the document

    pdfView.document = pdfDocument

  2. Set the display mode

    pdfView.displayMode = .singlePage

  3. Set any constraints, background, shadow etc.

  4. Perform changes to the pdfView size by modifying constraints

  5. Set autoScales

    pdfView.autoScales = true

  6. Set the scale factors

    pdfView.minScaleFactor = pdfView.scaleFactorForSizeToFit

This is the only order in which everything worked in my case, and it only worked when stages 2, 5 and 6 were all present.

Ron Regev
  • 459
  • 2
  • 18
2

Just use pdfview = PDFView(frame: CGRect(x: 0, y: 0, width: view.frame.width, height: view.frame.height)) before pdfView.document = pdfDocument

And remove these lines :

pdfView.maxScaleFactor = 4.0
pdfView.minScaleFactor = pdfView.scaleFactorForSizeToFit
Mahesh Shahane
  • 489
  • 5
  • 16
  • Thanks for the input, unfortunately this doesn't work. I just get a blank screen (below the title). FYI my view hierarchy in Storyboard is: View - PDFView – Nicholas Farmer Oct 27 '18 at 08:00
  • please share you storyboard hierarchy. – Mahesh Shahane Oct 27 '18 at 09:30
  • if you are using UIView and inside that pdfview then you can change pdfview = PDFView(frame: CGRect(x: 0, y: 0, width: view.frame.width, height: view.frame.height)) to pdfview = PDFView(frame: CGRect(x: 0, y: 0, width: yourView.frame.width, height: yourView.frame.height)) – Mahesh Shahane Oct 27 '18 at 09:31
  • Hi Mahesh, apologies for delayed repose, I couldn't get to my computer. Unfortunately that doesn't work. I had actually tried it before posting comment above, but re-tired and no effect. Ive also tried removing constraints from pdfView to no effect. I would appreciate any further hep, I'm keen to give you the bounty! – Nicholas Farmer Oct 28 '18 at 10:59
  • @MaheshShahane Hey can you please help me ? – Ekta Padaliya Aug 27 '19 at 11:47
  • @EktaPadaliya what you need? let me know. – Mahesh Shahane Aug 28 '19 at 12:03
2

Setup the pdfView in viewDidLoad() and put this in viewDidLayoutSubviews():

pdfView.maxScaleFactor = 4.0 
pdfView.minScaleFactor = pdfView.scaleFactorForSizeToFit
MJQZ1347
  • 2,607
  • 7
  • 27
  • 49
0

First, set minScaleFactor, then set scaleFactor, which must be between minScaleFactor and maxScaleFactor.

Run a debug, and vary this values until you got the perfect size for you.

func showPDF(_ dataStr:String){
    guard let data = Data(base64Encoded: dataStr) else { return }
    let pdfView = PDFView(frame: self.view.bounds)
    pdfView.autoresizingMask = [.flexibleWidth, .flexibleHeight]
    pdfView.autoScales = true
    pdfView.displayMode = .singlePageContinuous
    pdfView.displaysPageBreaks = true
    pdfView.document = PDFDocument(data:data)
    pdfView.maxScaleFactor = 4.0
    pdfView.minScaleFactor = 1.15
    pdfView.scaleFactor = 1.15
    self.view.addSubview(pdfView)
}
Giovax68
  • 25
  • 4