博物馆展厅文物标记或售楼处房型区域标记处理解决方案-图片标记位置

本文主要是介绍博物馆展厅文物标记或售楼处房型区域标记处理解决方案-图片标记位置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

    今天项目完结了所以对前面的内容坐下规整处理,上个项目是个博物馆的项目,其中有个要求是需要将展厅内的文物都标记显示在前端页面然后通过点击某文物跳转到对应的文物详情,其中图片需要进行放大缩小处理,而里面的标记点大小不变。这其中涉及到几块内容

    1、图片拼接问题,需要将博物馆楼层的图片拼接成为一张图片

    2、图片拼接后的放大缩小处理,因为你需要查看某个文物详情,有可能一张图片的标记点太多而看不到所以需要将图片放大

    3、图片伸缩后标记点大小不变,这需要重新对位置进行计算并刷新view

先上一张成果图,下面是刚显示出来的标记点

        


效果图已经放了,接下来说下处理方案,首先在后台需要上传我们的底图,然后标记位置


然后看下后台返回的接口数据,后台会将每个文物位于图片的位置的x、y坐标返回给与APP进行瞄点操作

{"msg": "请求成功","code": "0","data": {"floorList": [{"no": "1","plan": "/zbjj/userfiles/1/images/floor/2018/03/777.jpg","showroomList": [{"id": "fdf8ba5615bb4841851a5e6611784dbe","name": "世界野生动物标本展","x": "241.41019955654102","y": "154.14944356120827",}, {"id": "a1271374c0114501a33e814866194615","name": "深圳民俗展厅","x": "94.19955654101996","y": "93.48171701112878",}, {"id": "30b74233dc7e4b81a69cddfab4f55d0f","name": "123号展厅1","x": "89.91674375578168","y": "176.20171673819743",}]}, {"no": "2","plan": "/zbjj/userfiles/1/images/floor/2018/03/777.jpg","showroomList": [{"id": "9fd3bfc286174080b73be3cb921ae32a","name": "近代深圳","x": "66.7450110864745","y": "130.176",}, {"id": "3","name": "叶挺将军与深圳","x": "166.47893569844788","y": "91.008",}, {"id": "5","name": "古代深圳展厅","x": "294.0133037694013","y": "178.05019305019306",}]}]}
}

虽然后台返回了图片和瞄点但是这里需要注意一个问题,因为所有的楼层图片需要拼接为一个整体然后用PhotoView转载进行放大缩小的操作,所以我们需要拼接图片

int width = bitmaps.get(0).getWidth();int height = bitmaps.get(0).getHeight();int currentHeight=0;//获取总高度for (int i = 0; i < bitmaps.size(); i++) {height = height + bitmaps.get(i).getHeight();}//创建一个空的Bitmap(内存区域),宽度等于第一张图片的宽度,高度等于多张图片高度总和bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_4444);//将bitmap放置到绘制区域,并将要拼接的图片绘制到指定内存区域Canvas canvas = new Canvas(bitmap);//一张纸拼接图片for (int i = 0; i < bitmaps.size(); i++) {if (i == 0) {currentHeight=bitmaps.get(i).getHeight();canvas.drawBitmap(bitmaps.get(i), 0, 0, null);} else {//设置拼接的位置坐标canvas.drawBitmap(bitmaps.get(i), 0, currentHeight, null);currentHeight=currentHeight+bitmaps.get(i).getHeight();}}

拼接完成后还需要注意一个问题就是每张大小的图片都可能不同,但是因为图片都经过了缩放处理所以后台给与的瞄点位置也就不能使用了,而且现在的坐标点应该是拼接后的图片的坐标位置。我们需要将后台给与的x、y坐标根据图片放大缩小的比例进行处理,而且y坐标我们也需要根据当前标记点位于第几张图片来进行相应的加减

 float oneWidth = 0;float oneHeigth = 0;int imageHeight=0;int item=0;//因为每张楼层的图片都不同,所以将其放大缩小到屏幕宽度后,从后台返回的标记点位置也要通过运算做出统一处理for (int i = 0; i < showRoomListModels.size(); i++) {for (int j = 0; j <showRoomListModels.get(i).getShowroomList().size(); j++) {ShowRoomModel showRoomModel=showRoomListModels.get(i).getShowroomList().get(j);oneWidth = showRoomModel.getX() / (float)showRoomListModels.get(i).getImageWidth();oneHeigth = (showRoomModel.getY()*showRoomListModels.get(i).getImageFullHeight()/showRoomListModels.get(i).getImageHeight()+imageHeight)/(float)height;String name=showRoomModel.getName();ImageDotLayout.IconBean bean = new ImageDotLayout.IconBean(item,showRoomModel.getId(),name, oneWidth, oneHeigth, null);item++;iconBeanList.add(bean);}//添加楼层标记ImageDotLayout.IconBean bean = new ImageDotLayout.IconBean(-1,"-1",(i+1)+"F",0.05f, (float)(imageHeight+30)/(float)height, null);iconBeanList.add(bean);imageHeight=imageHeight+showRoomListModels.get(i).getImageFullHeight();}

