This is a fork of original tkPDFViewer librarary that fixes an " AttributeError: ‘Page’ object has no attribute ‘getPixmap’ " bug, which occurs due to a change in a fitz module. Original developer abandoned this project hence my fork with a fix.
The tkPDFViewer is python library, which allows you to embed the PDF file in your tkinter GUI. In just three steps.
- Install
- Import
- Embed on your gui
- Embed your PDF in your tkinter GUI.
- Customize width and height of your PDF.
High quality pdf pages image with customizable width and height worked with python 2.7+.
Install tkPDFViewer using pip
pip install tkPDFViewer
Install tkPDFViewer using pip3
pip3 install tkPDFViewer
Install using git.
pip install git+"https://github.com/Roshanpaswan/tkPDFViewer/archive/0.1.zip"
An Example of Using tkPDFViewer.
from tkPDFViewer import tkPDFViewer as pdf
from tkinter import*
root = Tk()
#create object like this.
variable1 = pdf.ShowPdf()
#Add your pdf location and width and height.
variable2 = variable1.pdf_view(root,pdf_location=r"location",width=50,height=100)
variable2.pack()
root.mainloop()
pdf_location = "" --> location of your pdf
width = 0 --> width of your pdf to be embeded
height = 0 --> height of your pdf to be embeded
To embed your pdf use --> .pack() or .grid() or .place()
bar --> True or False, Through this attribute you can hide or unhide the loading bar which showing on the frame after your gui is opened. This indicate that 'how much your pdf is loaded'.Once it complete it unhide automatically and your pdf get embeded.
load --> after or before, Through this attribute you can decide that , when your pdf object is to convert. If you select 'after' then the object of your pdf is convert after your gui is opened.Otherwise it convert first then your gui is opened. It is recommended that to select after which is default.Beacause this takes time. Depends on the size of pdf. And if you select 'before' then it make your gui slow to open.
- tkinter
- PyMuPDF
- Thread
- math
MIT