/usr/include/qgis/qgsscalewidget.h is in libqgis-dev 2.18.17+dfsg-1.
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 77 78 79 80 81 82 83 84 85 86 87 88 89 | /***************************************************************************
qgsscalewidget.h
--------------------------------------
Date : 08.01.2015
Copyright : (C) 2014 Denis Rouzaud
Email : denis.rouzaud@gmail.com
***************************************************************************
* *
* This program 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 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
#ifndef QGSSCALEWIDGET_H
#define QGSSCALEWIDGET_H
#include <QWidget>
#include <QToolButton>
#include "qgsscalecombobox.h"
class QgsMapCanvas;
/** \ingroup gui
* A combobox which lets the user select map scale from predefined list
* and highlights nearest to current scale value
**/
class GUI_EXPORT QgsScaleWidget : public QWidget
{
Q_OBJECT
Q_PROPERTY( bool showCurrentScaleButton READ showCurrentScaleButton WRITE setShowCurrentScaleButton )
Q_PROPERTY( bool scale READ scale WRITE setScale NOTIFY scaleChanged )
Q_PROPERTY( bool minScale READ minScale WRITE setMinScale )
public:
explicit QgsScaleWidget( QWidget *parent = nullptr );
virtual ~QgsScaleWidget();
//! shows a button to set the scale to the current scale of the map canvas next to the combobox
//! @note the map canvas must be defined to show the button
void setShowCurrentScaleButton( bool showCurrentScaleButton );
bool showCurrentScaleButton() { return mShowCurrentScaleButton;}
//! set the map canvas associated to the current button
void setMapCanvas( QgsMapCanvas* canvas );
//! Function to read the selected scale as text
QString scaleString() { return mScaleComboBox->scaleString(); }
//! Function to set the selected scale from text
bool setScaleString( const QString& scaleTxt ) { return mScaleComboBox->setScaleString( scaleTxt ); }
//! Function to read the selected scale as double
double scale() const { return mScaleComboBox->scale();}
//! Function to set the selected scale from double
void setScale( double scale );
//! Function to read the min scale
double minScale() const { return mScaleComboBox->minScale(); }
//! Helper function to convert a double to scale string
// Performs rounding, so an exact representation is not to
// be expected.
static QString toString( double scale ) { return QgsScaleComboBox::toString( scale ); }
//! Helper function to convert a scale string to double
static double toDouble( const QString& scaleString, bool *ok = nullptr ) { return QgsScaleComboBox::toDouble( scaleString, ok ); }
public slots:
void updateScales( const QStringList &scales = QStringList() ) { return mScaleComboBox->updateScales( scales ); }
//! assign the current scale from the map canvas
void setScaleFromCanvas();
//! Function to set the min scale
void setMinScale( double scale ) { mScaleComboBox->setMinScale( scale ); }
signals:
//! Signal is emitted when *user* has finished editing/selecting a new scale.
void scaleChanged( double scale );
private:
QgsScaleComboBox* mScaleComboBox;
QToolButton* mCurrentScaleButton;
QgsMapCanvas* mCanvas;
bool mShowCurrentScaleButton;
};
#endif // QGSSCALEWIDGET_H
|