質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

デザイン

プログラミングでのデザインとは、プログラムの構成や、使用の信頼性・持続性・正確性・利便性の目標達成にはどうするのがベストなのか特定の選択を行うことです。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

Kotlin

Kotlinは、ジェットブレインズ社のアンドリー・ブレスラフ、ドミトリー・ジェメロフが開発した、 静的型付けのオブジェクト指向プログラミング言語です。

Google マップ

Google Mapは、Google社がオンラインで提供している地図・ローカル検索サービスです。GIS(Geographic Information System:地理情報システム)の中の「WebGIS」に該当します。地図・航空写真・地形の表示方式があり、それぞれユーザーが縮尺を調整して表示させることができます。地域の情報サービスを検索する機能やルート検索の機能も搭載されています。

Q&A

解決済

2回答

1016閲覧

Androidのマップでマーカーにカスタムデザインを使いたい

Kawboy442

総合スコア14

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

デザイン

プログラミングでのデザインとは、プログラムの構成や、使用の信頼性・持続性・正確性・利便性の目標達成にはどうするのがベストなのか特定の選択を行うことです。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

Kotlin

Kotlinは、ジェットブレインズ社のアンドリー・ブレスラフ、ドミトリー・ジェメロフが開発した、 静的型付けのオブジェクト指向プログラミング言語です。

Google マップ

Google Mapは、Google社がオンラインで提供している地図・ローカル検索サービスです。GIS(Geographic Information System:地理情報システム)の中の「WebGIS」に該当します。地図・航空写真・地形の表示方式があり、それぞれユーザーが縮尺を調整して表示させることができます。地域の情報サービスを検索する機能やルート検索の機能も搭載されています。

0グッド

0クリップ

投稿2020/03/06 08:54

Androidのマップのマーカーにカスタムデザインのxmlファイルを用いたいと思っているのですが、マーカーのカスタムにはMarkerOptions().icon()メソッドを用いているのですが、そこではBitmapDescriptorFactoryがよく使われており、これではBMP画像しか使えないので困っております。

もしカスタムデザインをマーカーに適用させる方法を御存知でしたらご教授いただけますでしょうか。

Activityのソースコードは以下の通りです。

kotlin

1 2class MapActivity : AppCompatActivity(), OnMapReadyCallback { 3 4 private lateinit var mMap: GoogleMap 5 6 override fun onCreate(savedInstanceState: Bundle?) { 7 super.onCreate(savedInstanceState) 8 setContentView(R.layout.activity_map) 9 10 val mapFragment = supportFragmentManager 11 .findFragmentById(R.id.map) as SupportMapFragment 12 mapFragment.getMapAsync(this) 13 } 14 15 override fun onMapReady(googleMap: GoogleMap) { 16 mMap = googleMap 17 18 val nagoya = LatLng(35.170915, 136.881537) 19 20 val pinIcon = BitmapDescriptorFactory.fromResource(R.drawable.ic_pin) 21 22 mMap.addMarker(MarkerOptions().icon(pinIcon).position(nagoya).title("名古屋駅")) 23 24 val cameraUpdate = CameraUpdateFactory.newLatLngZoom(nagoya, 15.0F) 25 mMap.moveCamera(cameraUpdate) 26 } 27}

適用させたいXMLレイアウトは以下の通りです。

XML

1<?xml version="1.0" encoding="utf-8"?> 2<androidx.constraintlayout.widget.ConstraintLayout 3 xmlns:android="http://schemas.android.com/apk/res/android" 4 xmlns:app="http://schemas.android.com/apk/res-auto" 5 android:layout_width="106dp" 6 android:layout_height="67dp"> 7 8 <TextView 9 android:id="@+id/pinTextView" 10 android:layout_width="106dp" 11 android:layout_height="20dp" 12 android:background="@color/torch_red" 13 android:text="2019/12/12 21:59" 14 android:textAlignment="center" 15 android:textColor="@color/white" 16 android:textSize="12sp" 17 app:layout_constraintEnd_toEndOf="parent" 18 app:layout_constraintStart_toStartOf="parent" 19 app:layout_constraintTop_toTopOf="parent" /> 20 21 <ImageView 22 android:id="@+id/pinImageView" 23 android:layout_width="wrap_content" 24 android:layout_height="wrap_content" 25 app:layout_constraintBottom_toBottomOf="parent" 26 app:layout_constraintEnd_toEndOf="parent" 27 app:layout_constraintStart_toStartOf="parent" 28 app:srcCompat="@drawable/ic_pin" /> 29 30</androidx.constraintlayout.widget.ConstraintLayout>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

以下の記事でも扱っていますが、リソースファイルから生成したオブジェクトをBitmapで出力して使う、という方法がベストアンサーになっています。

Using an xml Layout for a Google Map Marker for Android

