Android布局动态化,一种基于堆积木思想的卡片式Android动态布局方法与流程

本发明涉及android界面布局,特别是一种基于堆积木思想的卡片式Android动态布局方法。

背景技术:

在Android流行的今天,android App在生活中使用日益广泛,相对PC,手机由于界面的尺寸的限制,手机的UI设计和布局有他自身的特点,android本身提供多种布局方式,能够满足各种需求,但业务需求的日益丰富和变化,对UI布局提出了更高的需求,除了满足功能需求还要满足频繁变更和快速开发的需求,由于Android本身提供的多种布局方法仅仅是针对基于编程元素的方法,布局一旦确定,后期根据需求灵活修改的就比较麻烦,需要耗费大量时间需要通过编程修改代码布局方法。

技术实现要素:

为解决上述技术问题,本发明的目的是提供一种基于堆积木思想的卡片式Android动态布局方法。

本发明采用的技术方案是:

一种基于堆积木思想的卡片式Android动态布局方法,包括以下步骤

第一步:制作卡片模板;

第二步:制作卡片适配器,该卡片适配器用于将元素数据填充到卡片模板,以制作出数据卡片;

第三步:制作页面布局管理器,该页面布局管理器配置为:根据业务需要,自由组合数据卡片以制作成页面布局。

其中,所述卡片模板的宽度与屏幕宽度一致,卡片模板的高度小于屏幕高度。

进一步,所述卡片模板根据预显示的元素组合制作而成。

本发明的有益效果:相对于传统部署方式,本实例卡片式布局实现功能实现与布局的分离,以及根据业务需求快速调整布局而不需要修改程序的方法。

附图说明

下面结合附图对本发明的具体实施方式做进一步的说明。

图1至图5是具体实施例的卡片模板示意图;

图6为卡片适配器的工作原理图;

图7为页面布局管理器的工作原理图。

具体实施方式

本发明主要采用堆积木的思想,基于APP屏幕布局的特点而设计,整个设计基于以下事实,手机屏幕宽度是有限的(能够一行表现的元素也是有限),如果将屏幕划分为与屏幕宽度相同的卡片组成(卡片高度不定),那么日常需求的卡片的种类是有限的(即卡片模板数量有限)。如果我们将有限的卡片模板预先设定出来,那么页面的布局就简化成简单位置卡片排列。而卡片模板填充不同的数据的就可以表现出不同的数据卡片(也就是有限卡片模板可以制作无限的卡片),基于以上的基础,整个方案技术实现如下:

第一步:制作卡片模板;卡片模板根据预显示的元素组合制作而成。以显示4个元素为例:可以有如图1至图5所示的几种卡片模板。

第二步:制作卡片适配器,该卡片适配器用于将元素数据填充到卡片模板,以制作出数据卡片,参见图6。

第三步:制作页面布局管理器,该页面布局管理器配置为:根据业务需要,自由组合数据卡片以制作成页面布局,参见图7。

其中,所述卡片模板的宽度与屏幕宽度一致,卡片模板的高度小于屏幕高度。

相对于传统部署方式,本发明通过堆积木式卡片布局方法实现快速布局和根据业务驱动布局的动态布局。

以上所述仅为本发明的优先实施方式,本发明并不限定于上述实施方式,只要以基本相同手段实现本发明目的的技术方案都属于本发明的保护范围之内。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/355914.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java cpu_Java High CPU故障排除指南–第1部分

java cpu本文是该系列的第1部分,它将为您提供有关如何进行故障排除和识别Java高CPU问题根本原因的综合指南。 本指南也适用于独立的Java程序,但旨在帮助涉及Java EE企业日常生产支持的个人。 它还将包括最常见的高级CPU问题列表以及高级解决方案。 生产…

android:ellipsize=end 不起作用,android:ellipsize=end 失效或者 相关的Bug

其实这文章有点傻逼。相关的问题TextView android:ellipsize“end”超出一个字符时不显示…的解决http://www.pocketdigi.com/20140122/1261.html上面我到没有遇到过。但是我遇到的更神奇。就是在使用android:ellipsize“end”正常的情况下这个属性。该textView的文本就不能加入…

适用于具有Couchbase和WildFly的多容器和多主机应用程序的Docker Machine,Swarm和Compose...

该博客将说明如何使用Docker创建部署在多个主机上的多容器应用程序。 这将使用Docker Machine,Swarm和Compose实现。 是的,所有这三个工具一起使此博客更加有趣! 该图说明了关键组件: Docker Machine用于配置多个Docker主机 …

android 手机工具箱,Android工具箱下载

安卓工具箱专业版是款集所有功能于一身的工具箱!包括硬件和软件和工具,您的手机使用的信息。非常容易使用,具有非常用户友好的用户界面。 主要功能: 1。硬件信息:CPU核心,CPU类型,内存信息&…

日记

时间:18年4月15日下午将近2点 地点:北京昌平区 本来是在github上写技术博客。突然听到楼下小朋友的嘻戏声,也是不止一次让这种声音勾起了我的回忆。 这种声音就仿佛是自己小时候和小朋友玩一般,但是,我现在却是在北京。…

一键复制android代码,兼容安卓和ios实现一键复制内容到剪切板

js兼容安卓和ios实现粘贴板一键复制color: #000;background: #fff;overflow-y: scroll;-webkit-text-size-adjust: 100%;-ms-text-size-adjust: 100%;}html*{outline:0;-webkit-text-size-adjust: none;-webkit-tap-highlight-color: transparent}*{margin:0;padding:0}.conten…

