source: pdfshuffler/trunk/fuentes/pdfshuffler/pdfshuffler_iconview.py @ 337

Last change on this file since 337 was 337, checked in by jrpelegrina, 4 years ago

Firs release to xenial

File size: 5.4 KB
Line 
1#!/usr/bin/python
2# -*- coding: utf-8 -*-
3
4"""
5
6 PdfShuffler 0.6.0 - GTK+ based utility for splitting, rearrangement and
7 modification of PDF documents.
8 Copyright (C) 2008-2012 Konstantinos Poulios
9 <https://sourceforge.net/projects/pdfshuffler>
10
11 This file is part of PdfShuffler.
12
13 PdfShuffler is free software; you can redistribute it and/or modify
14 it under the terms of the GNU General Public License as published by
15 the Free Software Foundation; either version 3 of the License, or
16 (at your option) any later version.
17
18 This program is distributed in the hope that it will be useful,
19 but WITHOUT ANY WARRANTY; without even the implied warranty of
20 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
21 GNU General Public License for more details.
22
23 You should have received a copy of the GNU General Public License along
24 with this program; if not, write to the Free Software Foundation, Inc.,
25 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
26
27"""
28
29import gtk
30import gobject
31import cairo
32
33from math import pi as M_PI
34
35class CellRendererImage(gtk.GenericCellRenderer):
36    __gproperties__ = {
37            "image": (gobject.TYPE_PYOBJECT, "Image", "Image",
38                      gobject.PARAM_READWRITE),
39            "width": (gobject.TYPE_FLOAT, "Width", "Width",
40                      0., 1.e4, 0., gobject.PARAM_READWRITE),
41            "height": (gobject.TYPE_FLOAT, "Height", "Height",
42                       0., 1.e4, 0., gobject.PARAM_READWRITE),
43            "rotation": (gobject.TYPE_INT, "Rotation", "Rotation",
44                         0, 360, 0, gobject.PARAM_READWRITE),
45            "scale": (gobject.TYPE_FLOAT, "Scale", "Scale",
46                      0.01, 100., 1., gobject.PARAM_READWRITE),
47            "resample": (gobject.TYPE_FLOAT,
48                     "Resample", "Resample Coefficient",
49                      1., 100., 1., gobject.PARAM_READWRITE),
50            "cropL": (gobject.TYPE_FLOAT, "CropL", "CropL",
51                      0., 1., 0., gobject.PARAM_READWRITE),
52            "cropR": (gobject.TYPE_FLOAT, "CropR", "CropR",
53                      0., 1., 0., gobject.PARAM_READWRITE),
54            "cropT": (gobject.TYPE_FLOAT, "CropT", "CropT",
55                      0., 1., 0., gobject.PARAM_READWRITE),
56            "cropB": (gobject.TYPE_FLOAT, "CropB", "CropB",
57                      0., 1., 0., gobject.PARAM_READWRITE),
58    }
59
60    def __init__(self):
61        self.__gobject_init__()
62        self.th1 = 2. # border thickness
63        self.th2 = 3. # shadow thickness
64
65    def get_geometry(self):
66
67        rotation = int(self.rotation) % 360
68        rotation = ((rotation + 45) / 90) * 90
69        if not self.image:
70            w0 = w1 = self.width / self.resample
71            h0 = h1 = self.height / self.resample
72        else:
73            w0 = self.image.get_width()
74            h0 = self.image.get_height()
75            if rotation == 90 or rotation == 270:
76                w1, h1 = h0, w0
77            else:
78                w1, h1 = w0, h0
79
80        x = self.cropL * w1
81        y = self.cropT * h1
82
83        scale = self.resample * self.scale
84        w2 = int(scale * (1. - self.cropL - self.cropR) * w1)
85        h2 = int(scale * (1. - self.cropT - self.cropB) * h1)
86       
87        return w0,h0,w1,h1,w2,h2,rotation
88
89    def do_set_property(self, pspec, value):
90        setattr(self, pspec.name, value)
91
92    def do_get_property(self, pspec):
93        return getattr(self, pspec.name)
94
95    def on_render(self, window, widget, background_area, cell_area, \
96                 expose_area, flags):
97        if not self.image:
98            return
99
100        w0,h0,w1,h1,w2,h2,rotation = self.get_geometry()
101        th = int(2*self.th1+self.th2)
102        w = w2 + th
103        h = h2 + th
104
105        x = cell_area.x
106        y = cell_area.y
107        if cell_area and w > 0 and h > 0:
108            x += self.get_property('xalign') * \
109                 (cell_area.width - w - self.get_property('xpad'))
110            y += self.get_property('yalign') * \
111                 (cell_area.height - h - self.get_property('ypad'))
112
113        cr = window.cairo_create()
114        cr.translate(x,y)
115
116        x = self.cropL * w1
117        y = self.cropT * h1
118
119        #shadow
120        cr.set_source_rgb(0.5, 0.5, 0.5)
121        cr.rectangle(th, th, w2, h2)
122        cr.fill()
123
124        #border
125        cr.set_source_rgb(0, 0, 0)
126        cr.rectangle(0, 0, w2+2*self.th1, h2+2*self.th1)
127        cr.fill()
128
129        #image
130        cr.set_source_rgb(1, 1, 1)
131        cr.rectangle(self.th1, self.th1, w2, h2)
132        cr.fill_preserve()
133        cr.clip()
134
135        cr.translate(self.th1,self.th1)
136        scale = self.resample * self.scale
137        cr.scale(scale, scale)
138        cr.translate(-x,-y)
139        if rotation > 0:
140            cr.translate(w1/2,h1/2)
141            cr.rotate(rotation * M_PI / 180)
142            cr.translate(-w0/2,-h0/2)
143
144        cr.set_source_surface(self.image)
145        cr.paint()
146
147    def on_get_size(self, widget, cell_area=None):
148        x = y = 0
149        w0,h0,w1,h1,w2,h2,rotation = self.get_geometry()
150        th = int(2*self.th1+self.th2)
151        w = w2 + th
152        h = h2 + th
153
154        if cell_area and w > 0 and h > 0:
155            x = self.get_property('xalign') * \
156                (cell_area.width - w - self.get_property('xpad'))
157            y = self.get_property('yalign') * \
158                (cell_area.height - h - self.get_property('ypad'))
159        w += 2 * self.get_property('xpad')
160        h += 2 * self.get_property('ypad')
161        return int(x), int(y), w, h
162
163
Note: See TracBrowser for help on using the repository browser.