Android 仿钉钉组织架构功能,动态创建多个按钮,并给每个按键添加监听事件

本文主要是介绍Android 仿钉钉组织架构功能,动态创建多个按钮,并给每个按键添加监听事件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

现在基本上很多的企业都会使用钉钉,然后细心地人会看到钉钉组织架构功能。在联系人中放着一个可以展开的公司,下面有组织架构和自己所在的部门。


现在我们产品经理说我们项目中也要加入组织架构功能,而且给个变态的需求就是如果一个人在多家公司呢。那就得有多个组织架构了。

这个需求你可能一下就会想到用ExpandListView能解决所有问题。可以呢,如果他本身就存在在ExpandListView的header或者ListView的header中,你直接放入ExpandListView确定不影响滑动的时候的性能吗,在某些机型上滑动的时候会流畅吗。答案是:不允许这样嵌套

于是我就想到一个办法,就是动态的去生成item,并给每一个item加上点击监听,还有变态需求就是如果存在一个人多家公司,那么就要双层item并进行点击监听。

下面是我做的效果,就是通过动态添加和动态监听。


代码分析:

//点击展开组织架构事件RelativeLayout rl__organization_head[] = new RelativeLayout[organizationList.size()];//箭头m_final ImageView iv_organization_arrow[] = new ImageView[organizationList.size()];//组织架构的bodyfinal LinearLayout ll_organization_body[] = new LinearLayout[organizationList.size()];for (int j = 0; j < organizationList.size(); j++) {//初始化header(公司)部分organization_header_view = LayoutInflater.from(mContext).inflate(R.layout.item_organization_header, null);tv_organization_header_text = (TextView) organization_header_view.findViewById(R.id.tv_organizational_organization);rl__organization_head[j] = (RelativeLayout) organization_header_view.findViewById(R.id.rl__organization_head);iv_organization_arrow[j] = (ImageView) organization_header_view.findViewById(R.id.iv_organization_arrow);ll_organization_body[j] = (LinearLayout) organization_header_view.findViewById(R.id.ll_organization_body);tv_organization_header_text.setText(organizationList.get(j).getOrganizationName());//组织架构body(部门)-nameTextView tv_organization_body_text[][] = new TextView[organizationList.size()][organizationList.get(j).getOrganizations().size()];for (int i = 0; i < organizationList.get(j).getOrganizations().size(); i++) {//初始化body(部门)部分insitution_body_view = LayoutInflater.from(mContext).inflate(R.layout.item_organization_body, null);tv_organization_body_text[j][i] = (TextView) insitution_body_view.findViewById(R.id.tv_organization_body_text);view_organization_body_text_line = insitution_body_view.findViewById(R.id.view_organization_body_text_line);if (i == 0) {view_organization_body_text_line.setVisibility(View.GONE);}tv_organization_body_text[j][i].setText(organizationList.get(j).getOrganizations().get(i).getOrganizationName());ll_organization_body[j].addView(insitution_body_view);final int finalJ1 = j;final int finalI = i;tv_organization_body_text[j][i].setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {String departmentName = organizationList.get(finalJ1).getOrganizations().get(finalI).getOrganizationName();String departmentId = organizationList.get(finalJ1).getOrganizations().get(finalI).getOrganizationId();Intent intent = new Intent(getActivity(), OrganizationActivity.class);intent.putExtra("organizationId", organizationList.get(finalJ1).getOrganizationId());intent.putExtra("organizationName", organizationList.get(finalJ1).getOrganizationName());if (finalI > 0) {intent.putExtra("nextFlag", "next");intent.putExtra("firstIntent", "first");}intent.putExtra("departmentId", departmentId);intent.putExtra("departmentName", departmentName);startActivity(intent);}});}//默认关闭组织架构ll_organization_body[j].setVisibility(View.GONE);iv_organization_arrow[j].setBackgroundResource(R.drawable.cell_header_down);ll_organization_header.addView(organization_header_view);final int finalJ = j;rl__organization_head[j].setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {if (isShowFra) {iv_organization_arrow[finalJ].setBackgroundResource(R.drawable.cell_header_up);isShowFra = false;ll_organization_body[finalJ].setVisibility(View.VISIBLE);} else {iv_organization_arrow[finalJ].setBackgroundResource(R.drawable.cell_header_down);isShowFra = true;ll_organization_body[finalJ].setVisibility(View.GONE);}}});}}
有道行的一眼就能看出怎么回事,对我用的数组去处理点击监听问题。类似仿写一个简单的ExpandListView,对绘制和滑动没有任何影响,占用内存也不大。

