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)
|
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 cairo
|
||||||
import StringIO
|
import StringIO
|
||||||
|
|
||||||
page = self.doc.get_page(pages[0] if pages else 0)
|
page = self.doc.get_page(pages[0] if pages else 0)
|
||||||
|
|
||||||
width, height = page.get_size()
|
width, height = page.get_size()
|
||||||
surface = cairo.ImageSurface(cairo.FORMAT_RGB24, int(width*2), int(height*2))
|
surface = cairo.ImageSurface(cairo.FORMAT_RGB24, int(width*2), int(height*2))
|
||||||
context = cairo.Context(surface)
|
context = cairo.Context(surface)
|
||||||
|
@ -27,6 +28,10 @@ class PopplerController(object):
|
||||||
|
|
||||||
for page_num in pages or xrange(self.doc.get_n_pages()):
|
for page_num in pages or xrange(self.doc.get_n_pages()):
|
||||||
page = self.doc.get_page(page_num)
|
page = self.doc.get_page(page_num)
|
||||||
|
|
||||||
|
if clear_page:
|
||||||
|
self.clear_page(page)
|
||||||
|
|
||||||
page.render(context)
|
page.render(context)
|
||||||
fd = StringIO.StringIO()
|
fd = StringIO.StringIO()
|
||||||
surface.write_to_png(fd)
|
surface.write_to_png(fd)
|
||||||
|
@ -34,15 +39,33 @@ class PopplerController(object):
|
||||||
yield fd
|
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):
|
def get_page_fields(self, page_num):
|
||||||
page = self.doc.get_page(page_num)
|
page = self.doc.get_page(page_num)
|
||||||
for field in page.get_form_field_mapping():
|
for field in page.get_form_field_mapping():
|
||||||
area = field.area
|
area = field.area
|
||||||
data = field.field
|
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 {
|
yield {
|
||||||
'name': data.get_name(),
|
'name': data.get_name(),
|
||||||
'value': data.text_get_text(),
|
'value': value,
|
||||||
|
'type': field_type.value_nick,
|
||||||
'area': {
|
'area': {
|
||||||
'pos_x': area.x1,
|
'pos_x': area.x1,
|
||||||
'pos_y': area.y1,
|
'pos_y': area.y1,
|
||||||
|
|
21
models.py
21
models.py
|
@ -9,6 +9,7 @@ from pdfformfiller.controller import PopplerController
|
||||||
FIELD_TYPE_CHOICES = (
|
FIELD_TYPE_CHOICES = (
|
||||||
('t', 'Text'),
|
('t', 'Text'),
|
||||||
('c', 'Checkbox'),
|
('c', 'Checkbox'),
|
||||||
|
('b', 'Button'),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@ -52,9 +53,14 @@ class Page(models.Model):
|
||||||
def __unicode__(self):
|
def __unicode__(self):
|
||||||
return self.name
|
return self.name
|
||||||
|
|
||||||
def process_fields(self):
|
@property
|
||||||
poppler_con = PopplerController(self.document.pdf.path)
|
def poppler(self):
|
||||||
fields = poppler_con.get_page_fields(self.page_num)
|
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:
|
for fdata in fields:
|
||||||
try:
|
try:
|
||||||
|
@ -63,12 +69,12 @@ class Page(models.Model):
|
||||||
field = FormField(page=self,
|
field = FormField(page=self,
|
||||||
name=fdata['name'])
|
name=fdata['name'])
|
||||||
|
|
||||||
|
field.fieldtype = fdata['type']
|
||||||
area = fdata['area']
|
area = fdata['area']
|
||||||
field.pos_x = area['pos_x']
|
field.pos_x = area['pos_x']
|
||||||
field.pos_y = area['pos_y']
|
field.pos_y = area['pos_y']
|
||||||
field.width = area['width']
|
field.width = area['width']
|
||||||
field.height = area['height']
|
field.height = area['height']
|
||||||
field.fieldtype = 't'
|
|
||||||
field.save()
|
field.save()
|
||||||
|
|
||||||
|
|
||||||
|
@ -76,7 +82,7 @@ class Page(models.Model):
|
||||||
def page_post_save(sender, **kwargs):
|
def page_post_save(sender, **kwargs):
|
||||||
instance = kwargs.get('instance', None)
|
instance = kwargs.get('instance', None)
|
||||||
if instance:
|
if instance:
|
||||||
instance.process_fields()
|
instance.extract_fields()
|
||||||
|
|
||||||
models.signals.post_save.connect(page_post_save, sender=Page)
|
models.signals.post_save.connect(page_post_save, sender=Page)
|
||||||
|
|
||||||
|
@ -95,3 +101,8 @@ class FormField(models.Model):
|
||||||
|
|
||||||
def page_num(self):
|
def page_num(self):
|
||||||
return self.page.page_num
|
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