投稿2020/03/08 15:54

nakasho_dev

総合スコア2655

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Kawboy442

2020/03/10 07:28

ありがとうございました。頂いた回答を元に上記のようなコードとすることで解決しました。
guest

0

自己解決

頂いた記事を元にメソッドを追加し、下記のようなコードとすることで解決しました。

kotlin

1class MapActivity : AppCompatActivity(), OnMapReadyCallback { 2 3 private lateinit var mMap: GoogleMap 4 5 override fun onCreate(savedInstanceState: Bundle?) { 6 super.onCreate(savedInstanceState) 7 setContentView(R.layout.activity_map) 8 9 val mapFragment = supportFragmentManager 10 .findFragmentById(R.id.map) as SupportMapFragment 11 mapFragment.getMapAsync(this) 12 } 13 14 override fun onMapReady(googleMap: GoogleMap) { 15 mMap = googleMap 16 17 val nagoya = LatLng(35.170915, 136.881537) 18 19 val nagoyaBitmap = 20 createBitmap( 21 "2020/3/10 12:30", 22 ContextCompat.getColor(applicationContext, R.color. torch_red), 23 R.drawable.ic_pin 24 ) 25 26 mMap.addMarker( 27 MarkerOptions().icon(BitmapDescriptorFactory.fromBitmap(nagoyaBitmap)).position(nagoya) 28 ) 29 30 val cameraUpdate = CameraUpdateFactory.newLatLngZoom(nagoya, 15.0F) 31 mMap.moveCamera(cameraUpdate) 32 } 33 34 private fun createBitmap(text: String, @ColorInt back: Int, Image: Int): Bitmap { 35 36 val v: View = LayoutInflater.from(this).inflate(R.layout.pin_item_ic_pin, null) 37 val tv: TextView = v.findViewById(R.id.annotationTextView) 38 val mv: ImageView = v.findViewById(R.id.annotationImageView) 39 tv.text = text 40 tv.setBackgroundColor(back) 41 mv.setImageResource(Image) 42 43 v.measure( 44 106, 45 LinearLayout.LayoutParams.WRAP_CONTENT 46 ) 47 48 val b = Bitmap.createBitmap( 49 v.measuredWidth, 50 v.measuredHeight, 51 Bitmap.Config.ARGB_8888 52 ) 53 val c = Canvas(b) 54 v.layout(0, 0, v.measuredWidth, v.measuredHeight) 55 v.draw(c) 56 return b 57 } 58} 59

注意しなければいけないのが、適応するカスタムレイアウトがConstraintLayoutだと、java.lang.IllegalArgumentException: width and height must be > 0というエラーが出てしまうため、使用できませんでした。
FrameLayoutやLinearLayoutでは問題なかったため、今回は下記のようにLinearLayoutとしました。

また、メソッド内のv.measureで規定しているViewのサイズですが、上のwidthの部分をWRAP_CONTENTにしてしまうと見た目がタイトになってしまうので、カスタムレイアウトのwidthと同じサイズにしてあります。

XML

1<?xml version="1.0" encoding="utf-8"?> 2<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 3 xmlns:app="http://schemas.android.com/apk/res-auto" 4 android:layout_width="106dp" 5 android:layout_height="67dp" 6 android:orientation="vertical"> 7 8 <TextView 9 android:id="@+id/pinTextView" 10 android:layout_width="106dp" 11 android:layout_height="20dp" 12 android:background="@color/torch_red" 13 android:text="2020/3/10 12:30" 14 android:textAlignment="center" 15 android:textColor="@color/white" 16 android:textSize="12sp" 17 app:layout_constraintEnd_toEndOf="parent" 18 app:layout_constraintStart_toStartOf="parent" 19 app:layout_constraintTop_toTopOf="parent" /> 20 21 <ImageView 22 android:id="@+id/pinImageView" 23 android:layout_width="wrap_content" 24 android:layout_height="wrap_content" 25 android:layout_gravity="center" 26 app:layout_constraintBottom_toBottomOf="parent" 27 app:layout_constraintEnd_toEndOf="parent" 28 app:layout_constraintStart_toStartOf="parent" 29 app:srcCompat="@drawable/ic_pin" /> 30 31</LinearLayout>

投稿2020/03/10 07:26

Kawboy442

総合スコア14

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kakajika

2020/03/12 04:07

LayoutInflater.inflate(...)の引数に親ViewGroupの情報を渡してあげないと、レイアウトXMLのルートとなるView(ご質問のコードの場合はConstraintLayout)のLayoutParamsが正しく設定されません。 適当にダミーのFrameLayoutを作って渡すようにしてみてください。これで回答に書かれている問題は解決するはずです。 LayoutInflater.from(this).inflate(R.layout.pin_item_ic_pin, FrameLayout(context), false)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問