Android自定义标题栏替代复杂的Actionbar

隐藏ActionBar,可以自定义一个组合控件替代

组合控件

  组合控件,顾名思义就是将一些小的控件组合起来形成一个新的控件,这些小的控件多是系统自带的控件。比如很多应用中普遍使用的标题栏控件,其实用的就是组合控件,那么下面将通过实现一个简单的标题栏自定义控件来说说组合控件的用法。

1、创建自定义标题栏的布局文件activitiy_app_title.xml:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="50dp"
    android:background="@color/colorTheme"
    android:focusable="true"
    android:focusableInTouchMode="true">

    <ImageView
        android:id="@+id/img_back"
        android:layout_width="wrap_content"
        android:layout_height="50dp"
        android:contentDescription="@null"
        android:paddingEnd="@dimen/mdp_15"
        android:paddingLeft="@dimen/mdp_10"
        android:paddingRight="@dimen/mdp_15"
        android:paddingStart="@dimen/mdp_10"
        android:scaleType="fitCenter"
        android:src="@mipmap/icon_back"
        android:visibility="invisible" />

    <TextView
        android:id="@+id/tv_title_mid"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:layout_gravity="center_horizontal"
        android:textColor="@color/colorWhite"
        android:textSize="@dimen/msp_16" />

    <ImageView
        android:id="@+id/img_right"
        android:layout_width="wrap_content"
        android:layout_height="50dp"
        android:layout_alignParentRight="true"
        android:layout_centerVertical="true"
        android:contentDescription="@null"
        android:paddingEnd="@dimen/mdp_10"
        android:paddingLeft="@dimen/mdp_15"
        android:paddingRight="@dimen/mdp_10"
        android:paddingStart="@dimen/mdp_15"
        android:scaleType="fitCenter"
        android:src="@mipmap/icon_search"
        android:visibility="invisible" />

    <TextView
        android:id="@+id/tv_title_right"
        android:layout_width="wrap_content"
        android:layout_height="50dp"
        android:layout_alignParentRight="true"
        android:layout_centerVertical="true"
        android:gravity="center_vertical"
        android:paddingEnd="@dimen/mdp_10"
        android:paddingLeft="@dimen/mdp_15"
        android:paddingRight="@dimen/mdp_10"
        android:paddingStart="@dimen/mdp_15"
        android:textColor="@color/colorWhite"
        android:textSize="@dimen/msp_14"
        android:visibility="invisible" />

</RelativeLayout>

2、在res/values/  下建立一个attrs.xml

(一共有:string,color,demension,integer,enum,reference,float,boolean,fraction,flag;不清楚的可以google一把。)

<?xml version="1.0" encoding="UTF-8"?>
<resources>
    <declare-styleable name="TitleLinearLayout">
        <attr name="isBack" format="boolean" />
    </declare-styleable>
</resources>

3、创建一个类TitleView,继承自LinearLayout:  

package com.a.b.view;


import android.app.Activity;
import android.content.Context;
import android.content.res.TypedArray;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.TextView;

import com.a.b.R;


/**
 * Title通用布局
 *
 * @author Administrator
 */
public class MTitle extends LinearLayout {
    private ImageView imgBack;
    private TextView tvMid;
    private ImageView imgRight;
    private TextView tvRight;

    public MTitle(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
        initView(context, attrs);
    }

    public MTitle(Context context, AttributeSet attrs) {
        super(context, attrs);
        initView(context, attrs);
    }

    private void initView(final Context context, AttributeSet attrs) {
        View title = LayoutInflater.from(context).inflate(R.layout.app_title, null);
        tvMid = (TextView) title.findViewById(R.id.tv_title_mid);
        TypedArray a = context.obtainStyledAttributes(attrs, R.styleable.TitleLinearLayout);
        boolean isBack = a.getBoolean(R.styleable.TitleLinearLayout_isBack, false);
        if (getTag() != null) {
            tvMid.setText(this.getTag().toString());
        }
        imgBack = (ImageView) title.findViewById(R.id.img_back);
        imgRight = (ImageView) title.findViewById(R.id.img_right);
        tvRight = (TextView) title.findViewById(R.id.tv_title_right);
        imgBack.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                ((Activity) context).finish();
            }
        });
        if (isBack) {
            imgBack.setVisibility(View.VISIBLE);
        }
        title.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.WRAP_CONTENT));
        this.addView(title);
    }

    public void setTitle(String str) {
        if (str != null) {
            tvMid.setText(str);
        }
    }
    public String getTitle() {
        return tvMid.getText().toString();
    }

    public ImageView getTitleRigthImg(int res) {
        tvRight.setVisibility(View.INVISIBLE);
        imgRight.setVisibility(View.VISIBLE);
        imgRight.setImageResource(res);
        return imgRight;
    }

    public ImageView getTitleLeftImg(int res) {
        imgBack.setVisibility(View.VISIBLE);
        imgBack.setImageResource(res);
        return imgBack;
    }

    public TextView getTitleRightText(String str) {
        imgRight.setVisibility(View.INVISIBLE);
        tvRight.setVisibility(View.VISIBLE);
        tvRight.setText(str);
        return tvRight;
    }
}

4、在.xml中引入自定义的标题栏:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:title="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@color/colorbackhui"
    android:orientation="vertical">

    <com.youpinwallet.ypw.view.MTitle
        android:id="@+id/title"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginBottom="@dimen/mdp_10"
        android:tag="我的优惠券"
        title:isBack="true" />

    <com.jcodecraeer.xrecyclerview.XRecyclerView
        android:id="@+id/x_recyclerview"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="@dimen/mdp_6"
        android:layout_marginRight="@dimen/mdp_6"
        android:paddingBottom="@dimen/mdp_10"
        android:paddingTop="@dimen/mdp_5"
        android:visibility="gone"
        android:background="@color/colorbackhui" />
     
