diff -r 000000000000 -r c316ab048e9d plugin/poi/geonames/provider/src/Provider.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/plugin/poi/geonames/provider/src/Provider.cpp Fri Jun 25 12:50:05 2010 +0200 @@ -0,0 +1,127 @@ +/* + * Name : Provider.cpp + * Description : + * Project : This file is part of OpenMAR, an Open Mobile Augmented Reality browser + * Website : http://OpenMAR.org + * + * Copyright (c) 2010 David Caabeiro + * + * All rights reserved. This program and the accompanying materials are made available + * under the terms of the Eclipse Public License v1.0 which accompanies this + * distribution, and is available at http://www.eclipse.org/legal/epl-v10.html + * + */ + +#include "Provider.h" + +#include +#include + +#include "Logger.h" + +/* + * Generates a unique id using name and coordinates as a seed + */ +TUint32 GenerateIdL(const CPosLandmark& aLandmark) +{ + TPtrC name; + aLandmark.GetLandmarkName(name); + + TLocality coordinate; + aLandmark.GetPosition(coordinate); + + HBufC8* name8 = HBufC8::NewLC(name.Length()); + name8->Des().Copy(name); + + TRealFormat realFormat; + realFormat.iPoint = TChar('.'); // Override TLocale::DecimalSeparator() as separator + realFormat.iWidth = 8; // Set max width of number + realFormat.iPlaces = 5; // Set max width of decimal portion + + TBuf8 latitude; + latitude.Num(coordinate.Latitude(), realFormat); + + TBuf8 longitude; + longitude.Num(coordinate.Longitude(), realFormat); + + CSHA1* hash = CSHA1::NewL(); + CleanupStack::PushL(hash); + hash->Update(*name8); + hash->Update(latitude); + TPtrC8 result = hash->Final(longitude); + + // Use only 32 bits from hash + const TUint32* ptr = reinterpret_cast(result.Ptr()); + TUint32 value = *ptr; + + CleanupStack::PopAndDestroy(2, name8); // hash, name8 + + return value; +} + +// Create instance of concrete ECOM interface implementation +CProvider* CProvider::NewL() +{ + CProvider* self = new(ELeave) CProvider(); + CleanupStack::PushL(self); + self->ConstructL(); + CleanupStack::Pop(self); + + return self; +} + +CProvider::~CProvider() +{ + delete iLoader; +} + +CProvider::CProvider() +{ +} + +void CProvider::ConstructL() +{ + iLoader = CLoader::NewL(*this); +} + +void CProvider::LandmarkLoaderOpenedL(TInt aError) +{ + if (iObserver) + iObserver->POIProviderLoadedL(this, aError); +} + +void CProvider::LandmarkLoaderItemCreatedL(const CPosLandmark& aLandmark) +{ + if (iObserver) + { + TPosLmItemId id = aLandmark.LandmarkId(); + + if (id == KPosLmNullItemId) + id = GenerateIdL(aLandmark); + + _LIT8(KObject, "geonames"); + OpenMAR::CPOIObject* object = OpenMAR::CPOIObject::NewL(KObject, *this); + CleanupStack::PushL(object); + + object->SetIdentifier(id); + + TLocality locality; + aLandmark.GetPosition(locality); + object->SetCoordinate(locality); + + TPtrC name; + aLandmark.GetLandmarkName(name); + object->SetNameL(name); + + iObserver->POIObjectCreatedL(object); // Transfers ownership + + CleanupStack::Pop(object); + } +} + +void CProvider::RetrieveL(const TCoordinate& aCoordinate, TReal32 aRadius) +{ + LOGARG("[GEONAMES] Retrieving entries from %f %f %f", aCoordinate.Latitude(), aCoordinate.Longitude(), aCoordinate.Altitude()); + + iLoader->RequestL(aCoordinate, aRadius); +}