หากต้องการเพิ่มเครื่องหมายขั้นสูงลงในแผนที่ ให้สร้างอินสแตนซ์ใหม่ของ AdvancedMarkerOptions
แล้วใช้ GoogleMap.addMarker()
เพื่อเพิ่มเครื่องหมาย
Kotlin
private val SYDNEY = LatLng(-33.87365, 151.20689)
val marker: Marker? = map.addMarker( AdvancedMarkerOptions() .position(SYDNEY) .iconView(textView) .zIndex(zIndex) )
Java
private final LatLng SYDNEY = new LatLng(-33.87365, 151.20689);
Marker marker = map.addMarker( new AdvancedMarkerOptions() .position(SYDNEY) .iconView(textView) .zIndex(zIndex));
GoogleMap.addMarker()
จะแสดงผลอินสแตนซ์ของ Marker
หากจําเป็น คุณสามารถแคสต์ค่าที่แสดงผลเป็น AdvancedMarker
ได้
ใช้ AdvancedMarkerOptions
เพื่อกําหนดค่าเครื่องหมายขั้นสูง
AdvancedMarkerOptions
เป็นคลาสย่อยของ MarkerOptions
จึงรองรับการตั้งค่าทั้งหมดเหมือนกับ MarkerOptions
AdvancedMarkerOptions
ยังช่วยให้คุณทำสิ่งต่อไปนี้ได้ด้วย
สร้างอินสแตนซ์ของคลาส
PinConfig
แล้วใช้อินสแตนซ์PinConfig
เพื่อกําหนดค่าอินสแตนซ์AdvancedMarkerOptions
ใช้
PinConfig
เพื่อปรับแต่งพร็อพเพอร์ตี้เครื่องหมายขั้นสูง เช่น สีพื้นหลัง สีเส้นขอบ และสัญลักษณ์สร้างอินสแตนซ์ของคลาส Android
View
ใช้อินสแตนซ์นั้นเพื่อกําหนดค่าอินสแตนซ์AdvancedMarkerOptions
อินสแตนซ์มุมมองช่วยให้คุณปรับแต่งเครื่องหมายได้อย่างเต็มรูปแบบ
ใช้ PinConfig
คลาส PinConfig
มีตัวเลือกในการปรับแต่งเครื่องหมายขั้นสูง ใช้ PinConfig
เพื่อดำเนินการต่อไปนี้
- เปลี่ยนสีพื้นหลัง
- เปลี่ยนสีเส้นขอบ
- เปลี่ยนสีสัญลักษณ์หรือเพิ่มข้อความ
- ซ่อนสัญลักษณ์
ใช้ PinConfig.Builder
เพื่อสร้างอินสแตนซ์ของ PinConfig
Kotlin
// Use PinConfig.Builder to create an instance of PinConfig. val pinConfigBuilder: PinConfig.Builder = PinConfig.builder() pinConfigBuilder.setBackgroundColor(Color.MAGENTA) val pinConfig: PinConfig = pinConfigBuilder.build()// Use the PinConfig instance to set the icon for AdvancedMarkerOptions. val advancedMarkerOptions: AdvancedMarkerOptions = AdvancedMarkerOptions() .icon(BitmapDescriptorFactory.fromPinConfig(pinConfig)) .position(MARKER_POSITION)
// Pass the AdvancedMarkerOptions instance to addMarker(). val marker: Marker? = map.addMarker(advancedMarkerOptions)
Java
// Use PinConfig.Builder to create an instance of PinConfig. PinConfig.Builder pinConfigBuilder = PinConfig.builder(); pinConfigBuilder.setBackgroundColor(Color.MAGENTA); PinConfig pinConfig = pinConfigBuilder.build();
// Use the PinConfig instance to set the icon for AdvancedMarkerOptions. AdvancedMarkerOptions advancedMarkerOptions = new AdvancedMarkerOptions() .icon(BitmapDescriptorFactory.fromPinConfig(pinConfig)) .position(MARKER_POSITION);
// Pass the AdvancedMarkerOptions instance to addMarker(). Marker marker = map.addMarker(advancedMarkerOptions);
เปลี่ยนสีพื้นหลัง
ใช้เมธอด PinConfig.background()
เพื่อเปลี่ยนสีพื้นหลังของเครื่องหมาย โดยทำดังนี้
Kotlin
// Use PinConfig.Builder to create an instance of PinConfig. val pinConfigBuilder: PinConfig.Builder = PinConfig.builder() pinConfigBuilder.setBackgroundColor(Color.MAGENTA) val pinConfig: PinConfig = pinConfigBuilder.build()
Java
// Use PinConfig.Builder to create an instance of PinConfig. PinConfig.Builder pinConfigBuilder = PinConfig.builder(); pinConfigBuilder.setBackgroundColor(Color.MAGENTA); PinConfig pinConfig = pinConfigBuilder.build();
เปลี่ยนสีเส้นขอบ
ใช้เมธอด PinConfig.borderColor()
เพื่อเปลี่ยนสีเส้นขอบของเครื่องหมาย โดยทำดังนี้
Kotlin
// Set the border color. val pinConfigBuilder: PinConfig.Builder = PinConfig.builder() pinConfigBuilder.setBorderColor(Color.BLUE) val pinConfig: PinConfig = pinConfigBuilder.build()
Java
// Set the border color. PinConfig.Builder pinConfigBuilder = PinConfig.builder(); pinConfigBuilder.setBorderColor(Color.BLUE); PinConfig pinConfig = pinConfigBuilder.build();
เปลี่ยนสัญลักษณ์
สร้างอินสแตนซ์ Glyph
แล้วใช้อินสแตนซ์นั้นเพื่อกำหนดค่า PinConfig
ใช้สัญลักษณ์เพื่อตั้งค่าข้อความสัญลักษณ์และสีข้อความ สีสัญลักษณ์ หรือเพื่อระบุรูปภาพที่กําหนดเองเพื่อใช้เป็นสัญลักษณ์
ตัวอย่างต่อไปนี้จะตั้งค่าข้อความแบบอักขระ
Kotlin
// Set the glyph text. val pinConfigBuilder: PinConfig.Builder = PinConfig.builder() val glyphText = Glyph("A")
// Alteratively, you can set the text color: // Glyph glyphText = new Glyph("A", Color.GREEN);
pinConfigBuilder.setGlyph(glyphText) val pinConfig: PinConfig = pinConfigBuilder.build()
Java
// Set the glyph text. PinConfig.Builder pinConfigBuilder = PinConfig.builder(); PinConfig.Glyph glyphText = new PinConfig.Glyph("A");
// Alternatively, you can set the text color: // PinConfig.Glyph glyphText = new PinConfig.Glyph("A", Color.GREEN);
pinConfigBuilder.setGlyph(glyphText); PinConfig pinConfig = pinConfigBuilder.build();
ตั้งค่าสีสัญลักษณ์
Kotlin
val glyphColor = PinConfig.Glyph(Color.BLUE) pinConfigBuilder.setGlyph(glyphColor) val pinConfig: PinConfig = pinConfigBuilder.build()
Java
PinConfig.Glyph glyphColor = new PinConfig.Glyph(Color.BLUE); pinConfigBuilder.setGlyph(glyphColor); PinConfig pinConfig = pinConfigBuilder.build();
ตั้งค่ารูปภาพที่กําหนดเองสําหรับสัญลักษณ์ เทคนิคนี้มีประโยชน์หากคุณต้องการใช้โลโก้ที่ออกแบบเองหรือตัวบ่งชี้ภาพอื่นๆ บนเครื่องหมาย
Kotlin
// Set the glyph image. val glyphImage: Int = R.drawable.example_image val descriptor = PinConfig.BitmapDescriptorFactory.fromResource(glyphImage) pinConfigBuilder.setGlyph(Glyph(descriptor)) val pinConfig: PinConfig = pinConfigBuilder.build()
Java
// Set the glyph image. int glyphImage = R.drawable.example_image; BitmapDescriptor descriptor = BitmapDescriptorFactory.fromResource(glyphImage); pinConfigBuilder.setGlyph(new PinConfig.Glyph(descriptor)); PinConfig pinConfig = pinConfigBuilder.build();
ซ่อนสัญลักษณ์
คุณซ่อนสัญลักษณ์เพื่อให้สีพื้นหลังเติมเต็มเครื่องหมายทั้งชิ้นได้ ดังนี้
Kotlin
// Create a transparent glyph. val pinConfigBuilder: PinConfig.Builder = PinConfig.builder() pinConfigBuilder.setBackgroundColor(Color.MAGENTA) pinConfigBuilder.setGlyph(PinConfig.Glyph(Color.TRANSPARENT)) val pinConfig: PinConfig = pinConfigBuilder.build()
Java
// Create a transparent glyph. PinConfig.Builder pinConfigBuilder = PinConfig.builder(); pinConfigBuilder.setBackgroundColor(Color.MAGENTA); pinConfigBuilder.setGlyph(new PinConfig.Glyph(Color.TRANSPARENT)); PinConfig pinConfig = pinConfigBuilder.build();
ใช้ iconView
วิธี AdvancedMarkerOptions.iconView()
ให้คุณใช้ Android View
ใดก็ได้เป็นเครื่องหมาย การใช้มุมมองเป็นเครื่องหมายช่วยให้คุณควบคุมเครื่องหมายได้อย่างเต็มที่
ในแอป คุณต้องสร้างมุมมองก่อน จากนั้นใช้เมธอด AdvancedMarkerOptions.iconView()
เพื่อเพิ่มมุมมองลงในเครื่องหมายขั้นสูง
Kotlin
// Create a TextView to use as the marker. val textView = TextView(this) textView.text = "Hello!!" textView.setBackgroundColor(Color.BLACK) textView.setTextColor(Color.YELLOW)
val marker: Marker? = map.addMarker( AdvancedMarkerOptions() .position(SYDNEY) .iconView(textView) )
Java
// Create a TextView to use as the marker. TextView textView = new TextView(this); textView.setText("Hello!!"); textView.setBackgroundColor(Color.BLACK); textView.setTextColor(Color.YELLOW);
Marker marker = map.addMarker( new AdvancedMarkerOptions() .position(SYDNEY) .iconView(textView));