iis服务器助手广告
返回顶部
首页 > 资讯 > 移动开发 >android自定义View之复合控件
  • 236
分享到

android自定义View之复合控件

2024-04-02 19:04:59 236人浏览 泡泡鱼
摘要

复合控件可以很好地创建出具有重用功能的控件集合。 很多的APP都有一些共通的UI界面,为了统一应用程序的风格,下面我们就以一个Topbar为实例讲解复合控件。 实现效果如图: 第一

复合控件可以很好地创建出具有重用功能的控件集合

很多的APP都有一些共通的UI界面,为了统一应用程序的风格,下面我们就以一个Topbar为实例讲解复合控件。
实现效果如图:

第一步:定义属性

在res资源目录的values目录下创建一个attrs.xml属性定义文件,为一个View提供可自定义的属性。
代码中,通过标签声明了自定义属性,并通过name属性来确定引用的名称。


<?xml version="1.0" encoding="utf-8"?> <resources>
    <declare-styleable name="TopBar">
        <attr name="titleText" fORMat="string"/>
        <attr name="titleSize" format="dimension"/>
        <attr name="titleTextColor2" format="color"/>
        <attr name="leftTextColor" format="color"/>
        <attr name="leftBackground" format="reference|color"/>
       <!--按钮的背景可以指定为具体颜色,也可以一张图片,所以使用“|”来分隔不同的属性-->
        <attr name="leftText" format="string"/>
        <attr name="rightTextColor" format="color"/>
        <attr name="rightBackground" format="reference|color"/>
        <attr name="rightText" format="string"/>
</declare-styleable> </resources>

第二步:创建自定义控件—-创建类CompositControlDemo01,并让其继承RelativeLayout


package com.wjc.customwidget_0502;

import Android.content.Context;
import android.content.res.TypedArray;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import android.view.Gravity;
import android.view.View;
import android.widget.Button;
import android.widget.RelativeLayout;
import android.widget.TextView;



public class CompositControlDemo01 extends RelativeLayout {

    //定义与attrs.xml中的自定义属性对应的属性
    private int mLeftTextColor;
    private String mLeftText;
    private Drawable mLeftBackground;
    private int mRightTextColor;
    private String mRightText;
    private Drawable mRightBackGound;
    private String mTitle;
    private float mTitleTextSize;
    private int mTitleTextColor;
    //布局参数
    private LayoutParams mLeftParame;
    private LayoutParams mRightParame;
    private LayoutParams mTitleParame;
    //定义显示的布局
    private Button mLeftButton;
    private Button mRightButton;
    private TextView mTitleView;
    //定义一个公共接口
    private topbarClickListener mListener;


    //构造函数,attrs就是布局文件传过来的对应的属性
    public CompositControlDemo01(Context context, AttributeSet attrs) {
        super(context, attrs);
        initAttrs(context, attrs);
        initView(context);
    }

    //将attrs.xml中定义的属性值存入typedArray中
    public void initAttrs(Context context, AttributeSet attrs) {
        TypedArray ta = context.obtainStyledAttributes(attrs, R.styleable.TopBar);
        mLeftTextColor = ta.getColor(R.styleable.TopBar_leftTextColor, 0);
        mLeftText = ta.getString(R.styleable.TopBar_leftText);
        mLeftBackground = ta.getDrawable(R.styleable.TopBar_leftBackground);

        mRightTextColor = ta.getColor(R.styleable.TopBar_rightTextColor, 0);
        mRightText = ta.getString(R.styleable.TopBar_rightText);
        mRightBackgound = ta.getDrawable(R.styleable.TopBar_rightBackground);

        mTitle = ta.getString(R.styleable.TopBar_titleText);
        mTitleTextSize = ta.getDimension(R.styleable.TopBar_titleSize, 10);
        mTitleTextColor = ta.getColor(R.styleable.TopBar_titleTextColor2, 0);
        ta.recycle();//避免重新创建时的错误
    }

    //组合控件,并将属性分配给他们,并设置监听事件
    public void initView(Context context) {
        mLeftButton = new Button(context);
        mRightButton = new Button(context);
        mTitleView = new TextView(context);

        mLeftButton.setTextColor(mLeftTextColor);
        mLeftButton.setText(mLeftText);
        mLeftButton.setBackground(mLeftBackground);

        mRightButton.setTextColor(mRightTextColor);
        mRightButton.setText(mRightText);
        mRightButton.setBackground(mRightBackgound);

        mTitleView.setTextColor(mTitleTextColor);
        mTitleView.setText(mTitle);
        mTitleView.setTextSize(mTitleTextSize);
        mTitleView.setGravity(Gravity.CENTER);

        //为元素设定相应的布局参数
        mLeftParame = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.MATCH_PARENT);
        mLeftParame.addRule(RelativeLayout.ALIGN_PARENT_LEFT, TRUE);
        addView(mLeftButton, mLeftParame);

