Allowed slide contrllers to be passed to the plugins. It's broken at

the moment though!

bzr-revno: 331
This commit is contained in:
Martin Thompson 2009-02-20 21:13:04 +00:00
parent d1a6cc585b
commit ad48e1f4e6
6 changed files with 52 additions and 15 deletions

View File

@ -17,6 +17,7 @@ You should have received a copy of the GNU General Public License along with
this program; if not, write to the Free Software Foundation, Inc., 59 Temple this program; if not, write to the Free Software Foundation, Inc., 59 Temple
Place, Suite 330, Boston, MA 02111-1307 USA Place, Suite 330, Boston, MA 02111-1307 USA
""" """
from PyQt4 import QtCore, QtGui
class ImageServiceItem(): class ImageServiceItem():
""" """
@ -24,11 +25,23 @@ class ImageServiceItem():
the service manager, the slide controller, and the renderer. the service manager, the slide controller, and the renderer.
""" """
def __init__(self): def __init__(self, controller):
""" """
Init Method Init Method
""" """
self.imgs=[] self.imgs=[]
self.slide_controller=controller
self.slide_controller.ControllerContents=QtGui.QTableWidget()
c=self.slide_controller.ControllerContents
c.setColumnCount(2)
c.setColumnHidden(0, True)
c.setColumnWidth(1, 275)
c.setShowGrid(False)
c.setSortingEnabled(False)
c.setAlternatingRowColors(True)
c.setHorizontalHeaderLabels(QtCore.QStringList(["","Name"]))
c.setAlternatingRowColors(True)
c.setGeometry(QtCore.QRect(10, 100, 256, 591))
pass pass
def render(self): def render(self):
@ -36,7 +49,16 @@ class ImageServiceItem():
The render method is what the plugin uses to render its meda to the The render method is what the plugin uses to render its meda to the
screen. screen.
""" """
pass # render the "image chooser first"
for f in self.imgs:
fl , nm = os.path.split(str(f))
c = self.slide_controller.rowCount()
self.slide_controller.setRowCount(c+1)
twi = QtGui.QTableWidgetItem(str(f))
self.slide_controller.setItem(c , 0, twi)
twi = QtGui.QTableWidgetItem(str(nm))
self.slide_controller.setItem(c , 1, twi)
self.slide_controller.setRowHeight(c, 20)
def get_parent_node(self): def get_parent_node(self):
""" """

View File

@ -67,7 +67,7 @@ class Plugin(object):
and screen number. and screen number.
""" """
def __init__(self, name=None, version=None): def __init__(self, name=None, version=None, preview_controller=None, live_controller=None):
""" """
This is the constructor for the plugin object. This provides an easy This is the constructor for the plugin object. This provides an easy
way for descendent plugins to populate common data. This method *must* way for descendent plugins to populate common data. This method *must*
@ -89,7 +89,8 @@ class Plugin(object):
# Set up logging # Set up logging
self.log = logging.getLogger(self.name) self.log = logging.getLogger(self.name)
self.repaint_main_window = None self.repaint_main_window = None
self.preview_controller=preview_controller
self.live_controller=live_controller
def check_pre_conditions(self): def check_pre_conditions(self):
""" """
Provides the Plugin with a handle to check if it can be loaded. Provides the Plugin with a handle to check if it can be loaded.

View File

@ -35,7 +35,8 @@ class PluginManager(object):
def __init__(self, dir): def __init__(self, dir):
""" """
The constructor for the plugin manager. This does a, b and c. The constructor for the plugin manager.
Passes the controllers on to the plugins for them to interact with via their ServiceItems
""" """
log.info("Plugin manager initing") log.info("Plugin manager initing")
if not dir in sys.path: if not dir in sys.path:
@ -44,13 +45,14 @@ class PluginManager(object):
self.basepath = os.path.abspath(dir) self.basepath = os.path.abspath(dir)
log.debug("Base path %s ", self.basepath) log.debug("Base path %s ", self.basepath)
self.plugins = [] self.plugins = []
self.find_plugins(dir) # this has to happen after the UI is sroted self.find_plugins(dir)
log.info("Plugin manager done init") log.info("Plugin manager done init")
def find_plugins(self, dir, preview_controller, live_controller): # xxx shouldn't dir come from self.basepath
def find_plugins(self, dir):
""" """
Scan the directory dir for objects inheriting from openlp.plugin Scan the directory dir for objects inheriting from openlp.plugin
""" """
self.preview_controller=preview_controller
self.live_controller=live_controller
startdepth=len(os.path.abspath(dir).split(os.sep)) startdepth=len(os.path.abspath(dir).split(os.sep))
log.debug("find plugins %s at depth %d" %( str(dir), startdepth)) log.debug("find plugins %s at depth %d" %( str(dir), startdepth))
@ -76,7 +78,12 @@ class PluginManager(object):
self.plugins = [] self.plugins = []
plugin_objects = [] plugin_objects = []
for p in self.plugin_classes: for p in self.plugin_classes:
try:
plugin = p(self.preview_controller, self.live_controller)
log.debug('loaded plugin' + str(p) + ' with controllers'+str(self.preview_controller)+str(self.live_controller))
except TypeError: # xxx need to get rid of this once all plugins are up to date
plugin = p() plugin = p()
log.debug('loaded plugin' + str(p) + ' with no controllers')
if plugin.check_pre_conditions(): if plugin.check_pre_conditions():
plugin_objects.append(plugin) plugin_objects.append(plugin)
self.plugins = sorted(plugin_objects, self.order_by_weight) self.plugins = sorted(plugin_objects, self.order_by_weight)

View File

@ -40,6 +40,12 @@ class MainWindow(object):
pluginpath = os.path.abspath(os.path.join(pluginpath, '..', '..','plugins')) pluginpath = os.path.abspath(os.path.join(pluginpath, '..', '..','plugins'))
self.plugin_manager = PluginManager(pluginpath) self.plugin_manager = PluginManager(pluginpath)
self.setupUi() self.setupUi()
self.plugin_manager.find_plugins(pluginpath, self.PreviewController, self.LiveController)
self.receiver = Receiver()
QtCore.QObject.connect(self.receiver.get_receiver(),QtCore.SIGNAL("openlprepaint"),self.repaint)
def repaint(self):
self.main_window.repaint()
def setupUi(self): def setupUi(self):
self.main_window.setObjectName("main_window") self.main_window.setObjectName("main_window")

View File

@ -21,8 +21,9 @@ import os
from time import sleep from time import sleep
from PyQt4 import QtCore, QtGui from PyQt4 import QtCore, QtGui
class SlideController(QtCore.QObject): class SlideController(QtGui.QWidget):
def __init__(self, control_splitter): def __init__(self, control_splitter):
QtGui.QWidget.__init__(self)
self.Pane = QtGui.QWidget(control_splitter) self.Pane = QtGui.QWidget(control_splitter)
self.Splitter = QtGui.QSplitter(self.Pane) self.Splitter = QtGui.QSplitter(self.Pane)
self.Splitter.setOrientation(QtCore.Qt.Vertical) self.Splitter.setOrientation(QtCore.Qt.Vertical)

View File

@ -24,17 +24,17 @@ from openlp.core.lib import Plugin, PluginUtils, MediaManagerItem, ImageServiceI
#from forms import EditSongForm #from forms import EditSongForm
class ImagePlugin(Plugin, PluginUtils): class ImagePlugin(Plugin, PluginUtils):
def __init__(self): def __init__(self, preview_controller, live_controller):
# Call the parent constructor # Call the parent constructor
Plugin.__init__(self, 'Images', '1.9.0') Plugin.__init__(self, 'Images', '1.9.0', preview_controller, live_controller)
self.weight = -7 self.weight = -7
# Create the plugin icon # Create the plugin icon
self.icon = QtGui.QIcon() self.icon = QtGui.QIcon()
self.icon.addPixmap(QtGui.QPixmap(':/media/media_image.png'), self.icon.addPixmap(QtGui.QPixmap(':/media/media_image.png'),
QtGui.QIcon.Normal, QtGui.QIcon.Off) QtGui.QIcon.Normal, QtGui.QIcon.Off)
self.preview_service_item=ImageServiceItem() self.preview_service_item=ImageServiceItem(preview_controller)
self.live_service_item=ImageServiceItem() self.live_service_item=ImageServiceItem(live_controller)
def get_media_manager_item(self): def get_media_manager_item(self):
# Create the MediaManagerItem object # Create the MediaManagerItem object