adf时间作用域_ADF:在任务流终结器中支持bean作用域

adf时间作用域介绍 当我们需要在任务流消失之前做一些最终工作(干净的资源,紧密的连接等)时,这是使用任务流终结器的非常普遍的建议做法。 和往常一样,我们使用在任务流中声明的托管bean。 托管Bean可以具有不同的范围…

贴一段自动编译java,并混淆编译的代码

刚写的一个自动编译、混淆、打包jar的代码&#xff0c;做个记录 用到的NuGet&#xff1a; <?xml version"1.0" encoding"utf-8"?> <packages><package id"DotNetZip" version"1.10.1" targetFramework"net45&qu…

android jpush json,发送了正确的JPush json却报1002

问题描述&#xff1a;调用jPushClient.sendPush前将PushPayload转换成JSON串打印到日志上&#xff0c;检查日志上的JSON发现没有错误&#xff0c;但是response返回报{"error": {"message": "Missing parameter", "code": 1002}}, jpus…

Drools:fireAllRules,fireUntilHalt和Timers内部代码清理的详细说明

在六月&#xff0c;我们在博客上发布了一个新的内部状态机&#xff0c;用于管理用户&#xff0c;计时器和引擎线程之间的交互。 现在&#xff0c;我们对该代码进行了另一次大的内部清理&#xff0c;以使其更易于阅读和理解。 如前所述&#xff0c;所有操作&#xff08;插入&am…

BZOJ 4517 组合数+错排

思路&#xff1a; 预处理错排 然后C(n,m)*s[n-m-1]就是答案了 特判n-m-1<0 //By SiriusRen #include <cstdio> using namespace std; #define int long long const int mod1000000007,N1000050; int cases,n,m,fac[N],s[N]; int pow(int x,int y){int res1;while(y){i…

鸿蒙os下载到电脑上,鸿蒙系统pc版下载2.0

鸿蒙系统pc版2.0是华为最新打造的系统&#xff0c;采用分布式操作系统&#xff0c;可以在华为各种设备上使用。华为鸿蒙2.0系统pc版可以适应全新的芯片&#xff0c;打造个性化的操作习惯&#xff0c;可以让用户使用更舒适&#xff0c;功能更强大。它是一个面向全场景的开源分布…

nodejs+vue+ElementUi房屋房产销售预约看房系统bqv00

完成房产销售系统&#xff0c;对房源的信息、用户信息及各种资料进行收集和科学的管理&#xff0c;该系统的功能基本可以满足当前市面上的小型房产企业对于房产销售的基本要求&#xff0c;收集各个地区的房源信息并进行分类管理&#xff0c;用户通过注册账号登录网站查询房源信…

16.条件控制语句

11.关于条件控制和语句&#xff0c;流程控制语句if...else 1)语法&#xff1a; 第一种结构&#xff1a; if(boolean表达式){ java语句&#xff1b; } 第二种结构&#xff1a; if(boolean表达式){ java语句; }else{ java语句; } 第三种结构&#xff1a; if(boolean表达式){ java…

使用Chameleon,Shrinkwrap,Drone / Graphene与Arquillian进行Java EE集成测试

从我以前的帖子继续在这里 &#xff0c;我想我已经了解了Java EE和也的Arquillian&#xff0c;并测试了一些新的&#xff08;和令人兴奋的&#xff09;事&#xff0c;我想与大家分享。 但是&#xff0c;在开始之前&#xff0c;我想首先请您注意以下几点&#xff08;这些纯粹是…

mysql配置以及性能优化(转)

MySQL配置文件my.cnf中文详解&#xff0c;附mysql性能优化方法分享 Mysql参数优化对于新手来讲&#xff0c;是比较难懂的东西&#xff0c;其实这个参数优化&#xff0c;是个很复杂的东西&#xff0c;对于不同的网站&#xff0c;及其在线量&#xff0c;访问量&#xff0c;帖子数…

android+完美的列表,android完美讲义.pdf

android完美讲义王骋QQPhoneMail• 感谢我的同事&#xff0c;陈操(横拓开源技术副总)&#xff0c;在他提供的资料乊上做了迚一步总结提炼。• 参考资料android sdk开发文档&#xff0c;IBM开发者&#xff0c;同时也感谢网络上的各位大侠• 这个ppt更多是总结&#xff0c;侧重亍…

ios framework 找不到.h_找不到好看的壁纸?上万张「高清壁纸」,都在iOS捷径里...

所需工具&#xff1a;iOS捷径获取方法&#xff1a;后台私信回复「363」不和大家废话&#xff0c;今天给大家分享一个超好用的ios壁纸捷径&#xff0c;用了它之后再也不怕找不到喜欢的壁纸了~将克拉壁纸的捷径链接在Safari浏览器打开&#xff0c;就会自动跳转到一个获取捷径的窗…

12306余票查询

https://kyfw.12306.cn/otn/leftTicket/queryX?leftTicketDTO.train_date2017-04-02&leftTicketDTO.from_stationHXZ&leftTicketDTO.to_stationIZQ&purpose_codesADULT 转载于:https://www.cnblogs.com/jekaysnow/p/6657918.html

div内容用html语言写,html – 使用DIV作为另一个元素的背景

这里我用2个div做了一个例子&#xff1a;> .content,包含前端所需的一切> .background – 包含文本,图像和背景中的所有其他内容要将一个div包装在另一个div上(制作叠加层),你必须将它们放入相同的元素中,在本例中它是#wrapper div.放置位置&#xff1a;包装的相对宽度/高…