</LinearLayout>

5、在java代码中引用标题栏 

title.setTitle(type.equals("WD") ? "我的优惠券" : "可使用优惠券");
title.getTitleRightText("使用规则").setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        Intent intent = new Intent(CouponActivity.this, WebViewActivity.class);
        intent.putExtra("title", "优惠券使用规则");
        intent.putExtra("url", ApiUtils.URL_COUPON_DEAL);
        startActivity(intent);
    }
});

自绘控件

自绘控件的内容都是自己绘制出来的,在View的onDraw方法中完成绘制。

1、组合控件中2自定义属性;

2、组合控件中3;

重写三个构造方法;

重写onDraw,onMesure调用系统提供的:

3、组合控件中4引用到布局中;

继承控件

就是继承已有的控件,创建新控件,保留继承的父控件的特性,并且还可以引入新特性。
 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: 要在Android Studio中自定义标题栏,可以按照以下步骤进行操作: 1. 在res文件夹中创建一个新的布局文件,例如“custom_title.xml”,用于定义自定义标题栏的布局。 2. 在AndroidManifest.xml文件中的Activity标签中添加以下属性: android:theme="@style/CustomTheme" 其中,“CustomTheme”是自定义主题的名称。 3. 在res文件夹中创建一个新的styles.xml文件,并在其中定义自定义主题。例如: <style name="CustomTheme" parent="Theme.AppCompat.Light.DarkActionBar"> <item name="android:windowNoTitle">true</item> <item name="android:windowActionBar">false</item> <item name="android:windowBackground">@color/colorPrimary</item> <item name="android:colorPrimary">@color/colorAccent</item> <item name="android:colorPrimaryDark">@color/colorPrimaryDark</item> </style> 其中,“colorPrimary”、“colorAccent”和“colorPrimaryDark”是自定义颜色的名称。 4. 在Activity的onCreate方法中使用以下代码来设置自定义标题栏: getSupportActionBar().setDisplayOptions(ActionBar.DISPLAY_SHOW_CUSTOM); getSupportActionBar().setCustomView(R.layout.custom_title); 其中,“custom_title”是自定义标题栏布局文件的名称。 5. 最后,根据需要在自定义标题栏布局文件中添加所需的视图元素,例如TextView、ImageView等。 以上就是在Android Studio中自定义标题栏的步骤。 ### 回答2: 在Android应用程序中,标题栏是一个非常重要的UI元素,它包含了应用程序的标识、回退按钮和其他重要的导航元素。但是,Android应用程序也允许开发者通过自定义标题栏来增加应用程序的可操作性和美观性。这篇文章将介绍如何通过Android Studio来自定义标题栏。 首先,在Android Studio中创建一个新的Android项目,选择空活动模板。然后,在XML布局中添加一个水平线性布局,它将成为自定义标题栏的容器。往容器中添加几个控件,比如图标、标题、搜索框等。 接下来,在java代码中找到onCreate()方法,使用以下代码来隐藏系统默认的标题栏: ```java getSupportActionBar().hide(); ``` 然后,在style.xml文件中创建一个新的主题,并修改样式以使应用程序的标题栏适应自定义标题栏。修改以下属性: ```xml <item name="windowActionBar">false</item> <item name="android:windowNoTitle">true</item> <item name="android:windowFullscreen">false</item> ``` 然后,将自定义主题应用到AndroidManifest.xml文件中的应用程序标记上。代码如下: ```xml android:theme="@style/Theme.AppCompat.Light.NoActionBar" ``` 最后但并非最不重要的是,将自定义标题栏添加到每个活动中。可以通过继承Activity类,并在onCreate()方法中使用以下代码添加自定义标题栏: ```java requestWindowFeature(Window.FEATURE_NO_TITLE); setContentView(R.layout.activity_main); ``` 其中,先使用`requestWindowFeature(Window.FEATURE_NO_TITLE)`代码来隐藏默认的标题栏,然后使用`setContentView(R.layout.activity_main)`来添加自定义布局。 综上所述,通过以上简单的步骤,即可在Android Studio中自定义标题栏,以使应用程序更加个性化和专业化。 ### 回答3: Android Studio是一款流行的Android开发工具,可用于创建Android应用程序。标题栏Android应用程序中的重要组成部分,它可以显示应用程序的名称和其他相关信息。Android Studio提供了一些内置的标题栏风格,但是如果您想要定制自己的标题栏,您可以按照以下步骤进行操作。 1.在布局文件中添加自定义标题栏布局。您可以使用LinearLayout、RelativeLayout或任何其他布局。在布局中添加TextView、ImageView和其他控件以显示自定义标题栏中希望显示的任何内容。 2.启用应用程序主题的覆盖。为了覆盖原生主题中的标题栏,您需要将应用程序主题的风格设置为ThemeOverlay。在styles.xml文件中添加以下代码: <style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar"> <item name="android:windowContentOverlay">@null</item> </style> 3.将自定义标题栏与应用程序主题相关联。在清单文件中,将应用程序主题设置为新定义的主题。在application标记内添加以下代码: android:theme="@style/AppTheme" 4.在活动中设置另一个标题栏的布局。在活动的onCreate()方法中使用setContentView()方法设置自定义标题栏布局。例如: protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_custom_title_bar); } 现在您已经成功地为您的Android应用程序创建了自定义标题栏自定义标题栏可以使您的应用程序看起来更加专业和个性化。您可以根据自己的喜好和应用程序的要求进行处理。以上是有关Android Studio自定义标题栏的一些基本步骤,如果您感兴趣,建议您查阅其他资源以学习更多有关Android应用程序的开发技巧和技能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

帅次

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值