iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Android自定义图片地图坐标功能的实现方法
  • 178
分享到

Android自定义图片地图坐标功能的实现方法

2023-06-20 14:06:37 178人浏览 薄情痞子
摘要

本篇内容主要讲解“Android自定义图片地图坐标功能的实现方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android自定义图片地图坐标功能的实现方法”吧!一、前言最近项目要求实现一个在自

本篇内容主要讲解“Android自定义图片地图坐标功能的实现方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android自定义图片地图坐标功能的实现方法”吧!

一、前言

最近项目要求实现一个在自定义地图图片上添加坐标信息的功能,类似于在图片做标注的功能。如下图所示。坐标的位置是相对于图片宽高的百分比

Android自定义图片地图坐标功能的实现方法
Android自定义图片地图坐标功能的实现方法

二、思路

改功能主要分为三个视图,1.继承FrameLayout作为父容器;2.添加一个铺满父布局的ImageView显示地图图片;3.动态添加自定义坐标视图

三、代码实现

1. 自定义坐标视图

<?xml version="1.0" encoding="utf-8"?><androidx.constraintlayout.widget.ConstraintLayout xmlns:android="Http://schemas.android.com/apk/res/android"    xmlns:app="http://schemas.android.com/apk/res-auto"    android:layout_width="wrap_content"    android:layout_height="wrap_content">    <ImageView        android:id="@+id/iv_sign"        android:layout_width="20dp"        android:layout_height="wrap_content"        android:layout_marginTop="20dp"        android:src="@mipmap/dot2"        app:layout_constraintEnd_toStartOf="@+id/tv_sign_name"        app:layout_constraintStart_toStartOf="parent"        app:layout_constraintTop_toTopOf="parent" />    <TextView        android:id="@+id/tv_sign_name"        android:layout_width="80dp"        android:layout_height="wrap_content"        android:background="@color/white"        android:text="美食城"        app:layout_constraintEnd_toEndOf="parent"        app:layout_constraintTop_toTopOf="parent" />    <TextView        android:id="@+id/tv_sign_state"        android:layout_width="80dp"        android:layout_height="wrap_content"        android:background="@color/teal_200"        android:text="正常"        android:textColor="@color/white"        app:layout_constraintEnd_toEndOf="parent"        app:layout_constraintStart_toStartOf="@+id/tv_sign_name"        app:layout_constraintTop_toBottomOf="@+id/tv_sign_name" /></androidx.constraintlayout.widget.ConstraintLayout>
class SignView : ConstraintLayout {    private val TAG = SignView::class.java.simpleName    private var view: View    private var signIv: ImageView    private var signNameTv: TextView    private var signStateTv: TextView    constructor(context: Context) : super(context)    constructor(context: Context, attrs: AttributeSet?) : super(context, attrs)    constructor(context: Context, attrs: AttributeSet?, @AttrRes defStyleAttr: Int) : super(        context,        attrs,        defStyleAttr    )    init {        view = LayoutInflater.from(context).inflate(R.layout.sign_view, this, true)        signIv = view.findViewById(R.id.iv_sign)        signNameTv = view.findViewById(R.id.tv_sign_name)        signStateTv = view.findViewById(R.id.tv_sign_state)    }        fun setData(signBean: SignBean) {        signNameTv.text = signBean.name        signStateTv.text = signBean.state    }        fun getSignOffset(): IntArray {        val w = MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED)        val h = MeasureSpec.makeMeasureSpec(0, MeasureSpec.UNSPECIFIED)        signIv.measure(w, h)        val offset = IntArray(2)        val signImageWidth = signIv.measuredWidth        val signImageHeight = signIv.measuredHeight        offset[0] = signImageWidth / 2        offset[1] = 20 + signImageHeight - offset[0]        Log.d(TAG, "getSignOffset: x:${offset[0]}, y:${offset[1]}")        return offset    }}

自定义的坐标视图是一个组合的控件,主要是要计算出坐标图片在整个控件的偏移量

2. 父容器

class MapView : FrameLayout {    private val TAG = MapView::class.java.simpleName    //地图图片    private var mapimage = ImageView(context)    private var mapWidth = 0    private var mapHeight = 0    private var mapLeft = 0    private var mapTop = 0    private var signBeanList = listOf<SignBean>()    private var signOffsetList = mutableListOf<IntArray>()    private var signViewList = mutableListOf<SignView>()    private var capturedViewIndex = 0    private val mDragger: ViewDragHelper =        ViewDragHelper.create(this, 1.0f, object : ViewDragHelper.Callback() {            override fun tryCaptureView(child: View, pointerId: Int): Boolean {                return child != mapImage            }            override fun onViewCaptured(capturedChild: View, activePointerId: Int) {                signViewList.forEachIndexed { index, signView ->                    if (signView == capturedChild) {                        capturedViewIndex = index                        return@forEachIndexed                    }                }            }            override fun onViewPositionChanged(                changedView: View,                left: Int,                top: Int,                dx: Int,                dy: Int            ) {                signOffsetList[capturedViewIndex][0] += dx                signOffsetList[capturedViewIndex][1] += dy            }            override fun clampViewPositionHorizontal(child: View, left: Int, dx: Int): Int {                val move = if (left <= mapLeft)                    mapLeft                else if (left >= mapWidth + mapLeft)                    mapWidth + mapLeft                else                    left                return move            }            override fun clampViewPositionVertical(child: View, top: Int, dy: Int): Int {                val move = if (top <= mapTop)                    mapTop                else if (top >= mapHeight + mapTop)                    mapHeight + mapLeft                else                    top                return move            }        })    constructor(context: Context) : super(context)    constructor(context: Context, attrs: AttributeSet?) : this(context, attrs, 0)    constructor(context: Context, attrs: AttributeSet?, @AttrRes defStyleAttr: Int) : this(        context,        attrs,        defStyleAttr,        0    )    constructor(        context: Context, attrs: AttributeSet?,        @AttrRes defStyleAttr: Int, @StyleRes defStyleRes: Int    ) : super(context, attrs, defStyleAttr, defStyleRes)        fun setMapImage(@DrawableRes resId: Int) {        removeAllViews()        mapImage.setImageResource(resId)        addView(mapImage)    }        fun setSignData(list: List<SignBean>) {        val mapOffset = getBitmapOffset(mapImage, true)        mapLeft = mapOffset[0]        mapTop = mapOffset[1]        mapWidth = mapImage.width - mapLeft * 2        mapHeight = mapImage.height - mapTop * 2        var signOffset = IntArray(2)        var boolean = true        Log.d(TAG, "mapWidth:$mapWidth, mapHeight:$mapHeight, mapLeft:$mapLeft, mapTop:$mapTop")        signBeanList = list        removeViews(1, childCount - 1)        signViewList.clear()        signOffsetList.clear()        list.forEach {            val signView = SignView(context).apply {                setData(it)            }            // 只需要计算一次            if (boolean) {                boolean = false                signOffset = signView.getSignOffset()            }            signView.layoutParams = getParams(it, signOffset)            addView(signView)            signViewList.add(signView)            signOffsetList.add(intArrayOf((it.x * mapWidth).toInt(), (it.y * mapHeight).toInt()))        }    }        fun getMoveSignData(): List<SignBean> {        val data = mutableListOf<SignBean>()        signOffsetList.forEachIndexed { index, ints ->            val signBean = signBeanList[index]            data.add(                SignBean(                    signBean.name,                    signBean.state,                    ints[0] / mapWidth.toFloat(),                    ints[1] / mapHeight.toFloat()                )            )        }        return data    }        private fun getParams(signBean: SignBean, signOffset: IntArray): LayoutParams {        val params = LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT)        params.setMargins(            (signBean.x * mapWidth + mapLeft - signOffset[0]).toInt(),            (signBean.y * mapHeight + mapTop - signOffset[1]).toInt(),            0,            0        )        return params    }        private fun getBitmapOffset(img: ImageView, includeLayout: Boolean): IntArray {        val offset = IntArray(2)        val values = FloatArray(9)        val m: Matrix = img.imageMatrix        m.getValues(values)        offset[0] = values[2].toInt()        offset[1] = values[5].toInt()        if (includeLayout) {            val lp = img.layoutParams as MarginLayoutParams            offset[0] += img.paddingLeft + lp.leftMargin            offset[1] += img.paddingTop + lp.topMargin        }        return offset    }    override fun onInterceptTouchEvent(event: MotionEvent): Boolean {        return mDragger.shouldInterceptTouchEvent(event)    }    override fun onTouchEvent(event: MotionEvent): Boolean {        mDragger.processTouchEvent(event)        return true    }}

父容器中要注意的是由于图片不拉伸,所以会出现图片不会完成铺满ImageView,会有黑边。所以要计算出实际图片显示的大小。

3. Activity

<?xml version="1.0" encoding="utf-8"?><androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:app="http://schemas.android.com/apk/res-auto"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="match_parent"    android:layout_height="match_parent"    tools:context=".MainActivity">    <com.itc.floatparade.MapView        android:id="@+id/map"        android:layout_width="0dp"        android:layout_height="0dp"        android:layout_marginBottom="12dp"        android:background="@color/black"        app:layout_constraintBottom_toTopOf="@+id/tv_add_sign"        app:layout_constraintEnd_toEndOf="parent"        app:layout_constraintStart_toStartOf="parent"        app:layout_constraintTop_toTopOf="parent" />    <Button        android:id="@+id/tv_add_sign"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_marginStart="25dp"        android:layout_marginBottom="12dp"        android:text="添加坐标"        app:layout_constraintBottom_toBottomOf="parent"        app:layout_constraintStart_toStartOf="parent" />    <Button        android:id="@+id/btn_get_sign"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:layout_marginEnd="25dp"        android:text="获取坐标"        app:layout_constraintBottom_toBottomOf="parent"        app:layout_constraintEnd_toEndOf="parent"        app:layout_constraintTop_toBottomOf="@+id/map" />    <TextView        android:id="@+id/tv_sign_list"        android:layout_width="0dp"        android:layout_height="wrap_content"        android:layout_marginStart="8dp"        android:layout_marginEnd="8dp"        android:text=""        app:layout_constraintBottom_toBottomOf="parent"        app:layout_constraintEnd_toStartOf="@+id/btn_get_sign"        app:layout_constraintStart_toEndOf="@+id/tv_add_sign"        app:layout_constraintTop_toBottomOf="@+id/map" /></androidx.constraintlayout.widget.ConstraintLayout>
class MainActivity : AppCompatActivity() {    private lateinit var binding: ActivityMainBinding    override fun onCreate(savedInstanceState: Bundle?) {        super.onCreate(savedInstanceState)        binding = ActivityMainBinding.inflate(layoutInflater)        setContentView(binding.root)        binding.map.setMapImage(R.mipmap.map)        binding.tvAddSign.setOnClickListener {            val list = mutableListOf<SignBean>()            list.add(SignBean("美食城", "正常", 0.2f, 0.4f))            list.add(SignBean("恐龙危机", "正常", 0.5f, 0.5f))            list.add(SignBean("海盗船", "正常", 0.7f, 0.6f))            list.add(SignBean("魔法城堡", "正常", 0.4f, 0.8f))            binding.map.setSignData(list)        }        binding.btnGetSign.setOnClickListener {            val list = binding.map.getMoveSignData()            binding.tvSignList.text = list.toString()        }    }}

完整代码:https://GitHub.com/MattLjp/FloatParade

到此,相信大家对“Android自定义图片地图坐标功能的实现方法”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: Android自定义图片地图坐标功能的实现方法

本文链接: https://www.lsjlt.com/news/297203.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Android自定义图片地图坐标功能的实现方法
    本篇内容主要讲解“Android自定义图片地图坐标功能的实现方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android自定义图片地图坐标功能的实现方法”吧!一、前言最近项目要求实现一个在自...
    99+
    2023-06-20
  • Android 自定义图片地图坐标功能的实现
    一、前言 最近项目要求实现一个在自定义地图图片上添加坐标信息的功能,类似于在图片做标注的功能。如下图所示。坐标的位置是相对于图片宽高的百分比 二、思路 改功能主要分为三个视图,1...
    99+
    2024-04-02
  • Android编程实现自定义ImageView圆图功能的方法
    本文实例讲述了Android编程实现自定义ImageView圆图功能的方法。分享给大家供大家参考,具体如下:首先很感谢开源项目Universal Image Loader图片加载框架。之前也看过一段时间框架源码,但是却没有时间进行知识点的总...
    99+
    2023-05-30
    android 自定义 imageview
  • html+css实现自定义图片上传按钮功能的方法
    小编给大家分享一下html+css实现自定义图片上传按钮功能的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!普通的input[type=&lsquo;...
    99+
    2023-06-09
  • Android 模拟地图定位功能的实现
    实现原理: 手机定位方式目前有4种: 基站定位WIFI定位GPS定位AGPS定位 本工程利用手机自带的"模拟位置"功能实现运行时修改LocationManager...
    99+
    2024-04-02
  • C++瓦片地图坐标转换的实现详解
    目录一、前言二、定义三、矩形瓦片四、菱形瓦片1.斜菱形瓦片2.正菱形瓦片五、点在菱形内判断一、前言 严格来说,瓦片的角度并不是45度。因为为了美术作图方便,图片的宽高比一般为2:1,...
    99+
    2024-04-02
  • Android自定义视图中图片的处理
    目录1.使用Drawable对象2.Bitmap和BitmapFactory2.1 例子2.2 额外知识点(assets)2.3 代码更严谨3.Android9新增的ImageDec...
    99+
    2024-04-02
  • Android实现自定义曲线图
    一般来说应用中比较常见的是折线图,直方图这种比较多,今天来写一个项目中的需求曲线图,也是在之前的折线图基础上改进而来,看效果图 主要考虑曲线的实现以及阴影部分的实现 先看代码: i...
    99+
    2024-04-02
  • Android实现上传图片功能
    本文实例为大家分享了Android实现上传图片功能的具体代码,供大家参考,具体内容如下 设定拍照返回的图片路径 protected void image(String...
    99+
    2024-04-02
  • Android实现图片查看功能
    目录一、效果图二、支持功能三、核心实现方法3.1 缩放 Matrix.postScale(float sx, float sy, float px, float py)3.2 移动 ...
    99+
    2024-04-02
  • Android Bitmap Monitor图片定位功能怎么实现
    本篇内容介绍了“Android Bitmap Monitor图片定位功能怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有...
    99+
    2023-07-05
  • android实现上传本地图片到网络功能
    本文实例为大家分享了android上传本地图片到网络的具体代码,供大家参考,具体内容如下首先这里用到了Okhttp 所以需要一个依赖:compile 'com.squareup.okhttp3:okhttp:3.9.0'...
    99+
    2023-05-30
    android 上传图片 roi
  • OpenLayer实现自定义坐标点的绘制
    目录实现步骤引入相应的库绘制自定义图标获取当前地图所有图层判断重新绘制图标位置效果展示实现步骤 引入相应的库 import 'ol/ol.css'; import Map f...
    99+
    2024-04-02
  • Android实现画中画功能(图片)
    简介: Android 8.0(API 级别 26)允许以画中画 (PIP) 模式启动 Activity。画中画是一种特殊类型的多窗口模式,最常用于视频播放。使用该模式,用户可以通过...
    99+
    2024-04-02
  • Android使用xml自定义图片实例详解
    Android使用xml自定义图片实例详解实现效果图:白色圆角图片bg_round_rectangle_white.xml<?xml version="1.0" encoding="utf-8"?><sha...
    99+
    2023-05-31
    android xml 自定义图片
  • Android如何实现地图定位?Android studio+百度地图API+Android6.0系统实现地图显示、地址设置、点击地图定位功能(详细)
    文章说明:本文初衷是为了记录毕设学习过程,避免忘记操作流程。该功能是毕业设计的Android软件端的功能之一,本文将从获取百度地图密钥(AK)开始,详细地对地图定位配置和相关代码进行说明,文末将附上实现该功能的代码。后续等答辩完成会把整个A...
    99+
    2023-10-11
    android android studio 个人开发 百度
  • Android自定义View实现心形图案
    本文实例为大家分享了Android自定义View实现心形的具体代码,供大家参考,具体内容如下 通过继承View实现的❤形 在绘制心形需要Path类中的两个重要方法分别...
    99+
    2024-04-02
  • Android 实现自定义折线图控件
    目录前言概述原点计算Y轴宽度计算X轴高度X轴绘制轴线X轴刻度间隔网格线、文本Y轴计算Y轴分布刻度间隔、网格线、文本折线代码前言 日前,有一个“折现图”的需求,...
    99+
    2024-04-02
  • Vue实现自定义组件的方式引入图标
    这篇文章主要讲解了“Vue实现自定义组件的方式引入图标”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue实现自定义组件的方式引入图标”吧!前言在项目开发中,使用图标的方式有很多种,可以在i...
    99+
    2023-06-20
  • Android实现网络图片浏览功能
    我们在上网的过程中经常看到各种图片,那你知道它是如何实现的吗?接下来就让我们一块探讨一下。 网络图片的浏览可以分为俩部分,基本的页面布局与界面交互,让我们一步步的来编写。 基本布局很简单,只需要有一个输入图片链接的EditText,一个浏览...
    99+
    2023-05-31
    android 图片浏览 roi
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作