【Android-布局复用】 多个界面复用一个布局文件(一)
1.layout_common.xml
复用的布局文件
- <?xml version="1.0" encoding="utf-8"?>
- <!-- 复用的布局文件 -->
- <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="match_parent"
- android:layout_height="wrap_content"
- android:orientation="horizontal" >
- <TextView
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_weight="1" />
- <Button
- android:id="@+id/common_button1"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:text="按钮1" />
- <TextView
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_weight="1" />
- <Button
- android:id="@+id/common_button2"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:text="按钮2" />
- <TextView
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_weight="1" />
- <Button
- android:id="@+id/common_button3"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:text="按钮3" />
- <TextView
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_weight="1" />
- </LinearLayout>
2.layout_main.xml
主布局文件 ,在这里引用复用的布局文件
- <?xml version="1.0" encoding="utf-8"?>
- <!-- 主布局文件 -->
- <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="match_parent"
- android:layout_height="match_parent"
- android:orientation="vertical" >
- <RelativeLayout
- android:layout_width="match_parent"
- android:layout_height="0dp"
- android:layout_margin="16dp"
- android:layout_weight="1" >
- </RelativeLayout>
- <!-- 在布局文件中引用复用的布局文件 -->
- <include layout="@layout/layout_common" />
- </LinearLayout>
3.CommonView.java
复用布局文件实例化。单独封装,接口回调。 避免重复写布局文件,避免重复实例化控件,避免重复设置监听方法
- package com.example.mytestapp;
- import android.app.Activity;
- import android.content.Context;
- import android.view.View;
- import android.view.View.OnClickListener;
- import android.widget.Button;
- /**
- * 复用布局文件实例化
- */
- public class CommonView implements OnClickListener {
- // 接口
- public interface OnCommonViewClick {
- public void onButton1Click(View v);
- public void onButton2Click(View v);
- public void onButton3Click(View v);
- }
- public void setListener(OnCommonViewClick listener) {
- this.listener = listener;
- }
- Context mContext;
- OnCommonViewClick listener;
- public CommonView(Context context) {
- this.mContext = context;
- }
- public Button button1, button2, button3;
- public CommonView init() {
- button1 = (Button) ((Activity) mContext).findViewById(R.id.common_button1);
- button2 = (Button) ((Activity) mContext).findViewById(R.id.common_button2);
- button3 = (Button) ((Activity) mContext).findViewById(R.id.common_button3);
- button1.setOnClickListener(this);
- button2.setOnClickListener(this);
- button3.setOnClickListener(this);
- return this;
- }
- @Override
- public void onClick(View v) {
- if (listener == null)
- return;
- switch (v.getId()) {
- case R.id.common_button1:
- listener.onButton1Click(v);
- break;
- case R.id.common_button2:
- listener.onButton2Click(v);
- break;
- case R.id.common_button3:
- listener.onButton3Click(v);
- break;
- default:
- break;
- }
- }
- }
4.MainActivity.java
主界面实例化
- package com.example.mytestapp;
- import android.app.Activity;
- import android.os.Bundle;
- import android.view.View;
- import android.widget.Toast;
- /*
- * 问题:
- * 1.如何用代码改变控件的文字或颜色?
- */
- public class MainActivity extends Activity implements CommonView.OnCommonViewClick {
- int clickTimes = 0;
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.layout_main);
- // 在这里实例化布局文件, 并实现监听接口方法
- // 只需要一行代码就可以直接完成复用代码块的实例化
- new CommonView(this).init().setListener(this);
- }
- @Override
- public void onButton1Click(View v) {
- clickTimes++;
- // 在这里实现对应点击事件的方法
- Toast.makeText(this, "你点击了button" + clickTimes + "次", Toast.LENGTH_SHORT).show();
- }
- @Override
- public void onButton2Click(View v) {
- // 在这里实现对应点击事件的方法
- }
- @Override
- public void onButton3Click(View v) {
- // 在这里实现对应点击事件的方法
- }
- }
【Android-布局复用】 多个界面复用一个布局文件(一)的更多相关文章
- Android 手机卫士--实现设置界面的一个条目布局结构
本文地址:http://www.cnblogs.com/wuyudong/p/5908986.html,转载请注明源地址. 本文以及后续文章,将一步步完善功能列表: 要点击九宫格中的条目,需要注册点击 ...
- 【Android-布局复用】 多个界面复用一个布局文件(二)
多个界面复用一个布局界面 ,如何找到复用布局文件中的控件的id? 举个栗子: 1. layout_common.xml 复用的布局文件,如何找到button 的id? <?xml versio ...
- Android性能优化之中的一个 布局优化
本文为Android性能优化--布局优化,主要介绍使用抽象布局标签(include, viewstub, merge).去除不必要的嵌套和View节点.降低不必要的infalte及其它Layout方面 ...
- android界面设计之布局管理
谈到android界面设计,各种布局样式不得不提!传统的布局方式有6种,我们会一一介绍. 在android studio2.2版本之后出现了一款超棒的布局方式,真正意义上的所见即所得,后面我们也会讲到 ...
- freemarker实现通用布局的模板拆分与复用
原文:http://www.hawu.me/coding/733 一.基础页面布局 假设我们项目页面的通用布局如下图所示: 实现这样的布局的基本html代码如下: XHTML ...
- Android 手机卫士--导航界面1的布局编写
本文地址:http://www.cnblogs.com/wuyudong/p/5943005.html,转载请注明出处. 本文实现导航界面1的布局的实现,效果如下图所示: 首先分析所使用的布局样式: ...
- android 引入一个布局库后该有的操作
背景 引入一个布局库:com.zhy:percent-support-extends 然后sync now 成功了,也就是同步成功了. 然而开始使用的时候报告了: The following clas ...
- Android笔记——在布局文件中插入另一个布局文件
假如有一个布局文件A.xml想把另外一个布局文件B.xml引进其布局,则可以通过下面的代码 <include layout="@layout/B" />
- Android Studido下的应用性能优化总结--布局优化
前言:一个应用的成功=产品设计*性能 ,再此我们不讨论一个应用的设计,那交给我们可爱又可恨的产品经理和UI设计师来决定!所以这里分步骤讨论如何提升一个应用的性能,这里先探讨布局优化问题. 布局优化 避 ...
随机推荐
- Linux Centos下软件的安装与卸载方法
转载于: http://blog.csdn.net/zolalad/article/details/11368879 Linux下软件的安装与卸载 第一章 linux下安装软件,如何知道软件安 ...
- 15.Ansible安装与配置简单版
Ansible是一个简单高效的自动化运维管理工具,用Python开发,能大批量管理N多台机器,可以并发的在多台机器上部署应用.安装软件.执行命令.配置和编排任务. 一.Ansible工作机制 从图中可 ...
- gin获取全部参数
原文链接:https://blog.csdn.net/keyunq/article/details/82226280 一直都是用结构体接收参数,假如事先不清楚参数名,或者参数是不固定的,就要动态获取. ...
- 7-MySQL DBA笔记-研发规范
第7章 研发规范 本章将为读者解读一份研发规范.为了更好地协同工作和确保所开发的应用尽可能的稳定.高效,建立一套数据库相关的研发规范是很有必要的,虽然研发规范的确立和推广是一项很耗时的工作,但所取得的 ...
- windows下将jar包打入maven仓库
mvn install:install-file -DgroupId=org.csource -DartifactId=fastdfs-client-java -Dversion=1.27 -Dpac ...
- C# Redis分布式锁的应用 - 叶子栈 - SegmentFault 思否
原文:C# Redis分布式锁的应用 - 叶子栈 - SegmentFault 思否 叶子 1 微信扫一扫 新浪微博 Twitter Facebook C# Redis分布式锁的应用 c#redis分 ...
- react用高阶组件实现路由守卫
react-router不像vue-router一样有很多钩子函数,可以做路由守卫.想实现路由守卫,可以用高阶组件来实现. @connect(state => ({ isLogin: state ...
- arcgis 服务网页打开需要输入用户名和密码问题解决
解决方法: 在站点manager中,检查服务的安全性,确认是否是公共.如果不是,设置为公共,面向任何人:如果服务已经被设置为面向公共,那么先设置为私有,面向所选用户,然后再设置为公共,面向任何人 如果 ...
- YOLOV3 训练WIDER_FACE
1. dowload the img and labels : http://mmlab.ie.cuhk.edu.hk/projects/WIDERFace/index.html 2.
- docker 无法使用vi
更新来源 apt-get update 安装vim apt-get install -y vim