اضافه کردن برچسب – کاتلین

مستندات جامع اندروید

نسخه 1.0.3

در این آموزش نحوه اضافه کردن یک برچسب با متن دلخواه به یک موقعیت جغرافیایی از نقشه توضیح داده خواهد شد.

فهرست مطالب این صفحه

activity_add_label.xml:

فایل لی‌اوت این بخش صرفا شامل یک نقشه از کلاس org.neshan.ui.MapView است.

            <?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="activity.AddLabel">

    <org.neshan.mapsdk.MapView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/map"/>

</android.support.constraint.ConstraintLayout>
        

AddLabelActivity.kt:

به جز متد addLabel تمامی بخش‌های دیگر این کلاس مشابه با کلاس addMarker است و در صورت نیاز می‌توانید از (بخش اضافه کردن نشانگر) اطلاعات مربوط به بقیه بخش‌های کد را مطالعه کنید.

اگر شی label دارای مقدار است، به این معنی می باشد که قبلا یک متن به نقشه اضافه شده. ابتدا با دستور removeLabel این برچسب را از روی نقشه حذف می کنیم.

یک شی از کلاس TextStyleBuilder ساخته شده و با استفاده از متدهای setter ویژگی‌های مختلفی از جمله اندازه فونت، رنگ پس‌زمینه و … بر روی آن تنظیم می‌شود و در نهایت با صدا زدن متد buildStyle بر روی آن، شی ای از کلاس TextStyle برگردانده می‌شود.

شی‌ای از کلاس Label ایجاد شده و به عنوان آرگومان‌های ورودی، به ترتیب، به آن موقعیت جغرافیایی‌ای که برچسب در آن‌جا نشان داده شود، استایل ساخته شده و متنی که باید بر روی برچسب نشان داده شود داده می‌شود.

با صدا زدن متد addLabel بر روی map، برچسب ساخته شده بر روی نقشه نشان داده می‌شود.

            // This method gets a LatLng as input and adds a label on that position
    private fun addLabel(loc: LatLng) {
        if (label != null) {
            map.removeLabel(label)
        }
        // Creating text style. We should use an object of type TextStyleBuilder, set all features on it
        // and then call buildStyle method on it. This method returns an object of type TextStyle.
        val textStyleBuilder = TextStyleBuilder()
        textStyleBuilder.fontSize = 25f
        textStyleBuilder.color = Color(-0x1)
        textStyleBuilder.strokeWidth = 0.5f
        textStyleBuilder.strokeColor = Color(-0x1)
        textStyleBuilder.textMargins = TextMargins(5, 2, 5, 2)
        textStyleBuilder.backgroundColor = Color(-0x10000)
        val textStyle = textStyleBuilder.buildStyle()

        // Creating label
        label = Label(loc, textStyle, "مکان انتخاب شده")

        // Adding marker to labelLayer, or showing label on map!
        map.addLabel(label)
    }
        

نکته:

اولویت نمایش نشانگر (مارکر) نسبت به برچسب بیشتر است. در صورتی که نشانگری وارد محدوده برچسب شود، برچسب نمایش داده نخواهد شد. در صورتی که میخواهید برچسب در هر صورتی نمایش داده شود میتوانید متغیر isHideIfOverlapped را برابر false قرار دهید:

            textStyleBuilder.isHideIfOverlapped = false