Files
qt-creator/src/plugins/coreplugin/inavigationwidgetfactory.cpp

168 lines
4.7 KiB
C++
Raw Normal View History

/****************************************************************************
2008-12-02 12:01:29 +01:00
**
** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies).
** Copyright (c) 2014 Falko Arps
** Copyright (c) 2014 Sven Klein
** Copyright (c) 2014 Giuliano Schneider
** Contact: http://www.qt-project.org/legal
2008-12-02 12:01:29 +01:00
**
** This file is part of Qt Creator.
2008-12-02 12:01:29 +01:00
**
** Commercial License Usage
** Licensees holding valid commercial Qt licenses may use this file in
** accordance with the commercial license agreement provided with the
** Software or, alternatively, in accordance with the terms contained in
** a written agreement between you and Digia. For licensing terms and
** conditions see http://www.qt.io/licensing. For further information
** use the contact form at http://www.qt.io/contact-us.
**
** GNU Lesser General Public License Usage
** Alternatively, this file may be used under the terms of the GNU Lesser
** General Public License version 2.1 or version 3 as published by the Free
** Software Foundation and appearing in the file LICENSE.LGPLv21 and
** LICENSE.LGPLv3 included in the packaging of this file. Please review the
** following information to ensure the GNU Lesser General Public License
** requirements will be met: https://www.gnu.org/licenses/lgpl.html and
** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** In addition, as a special exception, Digia gives you certain additional
** rights. These rights are described in the Digia Qt LGPL Exception
2010-12-17 16:01:08 +01:00
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
**
****************************************************************************/
2008-12-02 14:09:21 +01:00
2008-12-02 12:01:29 +01:00
#include "inavigationwidgetfactory.h"
#include <QKeySequence>
/*!
\class Core::INavigationWidgetFactory
\mainclass
\inmodule Qt Creator
\brief The INavigationWidgetFactory class provides new instances of navigation widgets.
A navigation widget factory is necessary because there can be more than one navigation widget of
the same type at a time. Each navigation widget is wrapped in a \l{Core::NavigationView} for
delivery.
*/
/*!
\class Core::NavigationView
\inmodule Qt Creator
\brief The NavigationView class is a C struct for wrapping a widget and a list of tool buttons.
Wrapping the widget that is shown in the content area of the navigation widget and a list of
tool buttons that is shown in the header above it.
*/
/*!
\fn INavigationWidgetFactory::INavigationWidgetFactory()
Constructs a navigation widget factory.
*/
/*!
\fn QString INavigationWidgetFactory::displayName() const
Returns the display name of the navigation widget, which is shown in the dropdown menu above the
navigation widget.
*/
/*!
\fn int INavigationWidgetFactory::priority() const
Determines the position of the navigation widget in the dropdown menu.
0 to 1000 from top to bottom
*/
/*!
\fn Id INavigationWidgetFactory::id() const
Returns a unique identifier for referencing the navigation widget factory.
*/
/*!
\fn NavigationView INavigationWidgetFactory::createWidget()
Returns a \l{Core::NavigationView} containing the widget and the buttons. The ownership is given
to the caller.
*/
2008-12-02 12:01:29 +01:00
using namespace Core;
/*!
Creates a \l{Core::NavigationViewFactory}.
*/
INavigationWidgetFactory::INavigationWidgetFactory()
: m_priority(0)
{
}
/*!
Sets the display name for the factory.
\sa displayName()
*/
void INavigationWidgetFactory::setDisplayName(const QString &displayName)
{
m_displayName = displayName;
}
/*!
Sets the priority for the factory.
\sa priority()
*/
void INavigationWidgetFactory::setPriority(int priority)
{
m_priority = priority;
}
/*!
Sets the id for the factory.
\sa id()
*/
void INavigationWidgetFactory::setId(Id id)
{
m_id = id;
}
/*!
Sets the keyboard activation sequence for the factory.
\sa activationSequence()
*/
void INavigationWidgetFactory::setActivationSequence(const QKeySequence &keys)
{
m_activationSequence = keys;
}
/*!
Returns the keyboard shortcut to activate an instance of a navigation widget.
*/
QKeySequence INavigationWidgetFactory::activationSequence() const
2008-12-02 12:01:29 +01:00
{
return m_activationSequence;
2008-12-02 12:01:29 +01:00
}
/*!
Stores the settings for the \a widget at \a position that was created by this factory
(the \a position identifies a specific navigation widget).
\sa INavigationWidgetFactory::restoreSettings()
*/
2008-12-19 10:49:29 +01:00
void INavigationWidgetFactory::saveSettings(int /* position */, QWidget * /* widget */)
{
}
/*!
Reads and restores the settings for the \a widget at \a position that was created by this
factory (the \a position identifies a specific navigation widget).
\sa INavigationWidgetFactory::saveSettings()
*/
2008-12-19 10:49:29 +01:00
void INavigationWidgetFactory::restoreSettings(int /* position */, QWidget * /* widget */)
{
}