Added page clearing function

This commit is contained in:
Mark Riedesel 2013-10-16 12:45:02 -05:00
parent 1a5910f1ef
commit 51fe3faf69
2 changed files with 41 additions and 7 deletions

View file

@ -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,

View file

@ -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()