src/3rdparty/phonon/mmf/ancestormovemonitor.h
changeset 3 41300fa6a67c
child 7 3f74d0d4af4c
equal deleted inserted replaced
2:56cd8111b7f7 3:41300fa6a67c
       
     1 /*  This file is part of the KDE project.
       
     2 
       
     3 Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
       
     4 
       
     5 This library is free software: you can redistribute it and/or modify
       
     6 it under the terms of the GNU Lesser General Public License as published by
       
     7 the Free Software Foundation, either version 2.1 or 3 of the License.
       
     8 
       
     9 This library is distributed in the hope that it will be useful,
       
    10 but WITHOUT ANY WARRANTY; without even the implied warranty of
       
    11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
       
    12 GNU Lesser General Public License for more details.
       
    13 
       
    14 You should have received a copy of the GNU Lesser General Public License
       
    15 along with this library.  If not, see <http://www.gnu.org/licenses/>.
       
    16 
       
    17 */
       
    18 
       
    19 #ifndef PHONON_MMF_ANCESTORMOVEMONITOR_H
       
    20 #define PHONON_MMF_ANCESTORMOVEMONITOR_H
       
    21 
       
    22 #include <QObject>
       
    23 #include <QHash>
       
    24 #include <QList>
       
    25 
       
    26 QT_BEGIN_NAMESPACE
       
    27 
       
    28 namespace Phonon
       
    29 {
       
    30 namespace MMF
       
    31 {
       
    32 class VideoOutput;
       
    33 
       
    34 class AncestorMoveMonitor : public QObject
       
    35 {
       
    36     Q_OBJECT
       
    37 
       
    38 public:
       
    39     explicit AncestorMoveMonitor(QObject *parent);
       
    40     ~AncestorMoveMonitor();
       
    41 
       
    42     /**
       
    43      * Register target widget for notification.
       
    44      *
       
    45      * The widget receives an ancestorMoveEvent callback when a move event
       
    46      * is delivered to any of its ancestors:
       
    47      *
       
    48      * If the target is already registered, this function causes its
       
    49      * ancestor list to be updated - therefore it should be called when
       
    50      * the target receives a ParentChange event.
       
    51      */
       
    52     void registerTarget(VideoOutput *target);
       
    53 
       
    54     /**
       
    55      * Remove target from the monitor.
       
    56      *
       
    57      * The target will no longer receive notification when move events are
       
    58      * delivered to its ancestors.
       
    59      */
       
    60     void unRegisterTarget(VideoOutput *target);
       
    61 
       
    62 protected:
       
    63     /**
       
    64      * Function which receives events from the global event filter.
       
    65      */
       
    66     bool eventFilter(QObject *watched, QEvent *event);
       
    67 
       
    68     void dump();
       
    69 
       
    70 private:
       
    71     /**
       
    72      * List of registered target widgets which descend from a given
       
    73      * ancestor.
       
    74      *
       
    75      * Note that the members of the list should be non-redundant; this
       
    76      * invariant is checked in debug builds.  Semantically, the value is
       
    77      * therefore a set, however we use QList rather than QSet for
       
    78      * efficiency of iteration.
       
    79      */
       
    80     typedef QList<VideoOutput *> TargetList;
       
    81 
       
    82     /**
       
    83      * Map from widget on which the move event occurs, to widgets which
       
    84      * descend from it and therefore need to be notified.
       
    85      */
       
    86     typedef QHash<QObject *, TargetList> Hash;
       
    87     Hash m_hash;
       
    88 
       
    89 };
       
    90 }
       
    91 }
       
    92 
       
    93 QT_END_NAMESPACE
       
    94 
       
    95 #endif