|
Focus Scopes are an additional focus paradigm, designed to be more
suitable for use by declarative UI.
With focus scopes, graphics view continues to have a single focused item -
this is the single item to which key events are *actually* delivered. To
simplify the description that follows, we will say that this element has
"global focus".
Focus scopes partitions focus into a heirarchy. Each focus scope may have one
sub-focused item, which may itself be another focus scope. The sub-focused item
is said to be have "scope focus" or its ancestor focus scope. Consequently,
any given QGraphicsItem may be globally focused, scope focused (which means it
is focused within its ancestor focus scope) or both.
A focus scope corresponds to a QGraphicsItem with the ItemIsFocusScope flag set.
As graphics view doesn't have a single root item, a "virtual" focus scope is
modeled as being the ancestor of all the root items.
With focus scopes, when QGraphicsItem::setFocus() is called, the item's
ancestors are searched until a focus scope is found (remembering the "virtual"
root focus scope is used if there is no *actual* ancestor scope). The item is
set as the sub-focused item of the focus scope (becoming focus scoped) and any
existing sub-focused item of that focus scope has scope focus removed from it.
The item that receives global focus is found by beginning at the "virtual"
root focus scope and recursively decending into each item that is scope focused
until a leaf (non-focus scope) item is reached. The implementation takes
shortcuts here to be slightly more optimal, but the end result should be the
same as though this abstract algorithm was evaluated each time.
Two manual examples of focus scope are found under examples/declarative/focusscope
|