这样我们拿取到了新的坐标位置和图片,我们需要将图片设置到PhotoView上面去并将新的坐标点也传上去

//设置背景图片imageDotLayout.setImage(bitmap,2);
//添加标记点imageDotLayout.addIcons(iconBeanList);
代码下载地址: https://github.com/YaoShuaiAndroid/punctuation




这篇关于博物馆展厅文物标记或售楼处房型区域标记处理解决方案-图片标记位置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/188331

相关文章

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

SpringBoot操作spark处理hdfs文件的操作方法

《SpringBoot操作spark处理hdfs文件的操作方法》本文介绍了如何使用SpringBoot操作Spark处理HDFS文件,包括导入依赖、配置Spark信息、编写Controller和Ser... 目录SpringBoot操作spark处理hdfs文件1、导入依赖2、配置spark信息3、cont

python 字典d[k]中key不存在的解决方案

《python字典d[k]中key不存在的解决方案》本文主要介绍了在Python中处理字典键不存在时获取默认值的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录defaultdict:处理找不到的键的一个选择特殊方法__missing__有时候为了方便起见,

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

Linux限制ip访问的解决方案

《Linux限制ip访问的解决方案》为了修复安全扫描中发现的漏洞,我们需要对某些服务设置访问限制,具体来说,就是要确保只有指定的内部IP地址能够访问这些服务,所以本文给大家介绍了Linux限制ip访问... 目录背景:解决方案:使用Firewalld防火墙规则验证方法深度了解防火墙逻辑应用场景与扩展背景:

SpringBoot嵌套事务详解及失效解决方案

《SpringBoot嵌套事务详解及失效解决方案》在复杂的业务场景中,嵌套事务可以帮助我们更加精细地控制数据的一致性,然而,在SpringBoot中,如果嵌套事务的配置不当,可能会导致事务不生效的问题... 目录什么是嵌套事务?嵌套事务失效的原因核心问题:嵌套事务的解决方案方案一:将嵌套事务方法提取到独立类

Spring Boot实现多数据源连接和切换的解决方案

《SpringBoot实现多数据源连接和切换的解决方案》文章介绍了在SpringBoot中实现多数据源连接和切换的几种方案,并详细描述了一个使用AbstractRoutingDataSource的实... 目录前言一、多数据源配置与切换方案二、实现步骤总结前言在 Spring Boot 中实现多数据源连接

MySQL的索引失效的原因实例及解决方案

《MySQL的索引失效的原因实例及解决方案》这篇文章主要讨论了MySQL索引失效的常见原因及其解决方案,它涵盖了数据类型不匹配、隐式转换、函数或表达式、范围查询、LIKE查询、OR条件、全表扫描、索引... 目录1. 数据类型不匹配2. 隐式转换3. 函数或表达式4. 范围查询之后的列5. like 查询6

使用 Python 和 LabelMe 实现图片验证码的自动标注功能

《使用Python和LabelMe实现图片验证码的自动标注功能》文章介绍了如何使用Python和LabelMe自动标注图片验证码,主要步骤包括图像预处理、OCR识别和生成标注文件,通过结合Pa... 目录使用 python 和 LabelMe 实现图片验证码的自动标注环境准备必备工具安装依赖实现自动标注核心

使用Vue.js报错:ReferenceError: “Vue is not defined“ 的原因与解决方案

《使用Vue.js报错:ReferenceError:“Vueisnotdefined“的原因与解决方案》在前端开发中,ReferenceError:Vueisnotdefined是一个常见... 目录一、错误描述二、错误成因分析三、解决方案1. 检查 vue.js 的引入方式2. 验证 npm 安装3.