mirror of
https://github.com/OpenFOAM/ThirdParty-6.git
synced 2025-12-08 06:57:43 +00:00
ParaView-5.0.1: Added the source-tree to ThirdParty-dev and patched as described in the README file
Resolves bug-report http://bugs.openfoam.org/view.php?id=2098
This commit is contained in:
@ -0,0 +1,98 @@
|
||||
/*=========================================================================
|
||||
|
||||
Program: ParaView
|
||||
Module: pqDataTimeStepBehavior.cxx
|
||||
|
||||
Copyright (c) 2005,2006 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.
|
||||
|
||||
========================================================================*/
|
||||
#include "pqDataTimeStepBehavior.h"
|
||||
|
||||
#include "pqAnimationScene.h"
|
||||
#include "pqApplicationCore.h"
|
||||
#include "pqObjectBuilder.h"
|
||||
#include "pqPipelineSource.h"
|
||||
#include "pqScalarsToColors.h"
|
||||
#include "pqServer.h"
|
||||
#include "pqServerManagerModel.h"
|
||||
#include "pqTimeKeeper.h"
|
||||
#include "vtkPVGeneralSettings.h"
|
||||
#include "vtkSMPropertyHelper.h"
|
||||
#include "vtkSMProxy.h"
|
||||
#include "vtkSMSettings.h"
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
pqDataTimeStepBehavior::pqDataTimeStepBehavior(QObject* parentObject)
|
||||
: Superclass(parentObject)
|
||||
{
|
||||
QObject::connect(pqApplicationCore::instance()->getObjectBuilder(),
|
||||
SIGNAL(readerCreated(pqPipelineSource*, const QStringList&)),
|
||||
this, SLOT(onReaderCreated(pqPipelineSource*)),
|
||||
Qt::QueuedConnection);
|
||||
}
|
||||
|
||||
//-----------------------------------------------------------------------------
|
||||
void pqDataTimeStepBehavior::onReaderCreated(pqPipelineSource* reader)
|
||||
{
|
||||
vtkSMSettings* settings = vtkSMSettings::GetInstance();
|
||||
int defaultTimeStep = settings->GetSettingAsInt(
|
||||
".settings.GeneralSettings.DefaultTimeStep",
|
||||
vtkPVGeneralSettings::DEFAULT_TIME_STEP_UNCHANGED);
|
||||
if (defaultTimeStep == vtkPVGeneralSettings::DEFAULT_TIME_STEP_UNCHANGED)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
pqAnimationScene* scene =
|
||||
pqApplicationCore::instance()->getServerManagerModel()->
|
||||
findItems<pqAnimationScene*>(reader->getServer())[0];
|
||||
vtkSMProxy* readerProxy = reader->getProxy();
|
||||
if (readerProxy->GetProperty("TimestepValues"))
|
||||
{
|
||||
vtkSMPropertyHelper helper(readerProxy, "TimestepValues");
|
||||
unsigned int num_timesteps = helper.GetNumberOfElements();
|
||||
if (num_timesteps > 0)
|
||||
{
|
||||
std::vector<double> timesteps = helper.GetDoubleArray();
|
||||
unsigned int newTimeStep =
|
||||
(defaultTimeStep == vtkPVGeneralSettings::DEFAULT_TIME_STEP_FIRST) ? 0 :
|
||||
(num_timesteps - 1);
|
||||
scene->setAnimationTime(timesteps[newTimeStep]);
|
||||
}
|
||||
}
|
||||
else if (readerProxy->GetProperty("TimeRange"))
|
||||
{
|
||||
vtkSMPropertyHelper helper(readerProxy, "TimeRange");
|
||||
std::vector<double> timeRange = helper.GetDoubleArray();
|
||||
if (timeRange.size() > 0)
|
||||
{
|
||||
double newTime =
|
||||
(defaultTimeStep == vtkPVGeneralSettings::DEFAULT_TIME_STEP_FIRST) ?
|
||||
timeRange[0] : timeRange[1];
|
||||
scene->setAnimationTime(newTime);
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user