        mRightParame = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.MATCH_PARENT);
        mRightParame.addRule(RelativeLayout.ALIGN_PARENT_RIGHT, TRUE);
        addView(mRightButton, mRightParame);

        mTitleParame = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.MATCH_PARENT);
        mTitleParame.addRule(RelativeLayout.CENTER_IN_PARENT, TRUE);
        addView(mTitleView, mTitleParame);


        //按钮的点击事件,不需要具体的实现
        //只需调用者接口的方法,回调的时候,会有具体的实现
        mLeftButton.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                mListener.leftClick();
            }
        });
        mRightButton.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                mListener.rightClick();
            }
        });
    }

    //定义接口
    //接口对象,实现回调机制,在回调方法中,通过映射的接口对象调用接口的方法
    //而不用去考虑如何实现,具体的实现由调用者去创建
    public interface topbarClickListener {
        void leftClick();
        void rightClick();
    }

    //暴露一个方法给调用者来注册接口回调
    //通过接口来获取回调者对接口方法的实现
    public void setOnTopbarClickListener(topbarClickListener mListener) {
        this.mListener = mListener;
    }

    
    public void setButtonVisable(int id, boolean flag) {
        if (flag) {
            if (id == 0) {
                mLeftButton.setVisibility(View.VISIBLE);
            } else {
                mRightButton.setVisibility(View.VISIBLE);
            }
        } else {
            if (id == 0) {
                mLeftButton.setVisibility(View.GONE);
            } else {
                mRightButton.setVisibility(View.GONE);
            }
        }
    }
}

第三步:引用UI模板—创建topbar.xml文件


<?xml version="1.0" encoding="utf-8"?>
   <com.wjc.customwidget_0502.CompositControlDemo01
       xmlns:android="Http://schemas.android.com/apk/res/android"
       xmlns:custom="http://schemas.android.com/apk/res-auto"
       android:id="@+id/topBar"
       android:layout_width="wrap_content"
       android:layout_height="50dp"
       android:padding="5dp"
      android:background="#3F7EA4"

       custom:leftBackground="@drawable/chevron_left"
       custom:leftTextColor="#ff00"
       custom:leftText="返回"

        custom:rightText="更多"
        custom:rightTextColor="#ff00"
        custom:rightBackground="#ffccff"

        custom:titleText="自定义标题"
        custom:titleTextColor2="#555555"
        custom:titleSize="10sp"
       >
</com.wjc.customwidget_0502.CompositControlDemo01>

注:代码中


xmlns:android=http://schemas.android.com/apk/res/android

表示:引用android系统的属性,而


xmlns:custom=http://schemas.android.com/apk/res-auto

表示:引用第三方控件的属性,即引用自定义的属性

通过如上的代码,我们就可以在其他的布局文件中,直接带调用标签来引用这个UI模板View,代码如下


<include layout="@layout/topbar"/>

第四步:实现接口回调——即写一个activity引用此布局


package com.wjc.customwidget_0502;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {
    CompositControlDemo01 mTopbar;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mTopbar=(CompositControlDemo01)findViewById(R.id.topBar);//初始化组合控件
        //为topBar中的按钮注册监听事件 
        mTopbar.setOnTopbarClickListener(new CompositControlDemo01.topbarClickListener() {
            @Override
            public void leftClick() {
                Toast.makeText(MainActivity.this, "back", Toast.LENGTH_SHORT).show();
            }

            @Override
            public void rightClick() {
                Toast.makeText(MainActivity.this,"more",Toast.LENGTH_LONG).show();
            }
        });
        
    }


}

这是本人的第一篇博客,如有错漏,请留言指教!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: android自定义View之复合控件

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

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

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

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

