/usr/share/pyshared/libqtopensesame/items/feedpad.py is in opensesame 0.27.4-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 | #-*- coding:utf-8 -*-
"""
This file is part of OpenSesame.
OpenSesame 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, either version 3 of the License, or
(at your option) any later version.
OpenSesame 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 OpenSesame. If not, see <http://www.gnu.org/licenses/>.
"""
from libopensesame import debug
from libqtopensesame.dialogs import sketchpad_dialog
from libqtopensesame.items import qtitem
from libqtopensesame.misc import _
class feedpad:
"""GUI controls that are common to the sketchpad and the feedback item"""
def popout(self):
"""Open a new window for the drawing tool"""
a = sketchpad_dialog.sketchpad_dialog( \
self.experiment.ui.centralwidget, self);
a.exec_()
self.apply_edit_changes()
def static_items(self):
"""
Returns a list of items which are 'static' in the sense that they don't
contain variables that make it hard to draw them onto a sketchpad.
Variables in text and show_if properties are allowed.
Returns:
A list of static items
"""
l = []
for item in self.items:
static = True
for var in item:
if var != "text" and var != "show_if" and type(item[var]) == \
unicode and item[var].find("[") >= 0:
debug.msg("variable property: %s = %s" % (var, item[var]))
static = False
if static:
l.append(item)
return l
def items_out_of_bounds(self):
"""
Returns a count of items that are 'out of bounds' in the sense that the
coordinates fall outside of the screen boundaries.
Returns:
The nr of items the are out of bounds
"""
xc = self.get("width")/2
yc = self.get("height")/2
return sum( ["x" in i and "y" in i
and ( (type(i["x"]) not in (str, unicode) and abs(i["x"]) > xc)
or (type(i["y"]) not in (str, unicode) and abs(i["y"]) > yc) )
for i in self.items] )
|