[mapguide-internals] MapGuide RFC 33 - Convenience Methods
forSelection
Trevor Wekel
trevor.wekel at autodesk.com
Thu Sep 6 12:12:30 EDT 2007
Hi Paul,
You are bang on with the analysis. There may be a way to interrogate
MgLayer directly for the mapped properties and have the feature service
return those properties only. I will look into it and let you know.
Thanks,
Trevor
-----Original Message-----
From: mapguide-internals-bounces at lists.osgeo.org
[mailto:mapguide-internals-bounces at lists.osgeo.org] On Behalf Of Paul
Spencer (External)
Sent: Thursday, September 06, 2007 5:34 AM
To: MapGuide Internals Mail List
Subject: Re: [mapguide-internals] MapGuide RFC 33 - Convenience Methods
forSelection
Hi Trevor,
to figure out what this saves in realistic terms (in PHP anyway) I
wrote a sample of the difference in the code:
Before:
MgInitializeWebTier($extensionDir. "webconfig.ini");
$user = new MgUserInformation('Anonymous', '');
$siteConnection = new MgSiteConnection();
$siteConnection->Open($user);
$resourceService = $siteConnection->CreateService
(MgServiceType::ResourceService);
$featureService = $siteConnection->CreateService
(MgServiceType::FeatureService);
$map = new MgMap();
$map->Open($resourceService, $mapname);
$selection = new MgSelection($map);
$selection->Open($resourceService, $mapname);
$layers = $selection->GetLayers();
for ($i=0; $i<$layers->GetCount(); $i++) {
$layer = $layers->GetItem($i);
$featureId = $layer->GetFeatureSourceId();
$featureResource = new MgResourceIdentifier($featureId);
$className = $layer->GetFeatureClassName();
$selectionString = $selection->GenerateFilter($layer, $className);
$queryOptions = new MgFeatureQueryOptions();
$queryOptions->SetFilter($selectionString);
$featureReader = $featureService->SelectFeatures($featureSource,
$className, $queryOptions);
// do something with the feature reader
}
After:
MgInitializeWebTier($extensionDir. "webconfig.ini");
$user = new MgUserInformation('Anonymous', '');
$siteConnection = new MgSiteConnection();
$siteConnection->Open($user);
$resourceService = $siteConnection->CreateService
(MgServiceType::ResourceService);
$featureService = $siteConnection->CreateService
(MgServiceType::FeatureService);
$map = new MgMap();
$map->Open($resourceService, $mapname);
$selection = new MgSelection($map);
$selection->Open($resourceService, $mapname);
$layers = $selection->GetLayers();
for ($i=0; $i<$layers->GetCount(); $i++) {
$layer = $layers->GetItem($i);
//$featureId = $layer->GetFeatureSourceId();
//$featureResource = new MgResourceIdentifier($featureId);
$className = $layer->GetFeatureClassName();
//$selectionString = $selection->GenerateFilter($layer,
$className);
//$queryOptions = new MgFeatureQueryOptions();
//$queryOptions->SetFilter($selectionString);
//$featureReader = $featureService->SelectFeatures
($featureSource, $className, $queryOptions);
$featureReader = $selection->GetSelectedFeatures($layer,
$className);
// do something with the feature reader
}
It looks like this will save about 5 lines of code, is that right?
Also, the code I took the example from also modified the
$queryOptions to call AddFeaturePropertyName for each of the property
mappings in the associated layer so that I only get back the
properties that the layer is configured for. If I use the new API, I
would have to actually do that for every feature as it comes out of
the feature reader, and FDO would have to pass back all the
properties, regardless of the property mappings.
So I guess, for me, I won't really be able to use these new
convenience APIs :( I'm not against adding them, and it would
probably be nice to save those 5 lines of code for some people (or
not have to go through the learning curve of figuring out how to get
features from a selection is more likely), but I'm not sure in
practice how much of a convenience it would be. Depending on FDO
performance handling properties, it may actually encourage writing
code that performs more poorly (since you can't limit feature
properties).
Cheers
Paul
On 5-Sep-07, at 3:49 PM, Trevor Wekel wrote:
> Hello list,
>
> MapGuide RFC 33 is ready for review and posted on the Wiki at
> http://trac.osgeo.org/mapguide/wiki/MapGuideRfc33.
>
> Feel free to post any comments to the internals list and I will be
> happy
> to respond.
>
> Thanks,
> Trevor Wekel
>
> _______________________________________________
> mapguide-internals mailing list
> mapguide-internals at lists.osgeo.org
> http://lists.osgeo.org/mailman/listinfo/mapguide-internals
+-----------------------------------------------------------------+
|Paul Spencer pspencer at dmsolutions.ca |
+-----------------------------------------------------------------+
|Chief Technology Officer |
|DM Solutions Group Inc http://www.dmsolutions.ca/ |
+-----------------------------------------------------------------+
_______________________________________________
mapguide-internals mailing list
mapguide-internals at lists.osgeo.org
http://lists.osgeo.org/mailman/listinfo/mapguide-internals
More information about the mapguide-internals
mailing list