Bir özellik katmanındaki sınır poligonlarına çizgi ve dolgu stilleri uygulamak için:
FeatureLayer.StyleFactory
arayüzünü uygulayan bir stil fabrikası işlevi oluşturun. Bu işlev, bir özellik katmanının stil mantığını tanımlar.Stil fabrikası işlevini özellik katmanına uygulamak için
FeatureLayer.setFeatureStyle()
işlevini çağırın.
Aşağıdaki örnek haritada, bir Mahalle özellik katmanındaki tek bir bölgenin sınır poligonunun vurgulanması gösterilmektedir.
Stil fabrikası işlevi oluşturma
Stil fabrikası işlevi, işlevi özellik katmanında ayarladığınız sırada etkilenen özellik katmanındaki her poligona uygulanır. Bu işlev, poligonun stilini nasıl alacağını belirten bir FeatureStyle
nesnesi döndürmelidir.
Android için Haritalar SDK'sı, stil fabrikası işlevine bir Feature
örneği iletir. Feature
örneği, özelliğin meta verilerini temsil eder ve stil fabrikası işlevindeki meta verilere erişmenizi sağlar.
Stil fabrikası işlevi uygulandığında her zaman tutarlı sonuçlar döndürmelidir. Örneğin, bir dizi özelliği rastgele renklendirmek istiyorsanız rastgelelik özelliği, özellik stili işlevinde yer almamalıdır. Aksi takdirde istenmeyen sonuçlar ortaya çıkar.
Bu işlev, bir katmandaki her özellik üzerinde çalıştığından optimizasyon önemlidir. Oluşturma sürelerini etkilememek için:
Yalnızca ihtiyacınız olan özellik katmanlarını etkinleştirin.
Bir özellik katmanı artık kullanılmadığında
FeatureLayer.setFeatureStyle(null)
işlevini çağırın.
Poligon çizgisini ve doldurma rengini ayarlama
Stil fabrikası işlevinde bir sınır poligonuna stil uygularken şunları ayarlayabilirsiniz:
Color
sınıfı tarafından tanımlandığı şekilde, poligon kenarlığının ARGB renk biçimindeki çizgi rengi ve opaklığı. Varsayılan değer saydamdır (0x00000000).Poligon kenarlığının ekran piksel cinsinden çizgi genişliği. Varsayılan değer 2'dir.
Color
sınıfı tarafından tanımlandığı şekilde, poligonun ARGB renk biçimindeki dolgu rengi ve opaklığı. Varsayılan değer saydamdır (0x00000000).
Özellikleri hedeflemek için yer kimliklerini arayın
Birçok uygulama, bir özelliğe stil uygulamak için özelliğin konumunu temel alır. Örneğin, farklı ülkelere, bölgelere veya idari bölgelere stil uygulamak isteyebilirsiniz. Özellik konumu, yer kimliği ile temsil edilir.
Yer kimlikleri, bir yeri Google Places veritabanında ve Google Haritalar'da benzersiz şekilde tanımlar. Yer kimliği almak için:
- Bölgeleri ada göre aramak ve belirtilen sınırlar içindeki bölgelerin yer kimliklerini almak için Yerler API'lerini ve Coğrafi Kodlama'yı kullanın.
- Tıklama etkinliklerinden veri alma. Bu işlev, tıklanan bir bölgeye karşılık gelen özelliği döndürür. Bu özellik, yer kimliğine ve özellik türü kategorisine erişim sağlar.
Kapsam bölgeye göre değişir. Ayrıntılar için Google sınırları kapsamı başlıklı makaleyi inceleyin.
Coğrafi adlar, USGS Coğrafi Adlar Kurulu ve ABD Yer Adları Dosyaları gibi birçok kaynaktan edinilebilir.
Yer kimliği almak için PlaceFeature'i kullanma
PlaceFeature
sınıfı, Feature
sınıfının alt sınıfıdır.
ADMINISTRATIVE_AREA_LEVEL_1
, ADMINISTRATIVE_AREA_LEVEL_2
, COUNTRY
, LOCALITY
, POSTAL_CODE
ve SCHOOL_DISTRICT
türündeki özellikleri içeren bir yer özelliğini (yer kimliği olan bir özellik) temsil eder.
Yer kimliği mevcut olduğunda Android için Haritalar SDK'sı, özelliğin konumunu belirleyebilmeniz için stil fabrikası işlevine bir PlaceFeature
örneği iletir.
Stil fabrikası örneği
Bu örnekte, stil fabrikası işlevi Mahalle özellik katmanındaki bir poligona uygulanmaktadır. Stil fabrikası işlevi, PlaceFeature
örneğini kullanarak özelliğin yer kimliğini belirler. Yer kimliği Hawaii, Hana içinse işlev poligona özel bir dolgu ve çizgi stili uygular:
Henüz yapmadıysanız yeni bir harita kimliği ve harita stili oluşturmak için Başlayın bölümündeki adımları uygulayın. Yerleşim özellik katmanını etkinleştirdiğinizden emin olun.
Harita başlatılırken Mahalle özellik katmanına referans alın.
Java
private FeatureLayer localityLayer;
@Override public void onMapReady(GoogleMap map) { // Get the LOCALITY feature layer. localityLayer = map.getFeatureLayer(new FeatureLayerOptions.Builder() .featureType(FeatureType.LOCALITY) .build());
// Apply style factory function to LOCALITY layer. styleLocalityLayer(); }Kotlin
private var localityLayer: FeatureLayer? = null
override fun onMapReady(googleMap: GoogleMap) { // Get the LOCALITY feature layer. localityLayer = googleMap.getFeatureLayer(FeatureLayerOptions.Builder() .featureType(FeatureType.LOCALITY) .build())
// Apply style factory function to LOCALITY layer. styleLocalityLayer() }Stil fabrikası işlevi oluşturup bunu Mahalle özellik katmanına uygulayın.
Aşağıdaki örnekte işlev yalnızca özelliğin yer kimliği Hana, Hawaii ("ChIJ0zQtYiWsVHkRk8lRoB1RNPo") ise uygulanır. Belirtilen yer kimliği Hawaii, Hana için değilse stil uygulanmaz.
Java
private void styleLocalityLayer() {
// Create the style factory function. FeatureLayer.StyleFactory styleFactory = (Feature feature) -> {
// Check if the feature is an instance of PlaceFeature, // which contains a place ID. if (feature instanceof PlaceFeature) { PlaceFeature placeFeature = (PlaceFeature) feature;
// Determine if the place ID is for Hana, HI. if (placeFeature.getPlaceId().equals("ChIJ0zQtYiWsVHkRk8lRoB1RNPo")) {
// Use FeatureStyle.Builder to configure the FeatureStyle object // returned by the style factory function. return new FeatureStyle.Builder() // Define a style with purple fill at 50% opacity and solid purple border. .fillColor(0x80810FCB) .strokeColor(0xFF810FCB) .build(); } } return null; };
// Apply the style factory function to the feature layer. localityLayer.setFeatureStyle(styleFactory); }Kotlin
private fun styleLocalityLayer() {
// Create the style factory function. val styleFactory = FeatureLayer.StyleFactory { feature: Feature ->
// Check if the feature is an instance of PlaceFeature, // which contains a place ID. if (feature is PlaceFeature) { val placeFeature: PlaceFeature = feature as PlaceFeature
// Determine if the place ID is for Hana, HI. if (placeFeature.getPlaceId().equals("ChIJ0zQtYiWsVHkRk8lRoB1RNPo")) {
// Use FeatureStyle.Builder to configure the FeatureStyle object // returned by the style factory function. return@StyleFactory FeatureStyle.Builder() // Define a style with purple fill at 50% opacity and // solid purple border. .fillColor(0x80810FCB.toInt()) .strokeColor(0xFF810FCB.toInt()) .build() } } return@StyleFactory null }
// Apply the style factory function to the feature layer. localityLayer?.setFeatureStyle(styleFactory) }
Katmandan stili kaldırma
Bir katmandan stili kaldırmak için FeatureLayer.setFeatureStyle(null)
işlevini çağırın.