下载Word文档
猜你喜欢
  • android自定义View之复合控件
    复合控件可以很好地创建出具有重用功能的控件集合。 很多的APP都有一些共通的UI界面,为了统一应用程序的风格,下面我们就以一个Topbar为实例讲解复合控件。 实现效果如图: 第一...
    99+
    2024-04-02
  • android中自定义View之复合控件的示例分析
    这篇文章给大家分享的是有关android中自定义View之复合控件的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。复合控件可以很好地创建出具有重用功能的控件集合。很多的APP都有一些共通的UI界面,为了统...
    99+
    2023-06-15
  • Android如何自定义View歌词控件
    本篇内容介绍了“Android如何自定义View歌词控件”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!目录前言一、 歌词解析歌词实体类Lrc...
    99+
    2023-06-20
  • Android 自定义View 之 Dialog弹窗
    Dialog弹窗 前言正文一、弹窗视图帮助类二、弹窗控制类三、监听接口四、样式五、简易弹窗六、常规使用七、简易使用八、源码 前言   在日常开发中用到弹窗是比较多的,常用于提示作用,比如错误操作提示,余额不足提示,退出登录提...
    99+
    2023-08-18
    自定义Dialog 简易提示弹窗 EasyDialog
  • android怎么自定义组合控件
    要自定义一个组合控件,你可以按照以下步骤进行:1. 创建一个新的类,继承自现有的Android控件类,例如LinearLayout或...
    99+
    2023-08-09
    android
  • Android自定义View之简约风歌词控件实战指南
    目录前言一、 歌词解析1.歌词实体类LrcBean2. 解析歌词工具类LrcUtil二、歌词绘制1.设置自定View属性,在代码中设置默认值2. 初始化两支画笔3. 重复执行onDr...
    99+
    2024-04-02
  • Android view自定义带文字带进度的控件
    目标:自定义一个带文字带进度的控件,具体内容如下效果图:不啰嗦先看东西:步骤分析提取自定义属性//提供对外暴露的属性,如有不够自己扩展 <declare-styleable name="DescProgressView"> ...
    99+
    2023-05-30
    android view 进度
  • Android自定义View圆形进度条控件的方法
    这篇文章主要讲解了Android自定义View圆形进度条控件的方法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。继续练习自定义View,这次带来的圆形进度条控件与之前的圆形百分比控件大同小异,这次涉及到了渐变渲...
    99+
    2023-05-31
    android roi %d
  • Android自定义view实现滚动选择控件详解
    目录前言需求编写代码主要问题前言 上篇文章通过一个有header和footer的滚动控件(Viewgroup)学了下MeasureSpec、onMeasure以及onLayout,接...
    99+
    2022-11-13
    Android滚动选择 Android滚动选择控件 Android自定义view
  • Android怎么自定义View
    这篇文章主要介绍“Android怎么自定义View”,在日常操作中,相信很多人在Android怎么自定义View问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Android怎么自定义View”的疑惑有所帮助!...
    99+
    2023-06-30
  • Android自定义view实现滑动解锁九宫格控件
    目录前言需求效果图前言 上一篇文章用贝塞尔曲线画了一个看起来不错的小红点功能,技术上没什么难度,主要就是数学上的计算。这篇文章也差不多,模仿了一个常用的滑动解锁的九宫格控件。 需求 ...
    99+
    2023-02-09
    Android滑动解锁九宫格 Android滑动解锁 Android九宫格控件
  • Android 之自定义 View 的死亡三部曲之 Layout
    在 Android 中,自定义 View 的死亡三部曲是指测量(Measure)、布局(Layout)和绘制(Draw)三个阶段。L...
    99+
    2023-09-21
    Android
  • Android自定义View-Paint详解
    Paint的使用 setStyle Paint.Style.FILL:填充模式 Paint.Style.STROKE:画线模式 Paint.Style.FI...
    99+
    2024-04-02
  • Android自定义控件之日期选择控件使用详解
    Android日期选择控件效果如下:调用的代码:@OnClick(R.id.btn0) public void btn0() { final AlertDialog dialog = new AlertDialog.Builder(cont...
    99+
    2023-05-31
    android 日期 控件
  • android 自定义控件 使用declare
    在Android中,可以使用`declare-styleable`来定义和使用自定义控件的属性。下面是一个简单的示例:1. 在res...
    99+
    2023-09-21
    Android
  • android自定义View圆圈拖动
    本文实例为大家分享了android自定义View圆圈拖动的具体代码,供大家参考,具体内容如下 问题: 1 . 累加问题:“点击坐标”坐标在移动时必须改变位置,不然将导致累加过载 2....
    99+
    2024-04-02
  • Android如何通过组合的方式自定义View
    前言: 自定义View可以分为两种方式: 第一种通过继承ViewGroup,内部通过addView的方式将其他的View组合到一起。第二种则是通过继承View,重启View的onMe...
    99+
    2024-04-02
  • Android自定义View倒计时圆
    本文实例为大家分享了Android自定义View倒计时圆的具体代码,供大家参考,具体内容如下 创建attr<?xml version="1.0" encoding="utf-8"?><resour...
    99+
    2023-05-30
    android view 倒计时圆
  • Android自定义View原理(实战)
    目录1、为什么需要自定义View2、自定义View的基本方法3、自定义View的属性如何操作4、View的视图结构5、View的坐标系6、View树的绘制流程6.1 measure过...
    99+
    2024-04-02
  • Android自定义复杂view的方法是什么
    要自定义复杂的View,可以按照以下步骤进行:1. 创建一个新的类,继承自View或者ViewGroup的子类,例如LinearLa...
    99+
    2023-09-27
    Android
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作