//
#include <HYDROData_StricklerTable.h>
+#include <HYDROData_Tool.h>
+#include <HYDROData_Iterator.h>
#include <TDataStd_NamedData.hxx>
IMPLEMENT_STANDARD_RTTIEXT( HYDROData_StricklerTable, HYDROData_Entity )
HYDROData_StricklerTable::HYDROData_StricklerTable()
+: HYDROData_Entity( Geom_No )
{
}
int aColorInt = aParts[1].toInt( 0, 16 );
QString anAttrValue = aParts.size()>2 ? aParts[2] : QString();
- TCollection_ExtendedString aTypeExt = toExtString( aType );
+ TCollection_ExtendedString aTypeExt = HYDROData_Tool::toExtString( aType );
aMap->SetReal( aTypeExt, aCoeff );
aMap->SetInteger( aTypeExt, aColorInt );
- aMap->SetString( aTypeExt, toExtString( anAttrValue ) );
+ aMap->SetString( aTypeExt, HYDROData_Tool::toExtString( anAttrValue ) );
}
i++;
}
QStringList aTypes = GetTypes();
foreach( QString aType, aTypes )
{
- TCollection_ExtendedString aTypeExt = toExtString( aType );
+ TCollection_ExtendedString aTypeExt = HYDROData_Tool::toExtString( aType );
aStream << "\"" << aType << "\" " << Get( aType, 0.0 );
QString aColor = QString::number( aMap->GetInteger( aTypeExt ), 16 ).toUpper();
aColor = QString( 6-aColor.length(), '0' ) + aColor;
- QString anAttrValue = toQString( aMap->GetString( aTypeExt ) );
+ QString anAttrValue = HYDROData_Tool::toQString( aMap->GetString( aTypeExt ) );
aStream << " " << aColor;
if( !anAttrValue.isEmpty() )
double HYDROData_StricklerTable::Get( const QString& theType, double theDefault ) const
{
Handle( TDataStd_NamedData ) aMap = Map();
- TCollection_ExtendedString aType = toExtString( theType );
+ TCollection_ExtendedString aType = HYDROData_Tool::toExtString( theType );
if( aMap->HasReal( aType ) )
return aMap->GetReal( aType );
else
void HYDROData_StricklerTable::Set( const QString& theType, double theCoefficient )
{
Handle(TDataStd_NamedData) aMap = Map();
- aMap->SetReal( toExtString( theType ), theCoefficient );
+ aMap->SetReal( HYDROData_Tool::toExtString( theType ), theCoefficient );
}
void HYDROData_StricklerTable::GetCoefficientRange( double& theMin, double& theMax ) const
if( !aMap.IsNull() )
{
for( TDataStd_DataMapIteratorOfDataMapOfStringReal it( aMap->GetRealsContainer() ); it.More(); it.Next() )
- aSeq.append( toQString( it.Key() ) );
+ aSeq.append( HYDROData_Tool::toQString( it.Key() ) );
}
aSeq.sort();
return aSeq;
{
Handle(TDataStd_NamedData) aMap = Map();
- TCollection_ExtendedString aType = toExtString( theType );
+ TCollection_ExtendedString aType = HYDROData_Tool::toExtString( theType );
return !aMap.IsNull() && aMap->HasReal( aType );
}
return aMap;
}
-TCollection_ExtendedString HYDROData_StricklerTable::toExtString( const QString& theStr ) const
-{
- TCollection_ExtendedString aRes;
- if( !theStr.isEmpty() )
- {
- Standard_ExtString extStr = new Standard_ExtCharacter[ ( theStr.length() + 1 ) * 2 ];
- memcpy( (void*)extStr, theStr.unicode(), theStr.length() * 2 );
- ((short*)extStr)[theStr.length()] = '\0';
- aRes = TCollection_ExtendedString( extStr );
- delete [] extStr;
- }
- return aRes;
-}
-
-QString HYDROData_StricklerTable::toQString( const TCollection_ExtendedString& theStr ) const
-{
- return QString( (QChar*)theStr.ToExtString(), theStr.Length() );
-}
-
QString HYDROData_StricklerTable::GetAttrName() const
{
Handle(TDataStd_AsciiString) aName;
}
return QString();}
-void HYDROData_StricklerTable::SetAttrName( const QString& theAttrName ) const
+bool HYDROData_StricklerTable::SetAttrName( const QString& theAttrName ) const
{
- TDataStd_AsciiString::Set( myLab.FindChild( DataTag_AttrName ), toExtString( theAttrName ) );
+ HYDROData_Iterator anIt( HYDROData_Document::Document( myLab ), KIND_STRICKLER_TABLE );
+ for( ; anIt.More(); anIt.Next() )
+ {
+ Handle( HYDROData_StricklerTable ) aTable =
+ Handle( HYDROData_StricklerTable )::DownCast( anIt.Current() );
+ if( aTable->Label()==myLab )
+ continue;
+
+ if( theAttrName==aTable->GetAttrName() )
+ return false;
+ }
+
+ TDataStd_AsciiString::Set( myLab.FindChild( DataTag_AttrName ), HYDROData_Tool::toExtString( theAttrName ) );
+ return true;
}
QString HYDROData_StricklerTable::GetAttrValue( const QString& theType ) const
{
Handle( TDataStd_NamedData ) aMap = Map();
- TCollection_ExtendedString aType = toExtString( theType );
+ TCollection_ExtendedString aType = HYDROData_Tool::toExtString( theType );
if( aMap->HasString( aType ) )
- return toQString( aMap->GetString( aType ) );
+ return HYDROData_Tool::toQString( aMap->GetString( aType ) );
else
return "";
}
void HYDROData_StricklerTable::SetAttrValue( const QString& theType, const QString& theAttrValue ) const
{
Handle( TDataStd_NamedData ) aMap = Map();
- TCollection_ExtendedString aType = toExtString( theType );
- aMap->SetString( aType, toExtString( theAttrValue ) );
+ TCollection_ExtendedString aType = HYDROData_Tool::toExtString( theType );
+ aMap->SetString( aType, HYDROData_Tool::toExtString( theAttrValue ) );
}
QString HYDROData_StricklerTable::GetType( const QString& theAttrValue ) const
{
+ if( theAttrValue.isEmpty() )
+ return "";
+
Handle( TDataStd_NamedData ) aMap = Map();
- TCollection_ExtendedString anAttrValue = toExtString( theAttrValue );
+ TCollection_ExtendedString anAttrValue = HYDROData_Tool::toExtString( theAttrValue );
for( TDataStd_DataMapIteratorOfDataMapOfStringString it( aMap->GetStringsContainer() ); it.More(); it.Next() )
{
if( it.Value() == anAttrValue )
{
- QString aType = toQString( it.Key() );
+ QString aType = HYDROData_Tool::toQString( it.Key() );
return aType;
}
}
QColor HYDROData_StricklerTable::GetColor( const QString& theType ) const
{
Handle( TDataStd_NamedData ) aMap = Map();
- TCollection_ExtendedString aType = toExtString( theType );
+ TCollection_ExtendedString aType = HYDROData_Tool::toExtString( theType );
if( aMap->HasInteger( aType ) )
{
int aColorInt = aMap->GetInteger( aType );
void HYDROData_StricklerTable::SetColor( const QString& theType, const QColor& theColor ) const
{
Handle( TDataStd_NamedData ) aMap = Map();
- TCollection_ExtendedString aType = toExtString( theType );
+ TCollection_ExtendedString aType = HYDROData_Tool::toExtString( theType );
int r = theColor.red();
int g = theColor.green();
int b = theColor.blue();
int aColorInt = ( r<<16 ) + ( g<<8 ) + b;
aMap->SetInteger( aType, aColorInt );
+
+ // synchronize the color for the same type in other maps
+ HYDROData_Iterator anIt( HYDROData_Document::Document( myLab ), KIND_STRICKLER_TABLE );
+ for( ; anIt.More(); anIt.Next() )
+ {
+ Handle( HYDROData_StricklerTable ) aTable =
+ Handle( HYDROData_StricklerTable )::DownCast( anIt.Current() );
+ if( aTable->Label()==myLab )
+ continue;
+
+ if( aTable->HasType( theType ) )
+ aTable->Map()->SetInteger( aType, aColorInt );
+ }
}