就是不断的addView动态将item addView到第二层,然后再将第二层动态addView到第一层,以双重for循环处理。organizationList.size()就可以生成多少个公司的组织架构。是不是类似与ExpandListView了,这里为什么不用ExpandListView,是因为这个组件要放在ExpandListView的header里面,至少这样也不会影响ExpandListView的性能。

至于如果只要一个公司呢,organizationList.size() = 1或者拆分出只要一层for循环就行了。精华部分就是怎么去给每一个item添加点击监听事件,这个解决了,多少层都没有问题,一个大树都没有问题。


补充组织架构里面部门的写法,也是简单一级循环监听的方式来处理部门列表的显示,当然也可以用listview也可以做,只是需要对数据处理

/*** 处理部门显示的ui*/private void handleDepartmentUi() {if (departmentData != null && departmentData.size() > 0) {for (int i = 0; i < departmentData.size(); i++) {department_item_view = LayoutInflater.from(this).inflate(R.layout.item_organization_department, null);rl_department_item = (RelativeLayout) department_item_view.findViewById(R.id.rl_organization_department_item);tv_department_name = (TextView) department_item_view.findViewById(R.id.tv_organization_department_name);tv_department_count = (TextView) department_item_view.findViewById(R.id.tv_organization_department_count);tv_department_name.setText(departmentData.get(i).getOrganizationName());
//                tv_department_count.setText("100");//统一监听每个itemrl_department_item.setOnClickListener(clickListener);rl_department_item.setTag(i);ll_department_item.addView(department_item_view);}} else {ll_department_item.setVisibility(View.GONE);view_department_line_1.setVisibility(View.GONE);}}/*** 处理组织架构item的监听*/private View.OnClickListener clickListener = new View.OnClickListener() {@Overridepublic void onClick(View v) {int id = (Integer) v.getTag();Intent intent = new Intent(DepartmentActivity.this, OrganizationActivity.class);intent.putExtra("departmentName", departmentData.get(id).getOrganizationName());intent.putExtra("departmentId", departmentData.get(id).getOrganizationId());intent.putExtra("organizationId", organizationId);intent.putExtra("organizationName", organizationName);intent.putExtra("nextFlag", "next");startActivityForResult(intent, CLOSEREQUESTCODE);}};

这里就是我简单处理部门的方式,其实listview也可以做的,但是要看需求

不知道是否是你们所需要的,还是其他部分,可以提问




这篇关于Android 仿钉钉组织架构功能,动态创建多个按钮,并给每个按键添加监听事件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

mysql中的服务器架构详解

《mysql中的服务器架构详解》:本文主要介绍mysql中的服务器架构,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、mysql服务器架构解释3、总结1、背景简单理解一下mysqphpl的服务器架构。2、mysjsql服务器架构解释mysql的架

Golang如何用gorm实现分页的功能

《Golang如何用gorm实现分页的功能》:本文主要介绍Golang如何用gorm实现分页的功能方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景go库下载初始化数据【1】建表【2】插入数据【3】查看数据4、代码示例【1】gorm结构体定义【2】分页结构体

Java Web实现类似Excel表格锁定功能实战教程

《JavaWeb实现类似Excel表格锁定功能实战教程》本文将详细介绍通过创建特定div元素并利用CSS布局和JavaScript事件监听来实现类似Excel的锁定行和列效果的方法,感兴趣的朋友跟随... 目录1. 模拟Excel表格锁定功能2. 创建3个div元素实现表格锁定2.1 div元素布局设计2.

Android DataBinding 与 MVVM使用详解

《AndroidDataBinding与MVVM使用详解》本文介绍AndroidDataBinding库,其通过绑定UI组件与数据源实现自动更新,支持双向绑定和逻辑运算,减少模板代码,结合MV... 目录一、DataBinding 核心概念二、配置与基础使用1. 启用 DataBinding 2. 基础布局

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,