Added page clearing function
This commit is contained in:
parent
1a5910f1ef
commit
51fe3faf69
2 changed files with 41 additions and 7 deletions
|
@ -15,11 +15,12 @@ class PopplerController(object):
|
|||
return poppler.document_new_from_file('file://' + pdf_path, password=None)
|
||||
|
||||
|
||||
def generate_page_images(self, pages=[]):
|
||||
def generate_page_images(self, pages=[], clear_page=True):
|
||||
import cairo
|
||||
import StringIO
|
||||
|
||||
page = self.doc.get_page(pages[0] if pages else 0)
|
||||
|
||||
width, height = page.get_size()
|
||||
surface = cairo.ImageSurface(cairo.FORMAT_RGB24, int(width*2), int(height*2))
|
||||
context = cairo.Context(surface)
|
||||
|
@ -27,6 +28,10 @@ class PopplerController(object):
|
|||
|
||||
for page_num in pages or xrange(self.doc.get_n_pages()):
|
||||
page = self.doc.get_page(page_num)
|
||||
|
||||
if clear_page:
|
||||
self.clear_page(page)
|
||||
|
||||
page.render(context)
|
||||
fd = StringIO.StringIO()
|
||||
surface.write_to_png(fd)
|
||||
|
@ -34,15 +39,33 @@ class PopplerController(object):
|
|||
yield fd
|
||||
|
||||
|
||||
def clear_page(self, page):
|
||||
for field_mapping in page.get_form_field_mapping():
|
||||
field = field_mapping.field
|
||||
field_type = field.get_field_type().value_nick
|
||||
|
||||
if field_type == 'text':
|
||||
field.text_set_text('')
|
||||
elif field_type == 'button':
|
||||
field.button_set_state(0)
|
||||
|
||||
|
||||
def get_page_fields(self, page_num):
|
||||
page = self.doc.get_page(page_num)
|
||||
for field in page.get_form_field_mapping():
|
||||
area = field.area
|
||||
data = field.field
|
||||
field_type = data.get_field_type()
|
||||
|
||||
if field_type.value_nick == 'text':
|
||||
value = data.text_get_text()
|
||||
elif field_type.value_nick == 'button':
|
||||
value = data.button_get_state()
|
||||
|
||||
yield {
|
||||
'name': data.get_name(),
|
||||
'value': data.text_get_text(),
|
||||
'value': value,
|
||||
'type': field_type.value_nick,
|
||||
'area': {
|
||||
'pos_x': area.x1,
|
||||
'pos_y': area.y1,
|
||||
|
|
21
models.py
21
models.py
|
@ -9,6 +9,7 @@ from pdfformfiller.controller import PopplerController
|
|||
FIELD_TYPE_CHOICES = (
|
||||
('t', 'Text'),
|
||||
('c', 'Checkbox'),
|
||||
('b', 'Button'),
|
||||
)
|
||||
|
||||
|
||||
|
@ -52,9 +53,14 @@ class Page(models.Model):
|
|||
def __unicode__(self):
|
||||
return self.name
|
||||
|
||||
def process_fields(self):
|
||||
poppler_con = PopplerController(self.document.pdf.path)
|
||||
fields = poppler_con.get_page_fields(self.page_num)
|
||||
@property
|
||||
def poppler(self):
|
||||
if not hasattr(self, '_poppler'):
|
||||
self._poppler = PopplerController(self.document.pdf.path)
|
||||
return self._poppler
|
||||
|
||||
def extract_fields(self):
|
||||
fields = self.poppler.get_page_fields(self.page_num)
|
||||
|
||||
for fdata in fields:
|
||||
try:
|
||||
|
@ -63,12 +69,12 @@ class Page(models.Model):
|
|||
field = FormField(page=self,
|
||||
name=fdata['name'])
|
||||
|
||||
field.fieldtype = fdata['type']
|
||||
area = fdata['area']
|
||||
field.pos_x = area['pos_x']
|
||||
field.pos_y = area['pos_y']
|
||||
field.width = area['width']
|
||||
field.height = area['height']
|
||||
field.fieldtype = 't'
|
||||
field.save()
|
||||
|
||||
|
||||
|
@ -76,7 +82,7 @@ class Page(models.Model):
|
|||
def page_post_save(sender, **kwargs):
|
||||
instance = kwargs.get('instance', None)
|
||||
if instance:
|
||||
instance.process_fields()
|
||||
instance.extract_fields()
|
||||
|
||||
models.signals.post_save.connect(page_post_save, sender=Page)
|
||||
|
||||
|
@ -95,3 +101,8 @@ class FormField(models.Model):
|
|||
|
||||
def page_num(self):
|
||||
return self.page.page_num
|
||||
|
||||
@classmethod
|
||||
def create_from_poppler_field(cls, field):
|
||||
return cls()
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue