openlp/openlp/core/lib/screen.py

263 lines
10 KiB
Python
Raw Normal View History

# -*- coding: utf-8 -*-
2012-12-29 13:35:16 +00:00
# vim: autoindent shiftwidth=4 expandtab textwidth=120 tabstop=4 softtabstop=4
###############################################################################
# OpenLP - Open Source Lyrics Projection #
# --------------------------------------------------------------------------- #
2012-12-29 20:56:56 +00:00
# Copyright (c) 2008-2013 Raoul Snyman #
# Portions copyright (c) 2008-2013 Tim Bentley, Gerald Britton, Jonathan #
# Corwin, Samuel Findlay, Michael Gorven, Scott Guerrieri, Matthias Hub, #
2012-11-11 21:16:14 +00:00
# Meinert Jordan, Armin Köhler, Erik Lundin, Edwin Lunando, Brian T. Meyer. #
2012-10-21 13:16:22 +00:00
# Joshua Miller, Stevan Pettit, Andreas Preikschat, Mattias Põldaru, #
# Christian Richter, Philip Ridout, Simon Scudder, Jeffrey Smith, #
# Maikel Stuivenberg, Martin Thompson, Jon Tibble, Dave Warnock, #
# Frode Woldsund, Martin Zibricky, Patrick Zimmermann #
# --------------------------------------------------------------------------- #
# This program is free software; you can redistribute it and/or modify it #
# under the terms of the GNU General Public License as published by the Free #
# Software Foundation; version 2 of the License. #
# #
# This program is distributed in the hope that it will be useful, but WITHOUT #
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or #
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for #
# more details. #
# #
# 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 Place, Suite 330, Boston, MA 02111-1307 USA #
###############################################################################
2010-06-10 21:30:50 +00:00
"""
The :mod:`screen` module provides management functionality for a machines'
2011-02-26 21:43:41 +00:00
displays.
2010-06-10 21:30:50 +00:00
"""
import logging
2010-04-24 19:57:29 +00:00
import copy
2011-03-01 17:16:59 +00:00
from PyQt4 import QtCore
from openlp.core.lib import Receiver, translate
2011-03-01 17:16:59 +00:00
2013-01-11 19:36:28 +00:00
2010-02-27 15:31:23 +00:00
log = logging.getLogger(__name__)
2013-01-11 19:36:28 +00:00
2010-01-22 18:59:36 +00:00
class ScreenList(object):
"""
Wrapper to handle the parameters of the display screen.
To get access to the screen list call ``ScreenList()``.
"""
log.info(u'Screen loaded')
__instance__ = None
def __new__(cls):
if not cls.__instance__:
cls.__instance__ = object.__new__(cls)
return cls.__instance__
@classmethod
def create(cls, desktop):
2011-03-01 17:16:59 +00:00
"""
2011-03-02 17:56:06 +00:00
Initialise the screen list.
``desktop``
A ``QDesktopWidget`` object.
2011-03-01 17:16:59 +00:00
"""
screen_list = cls()
screen_list.desktop = desktop
screen_list.preview = None
screen_list.current = None
screen_list.override = None
screen_list.screen_list = []
screen_list.display_count = 0
screen_list.screen_count_changed()
screen_list._load_screen_settings()
2012-12-29 13:35:16 +00:00
QtCore.QObject.connect(desktop, QtCore.SIGNAL(u'resized(int)'), screen_list.screen_resolution_changed)
QtCore.QObject.connect(desktop, QtCore.SIGNAL(u'screenCountChanged(int)'), screen_list.screen_count_changed)
return screen_list
def screen_resolution_changed(self, number):
2010-06-10 21:30:50 +00:00
"""
2011-03-01 17:16:59 +00:00
Called when the resolution of a screen has changed.
2011-02-26 21:43:41 +00:00
2011-03-01 17:16:59 +00:00
``number``
The number of the screen, which size has changed.
"""
2011-06-01 06:31:22 +00:00
log.info(u'screen_resolution_changed %d' % number)
2011-03-01 17:16:59 +00:00
for screen in self.screen_list:
if number == screen[u'number']:
newScreen = {
u'number': number,
u'size': self.desktop.screenGeometry(number),
2011-03-02 17:58:17 +00:00
u'primary': self.desktop.primaryScreen() == number
2011-03-01 17:16:59 +00:00
}
self.remove_screen(number)
self.add_screen(newScreen)
# The screen's default size is used, that is why we have to
# update the override screen.
if screen == self.override:
self.override = copy.deepcopy(newScreen)
self.set_override_display()
Receiver.send_message(u'config_screen_changed')
break
2011-02-26 21:43:41 +00:00
def screen_count_changed(self, changed_screen=-1):
2010-06-10 21:30:50 +00:00
"""
2011-03-01 17:16:59 +00:00
Called when a screen has been added or removed.
``changed_screen``
2011-03-01 17:16:59 +00:00
The screen's number which has been (un)plugged.
"""
2011-06-01 06:31:22 +00:00
# Do not log at start up.
if changed_screen != -1:
log.info(u'screen_count_changed %d' % self.desktop.screenCount())
2011-03-01 17:16:59 +00:00
# Remove unplugged screens.
for screen in copy.deepcopy(self.screen_list):
if screen[u'number'] == self.desktop.screenCount():
2011-03-01 17:16:59 +00:00
self.remove_screen(screen[u'number'])
# Add new screens.
for number in xrange(self.desktop.screenCount()):
2011-03-01 17:16:59 +00:00
if not self.screen_exists(number):
self.add_screen({
u'number': number,
u'size': self.desktop.screenGeometry(number),
u'primary': (self.desktop.primaryScreen() == number)
})
2011-06-01 06:31:22 +00:00
# We do not want to send this message at start up.
if changed_screen != -1:
2011-03-01 17:16:59 +00:00
# Reload setting tabs to apply possible changes.
Receiver.send_message(u'config_screen_changed')
def get_screen_list(self):
"""
Returns a list with the screens. This should only be used to display
available screens to the user::
2011-03-02 18:07:07 +00:00
[u'Screen 1 (primary)', u'Screen 2']
"""
2011-03-04 14:44:21 +00:00
screen_list = []
for screen in self.screen_list:
screen_name = u'%s %d' % (translate('OpenLP.ScreenList', 'Screen'),
screen[u'number'] + 1)
if screen[u'primary']:
2012-12-29 13:35:16 +00:00
screen_name = u'%s (%s)' % (screen_name, translate('OpenLP.ScreenList', 'primary'))
screen_list.append(screen_name)
return screen_list
2011-03-01 17:16:59 +00:00
def add_screen(self, screen):
"""
Add a screen to the list of known screens.
``screen``
A dict with the screen properties::
2011-02-27 16:27:45 +00:00
{
u'primary': True,
u'number': 0,
u'size': PyQt4.QtCore.QRect(0, 0, 1024, 768)
}
"""
2012-12-29 13:35:16 +00:00
log.info(u'Screen %d found with resolution %s', screen[u'number'], screen[u'size'])
2011-03-01 17:16:59 +00:00
if screen[u'primary']:
self.current = screen
self.override = copy.deepcopy(self.current)
2011-03-01 17:16:59 +00:00
self.screen_list.append(screen)
self.display_count += 1
2011-02-26 21:43:41 +00:00
def remove_screen(self, number):
"""
Remove a screen from the list of known screens.
``number``
The screen number (int).
"""
log.info(u'remove_screen %d' % number)
2011-02-26 21:43:41 +00:00
for screen in self.screen_list:
if screen[u'number'] == number:
self.screen_list.remove(screen)
self.display_count -= 1
break
def screen_exists(self, number):
2010-06-10 21:30:50 +00:00
"""
2011-02-26 21:43:41 +00:00
Confirms a screen is known.
``number``
The screen number (int).
2010-06-10 21:30:50 +00:00
"""
for screen in self.screen_list:
if screen[u'number'] == number:
return True
return False
def set_current_display(self, number):
2010-04-02 18:12:54 +00:00
"""
2011-02-26 21:43:41 +00:00
Set up the current screen dimensions.
``number``
The screen number (int).
2010-04-02 18:12:54 +00:00
"""
2011-02-16 03:28:06 +00:00
log.debug(u'set_current_display %s', number)
2010-04-02 18:12:54 +00:00
if number + 1 > self.display_count:
self.current = self.screen_list[0]
else:
self.current = self.screen_list[number]
2010-04-24 19:57:29 +00:00
self.preview = copy.deepcopy(self.current)
self.override = copy.deepcopy(self.current)
2010-04-02 18:12:54 +00:00
if self.display_count == 1:
self.preview = self.screen_list[0]
def set_override_display(self):
"""
2011-02-26 21:43:41 +00:00
Replace the current size with the override values, as the user wants to
have their own screen attributes.
"""
2010-04-24 19:57:29 +00:00
log.debug(u'set_override_display')
self.current = copy.deepcopy(self.override)
self.preview = copy.deepcopy(self.current)
2010-04-24 19:57:29 +00:00
def reset_current_display(self):
"""
2011-02-26 21:43:41 +00:00
Replace the current values with the correct values, as the user wants to
use the correct screen attributes.
"""
2010-04-24 19:57:29 +00:00
log.debug(u'reset_current_display')
self.set_current_display(self.current[u'number'])
def which_screen(self, window):
"""
2011-12-23 21:52:54 +00:00
Return the screen number that the centre of the passed window is in.
``window``
A QWidget we are finding the location of.
"""
x = window.x() + (window.width() / 2)
y = window.y() + (window.height() / 2)
for screen in self.screen_list:
size = screen[u'size']
if x >= size.x() and x <= (size.x() + size.width()) and \
y >= size.y() and y <= (size.y() + size.height()):
return screen[u'number']
def _load_screen_settings(self):
"""
Loads the screen size and the monitor number from the settings.
"""
from openlp.core.lib import Settings
2012-05-17 15:13:09 +00:00
settings = Settings()
settings.beginGroup(u'general')
self.set_current_display(settings.value(u'monitor'))
self.display = settings.value(u'display on monitor')
override_display = settings.value(u'override position')
x = settings.value(u'x position')
y = settings.value(u'y position')
width = settings.value(u'width')
height = settings.value(u'height')
self.override[u'size'] = QtCore.QRect(x, y, width, height)
2011-06-01 07:38:19 +00:00
self.override[u'primary'] = False
settings.endGroup()
if override_display:
self.set_override_display()
else:
self.reset_current_display()