MarkerDimension: IDimInstance;
The MarkerDimension property determines geolocation objects dimension.
Map data source must contain exclusive dimension of geolocation objects. This dimension must be based on the MDM dictionary containing LATITUDE and LONGITUDE real attributes. Attributes must contain latitude and longitude values for geolocation markers.
Executing the example requires that the repository contains an express report with the EXPRESS_MARKERS identifier. Report data source is a time series database containing an indicator attribute with the CITY identifier. This attribute is a link to the MDM dictionary containing real attributes LATITUDE and LONGITUDE with values of latitude and longitude for geolocation markers.
Cubes, Dimensions, Express, Metabase, Rds.
Sub UserProc;
Var
MB: IMetabase;
Express: IEaxAnalyzer;
DArea: IEaxDataArea;
DAreaSlice: IEaxDataAreaSlice;
Rub: IRubricator;
Atts: IMetaAttributes;
DictObj: IMetabaseObjectDescriptor;
DimInst: IDimInstance;
Begin
// Get repository
MB := MetabaseClass.Active;
// Get express report
Express := MB.ItemById("EXPRESS_MARKERS").edit As IEaxAnalyzer;
DArea := Express.DataArea;
If DArea.Slices.Count > 0 Then
DAreaSlice := DArea.Slices.Item(0);
// Get data source for data slice
Rub := DAreaSlice.DataSource As IRubricator;
// Ger time series attributes
Atts := Rub.Facts.Attributes;
// Get the dictionary that is a data source for the "CITY" attribute
DictObj := Atts.FindById("CITY").ValuesObject;
// Open obtained dictionary
DimInst := DictObj.Open(Null) As IDimInstance;
// Set the open dictionary as a geolocation objects dimension
DAreaSlice.MarkerDimension := DimInst;
End If;
(Express As IMetabaseObject).Save;
End Sub UserProc;
After executing the example the geolocation object dimension is set in express report.
See also: