/usr/include/paraview/pqDisplayPolicy.h is in paraview-dev 5.0.1+dfsg1-4.
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 90 91 92 93 94 95 96 97 | /*=========================================================================
Program: ParaView
Module: pqDisplayPolicy.h
Copyright (c) 2005-2008 Sandia Corporation, Kitware Inc.
All rights reserved.
ParaView is a free software; you can redistribute it and/or modify it
under the terms of the ParaView license version 1.2.
See License_v1.2.txt for the full ParaView license.
A copy of this license can be obtained by contacting
Kitware Inc.
28 Corporate Drive
Clifton Park, NY 12065
USA
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR
CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
=========================================================================*/
#ifndef pqDisplayPolicy_h
#define pqDisplayPolicy_h
#include <QObject>
#include "pqCoreModule.h" // Needed for PQCORE_EXPORT macro
class pqDataRepresentation;
class pqOutputPort;
class pqPipelineSource;
class pqView;
class vtkSMProxy;
/// Display policy defines the application specific policy
/// for creating display proxies. Given a pair of a proxy to be displayed
/// and a view proxy in which to display, this class must tell the type
/// of display to create, if any. Custom applications can subclass
/// this to define their own policy. The pqApplicationCore maintains
/// an instance of the policy used by the application. Custom applications
/// should set their own policy instance on the global application core
/// instance.
class PQCORE_EXPORT pqDisplayPolicy : public QObject
{
Q_OBJECT
typedef QObject Superclass;
public:
pqDisplayPolicy(QObject* p);
virtual ~pqDisplayPolicy();
/// Set the visibility of the source in the given view.
/// Current implementation creates a new display for the source, if possible,
/// if none exists. If view is NULL, then a new view of "suitable" type will
/// be created for the source. Since custom applications may not necessarily
/// create new views, we provide this as part of display policy which can
/// be easily overridden by creating a new subclass.
virtual pqDataRepresentation* setRepresentationVisibility(
pqOutputPort* opPort, pqView* view, bool visible) const;
/// Returns the type for the view that is indicated as the preferred view
/// for the given output port. May return a null string if the no view type
/// can be determined as the preferred view.
/// If update_pipeline is set, then the pipeline will be update prior to
/// fetching the data information from the port.
virtual QString getPreferredViewType(pqOutputPort* opPort, bool update_pipeline) const;
/// Apps can choose whether new filter outputs are hidden upon creation by
/// overriding this method. The default behavior is to create a representation
/// such that it obeys to the Visibility from rendering.xml.
virtual bool getHideByDefault() const {
return false;
}
enum VisibilityState
{
Visible,
Hidden,
NotApplicable
};
/// Returns the visibility state for port in the given view (view may be null
/// for an empty view).
virtual VisibilityState getVisibility(pqView* view, pqOutputPort* port) const;
private:
Q_DISABLE_COPY(pqDisplayPolicy);
};
#endif
|