%PDF- %PDF-
Direktori : /lib/python3/dist-packages/orca/ |
Current File : //lib/python3/dist-packages/orca/brlmon.py |
# -*- coding: utf-8 -*- # Orca # # Copyright 2006-2008 Sun Microsystems Inc. # Copyright 2011 The Orca Team. # # This library is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public # License as published by the Free Software Foundation; either # version 2.1 of the License, or (at your option) any later version. # # This library 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 # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public # License along with this library; if not, write to the # Free Software Foundation, Inc., Franklin Street, Fifth Floor, # Boston MA 02110-1301 USA. """Provides a graphical braille display, mainly for development tasks.""" __id__ = "$Id$" __version__ = "$Revision$" __date__ = "$Date$" __copyright__ = "Copyright (c) 2005-2008 Sun Microsystems Inc." \ "Copyright (c) 2011 The Orca Team." __license__ = "LGPL" import brlapi from gi.repository import Gtk from . import script_manager from .input_event import BrailleEvent # Attribute/Selection mask strings: # DOT_7 = '\x40' # 01000000 DOT_8 = '\x80' # 10000000 DOTS_78 = '\xc0' # 11000000 class BrlDot(Gtk.Alignment): """A single braille dot.""" MARKUP_NORMAL = '<tt><small>%s</small></tt>' SYMBOL_LOWERED = '\u25CB' # '○' SYMBOL_RAISED = '\u25CF' # '●' def __init__(self, dotNumber, isRaised=False): """Create a new BrlDot. Arguments: - dotNumber: an integer reflecting the location of the dot within an 8-dot braille cell, using traditional braille dot values. """ super().__init__() if dotNumber in [1, 2, 3, 7]: self.set(1.0, 0.5, 0.0, 0.0) self.set_padding(3, 0, 0, 3) else: self.set(0.0, 0.5, 0.0, 0.0) self.set_padding(3, 0, 3, 0) self.label = Gtk.Label() self.add(self.label) if isRaised: self.raiseDot() else: self.lowerDot() def raiseDot(self): self.set(0.5, 0.5, 0, 0) self.label.set_markup(self.MARKUP_NORMAL % self.SYMBOL_RAISED) def lowerDot(self): self.set(0.5, 0.5, 0, 0) self.label.set_markup(self.MARKUP_NORMAL % self.SYMBOL_LOWERED) class BrlCell(Gtk.Button): """A single graphical braille cell with cursor routing capability.""" MARKUP_NORMAL = '<tt><big>%s</big></tt>' MARKUP_CURSOR_CELL = '<b><u>%s</u></b>' def __init__(self, position): """Create a new BrlCell. Arguments: - position: The location of the cell with respect to the monitor. """ Gtk.Button.__init__(self) self.set_size_request(30, 45) self._position = position self._displayedChar = Gtk.Label() self._dot7 = BrlDot(7) self._dot8 = BrlDot(8) grid = Gtk.Grid() grid.attach(self._displayedChar, 0, 0, 2, 3) grid.attach(self._dot7, 0, 3, 1, 1) grid.attach(self._dot8, 1, 3, 1, 1) self.add(grid) self.connect("clicked", self._onCellClicked) def _onCellClicked(self, widget): """Callback for the 'clicked' signal on the push button. Synthesizes a fake brlapi command to route the cursor to the current cell, similar to what occurs when a user presses the cursor routing key on his/her hardware braille display.""" script = script_manager.getManager().getActiveScript() if script is None: return fakeKeyPress = {} fakeKeyPress['command'] = brlapi.KEY_CMD_ROUTE fakeKeyPress['argument'] = self._position event = BrailleEvent(fakeKeyPress) script.processRoutingKey(event) def clear(self): """Clears the braille cell.""" self._displayedChar.set_markup("") self._dot7.lowerDot() self._dot8.lowerDot() def display(self, char, mask=None, isCursorCell=False): """Displays the specified character in the cell. Arguments: - char: The character to display in the cell. - isCursorCell: If True, the cursor/caret is at this cell and this should be indicated visually. """ if char == '&': char = '&' elif char == '<': char = '<' elif char == '\t': char = '$t' markup = self.MARKUP_NORMAL if isCursorCell: markup = markup % self.MARKUP_CURSOR_CELL self._displayedChar.set_markup(markup % char) if mask in [DOT_7, DOTS_78]: self._dot7.raiseDot() if mask in [DOT_8, DOTS_78]: self._dot8.raiseDot() class BrlMon(Gtk.Window): """Displays a GUI braille monitor that mirrors what would be displayed by Orca on a connected, configured, and enabled braille display. Cursor routing functionality is emulated by each cell being a push button. Panning and other functionality found on hardware braille displays will be added.""" def __init__(self, numCells=32): """Create a new BrlMon. Arguments: - numCells: how many braille cells to make """ super().__init__() self.set_title("Braille Monitor") grid = Gtk.Grid() self.add(grid) self.cells = [] for i in range(numCells): cell = BrlCell(i) grid.attach(cell, i, 0, 1, 1) self.cells.append(cell) self.set_resizable(False) self.set_property("accept-focus", False) self.set_skip_taskbar_hint(True) self.set_skip_pager_hint(True) def clear(self): """Clears the braille monitor display.""" for cell in self.cells: cell.clear() def writeText(self, cursorCell, string, mask=None): """Display the given text and highlight the given cursor cell. A cursorCell of 0 means no cell has the cursor. Arguments: - cursorCell: 1-based index of cell with cursor - string: len must be <= num cells. """ self.clear() length = min(len(string), len(self.cells)) for i in range(length): isCursorCell = i == cursorCell - 1 try: cellMask = mask[i] except (IndexError, TypeError): cellMask = None self.cells[i].display(string[i], cellMask, isCursorCell)