Branch data Line data Source code
1 : : /*************************************************************************** 2 : : qgsspeedstrategy.h 3 : : -------------------------------------- 4 : : Date : 2011-04-01 5 : : Copyright : (C) 2010 by Yakushev Sergey 6 : : Email : YakushevS <at> list.ru 7 : : **************************************************************************** 8 : : * * 9 : : * This program is free software; you can redistribute it and/or modify * 10 : : * it under the terms of the GNU General Public License as published by * 11 : : * the Free Software Foundation; either version 2 of the License, or * 12 : : * (at your option) any later version. * 13 : : * * 14 : : ***************************************************************************/ 15 : : 16 : : #include "qgsnetworkspeedstrategy.h" 17 : : 18 : 0 : QgsNetworkSpeedStrategy::QgsNetworkSpeedStrategy( int attributeId, double defaultValue, double toMetricFactor ) 19 : 0 : { 20 : 0 : mAttributeId = attributeId; 21 : 0 : mDefaultValue = defaultValue; 22 : 0 : mToMetricFactor = toMetricFactor; 23 : 0 : } 24 : : 25 : 0 : QVariant QgsNetworkSpeedStrategy::cost( double distance, const QgsFeature &f ) const 26 : : { 27 : 0 : QgsAttributes attrs = f.attributes(); 28 : : 29 : 0 : if ( mAttributeId < 0 || mAttributeId >= attrs.count() ) 30 : 0 : return QVariant( distance / ( mDefaultValue * mToMetricFactor ) ); 31 : : 32 : 0 : double val = distance / ( attrs.at( mAttributeId ).toDouble() * mToMetricFactor ); 33 : 0 : if ( val <= 0.0 ) 34 : 0 : return QVariant( distance / ( mDefaultValue / mToMetricFactor ) ); 35 : : 36 : 0 : return QVariant( val ); 37 : 0 : } 38 : : 39 : 0 : QSet<int> QgsNetworkSpeedStrategy::requiredAttributes() const 40 : : { 41 : 0 : QSet< int > l; 42 : 0 : l.insert( mAttributeId ); 43 : 0 : return l; 44 : 0 : }