Android自定义顶部标题栏

作者:习惯了沉默012 时间:2023-02-21 19:03:47 

本文实例为大家分享了Android自定义顶部标题栏展示的具体代码,供大家参考,具体内容如下

Android自定义顶部标题栏

思路及实现步骤

1.定义标题栏布局
2.自定义TitleActivity控制标题栏按钮监听
3.在TitleActivity中实现标题栏以下内容切换

首先定义标题栏


<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:id="@+id/layout_titlebar"
 android:layout_width="match_parent"
 android:layout_height="52dp"
 android:background="#ed4255" >

<TextView
   android:id="@+id/text_title"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:ellipsize="marquee"
   android:gravity="center_horizontal|center"
   android:singleLine="true"
   android:text="标题栏"
   android:textColor="#ffffffff"
   android:textSize="20dp" />

<Button
   android:id="@+id/button_backward"
   android:layout_width="60dp"
   android:layout_height="match_parent"
   android:background="@drawable/title_button_selector"
   android:drawableLeft="@drawable/back_arrow"
   android:drawablePadding="6dp"
   android:ellipsize="end"
   android:gravity="center"
   android:onClick="onClick"
   android:paddingLeft="5dp"
   android:singleLine="true"
   android:text="返回"
   android:textColor="#ffffffff"
   android:textSize="18dp"
   android:visibility="invisible" />

<Button
   android:id="@+id/button_forward"
   android:layout_width="60dp"
   android:layout_height="match_parent"
   android:layout_alignParentRight="true"
   android:background="@drawable/title_button_selector"
   android:drawablePadding="6dp"
   android:ellipsize="end"
   android:gravity="center"
   android:onClick="onClick"
   android:paddingLeft="5dp"
   android:singleLine="true"
   android:text="提交"
   android:textColor="#ffffffff"
   android:textSize="18dp"
   android:visibility="invisible" />

</RelativeLayout>

定义控制标题栏按钮和标题栏以下内容的布局


<?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" >

<!-- Title -->

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

<FrameLayout
   android:id="@+id/layout_content"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:background="#fff" >
 </FrameLayout>

</LinearLayout>

注:此处使用 <include> 标签引入标题栏,且下方有定义一个空的FrameLayout的布局。

定义TitleActivity控制按钮及布局


package org.gaochun.widget;

import org.gaochun.ui.R;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup.LayoutParams;
import android.widget.Button;
import android.widget.FrameLayout;
import android.widget.TextView;
import android.widget.Toast;

/**
* @author gao_chun
* 自定义标题栏
*/
public class TitleActivity extends Activity implements OnClickListener{

//private RelativeLayout mLayoutTitleBar;
 private TextView mTitleTextView;
 private Button mBackwardbButton;
 private Button mForwardButton;
 private FrameLayout mContentLayout;

@Override
 protected void onCreate(Bundle savedInstanceState) {
   super.onCreate(savedInstanceState);
   setupViews();  //加载 activity_title 布局 ,并获取标题及两侧按钮
 }

private void setupViews() {
   super.setContentView(R.layout.activity_title);
   mTitleTextView = (TextView) findViewById(R.id.text_title);
   mContentLayout = (FrameLayout) findViewById(R.id.layout_content);
   mBackwardbButton = (Button) findViewById(R.id.button_backward);
   mForwardButton = (Button) findViewById(R.id.button_forward);
 }

/**
  * 是否显示返回按钮
  * @param backwardResid 文字
  * @param show true则显示
  */
 protected void showBackwardView(int backwardResid, boolean show) {
   if (mBackwardbButton != null) {
     if (show) {
       mBackwardbButton.setText(backwardResid);
       mBackwardbButton.setVisibility(View.VISIBLE);
     } else {
       mBackwardbButton.setVisibility(View.INVISIBLE);
     }
   } // else ignored
 }

/**
  * 提供是否显示提交按钮
  * @param forwardResId 文字
  * @param show true则显示
  */
 protected void showForwardView(int forwardResId, boolean show) {
   if (mForwardButton != null) {
     if (show) {
       mForwardButton.setVisibility(View.VISIBLE);
       mForwardButton.setText(forwardResId);
     } else {
       mForwardButton.setVisibility(View.INVISIBLE);
     }
   } // else ignored
 }

/**
  * 返回按钮点击后触发
  * @param backwardView
  */
 protected void onBackward(View backwardView) {
   Toast.makeText(this, "点击返回,可在此处调用finish()", Toast.LENGTH_LONG).show();
   //finish();
 }

/**
  * 提交按钮点击后触发
  * @param forwardView
  */
 protected void onForward(View forwardView) {
   Toast.makeText(this, "点击提交", Toast.LENGTH_LONG).show();
 }

//设置标题内容
 @Override
 public void setTitle(int titleId) {
   mTitleTextView.setText(titleId);
 }

//设置标题内容
 @Override
 public void setTitle(CharSequence title) {
   mTitleTextView.setText(title);
 }

//设置标题文字颜色
 @Override
 public void setTitleColor(int textColor) {
   mTitleTextView.setTextColor(textColor);
 }

//取出FrameLayout并调用父类removeAllViews()方法
 @Override
 public void setContentView(int layoutResID) {
   mContentLayout.removeAllViews();
   View.inflate(this, layoutResID, mContentLayout);
   onContentChanged();
 }

@Override
 public void setContentView(View view) {
   mContentLayout.removeAllViews();
   mContentLayout.addView(view);
   onContentChanged();
 }

/* (non-Javadoc)
  * @see android.app.Activity#setContentView(android.view.View, android.view.ViewGroup.LayoutParams)
  */
 @Override
 public void setContentView(View view, LayoutParams params) {
   mContentLayout.removeAllViews();
   mContentLayout.addView(view, params);
   onContentChanged();
 }

/* (non-Javadoc)
  * @see android.view.View.OnClickListener#onClick(android.view.View)
  * 按钮点击调用的方法
  */
 @Override
 public void onClick(View v) {

switch (v.getId()) {
     case R.id.button_backward:
       onBackward(v);
       break;

case R.id.button_forward:
       onForward(v);
       break;

default:
       break;
   }
 }
}

MainActivity中调用时直接 extends TitleActivity 使用之前在TitleActivity中定义的方法

Android自定义顶部标题栏

来源:https://blog.csdn.net/huakaihualuo012/article/details/78431599

标签:Android,标题栏
0
投稿

猜你喜欢

  • C#双缓冲技术实例详解

    2023-02-02 15:56:37
  • java线程同步操作实例详解

    2023-11-13 14:19:08
  • Java8 用Lambda表达式给List集合排序的实现

    2023-02-05 17:27:09
  • Android 静默安装实现方法

    2021-08-04 05:11:25
  • C#将PPT文件转换成PDF文件

    2022-09-08 20:33:21
  • Java运行时数据区概述详解

    2023-10-08 07:00:10
  • Java规则引擎Easy Rules的使用介绍

    2023-05-04 01:42:57
  • Spring security权限配置与使用大全

    2022-03-05 15:37:21
  • 详解Kotlin中的面向对象(二)

    2021-12-29 03:10:00
  • Android编程获取网络连接方式及判断手机卡所属运营商的方法

    2023-09-18 21:54:14
  • C#中神器类BlockingCollection的实现详解

    2022-10-13 07:41:02
  • android中DatePicker和TimePicker的使用方法详解

    2021-08-28 14:45:13
  • IDEA中JetBrains Mono字体的正确安装姿势

    2022-03-12 12:21:40
  • springboot 如何设置端口号和添加项目名

    2022-01-11 07:31:12
  • C#实现将记事本中的代码编译成可执行文件的方法

    2022-03-05 02:17:53
  • 基于C#实现的屏幕指定区域截屏代码

    2021-12-31 19:42:09
  • jbuilder2006连接sqlserver2000的方法

    2022-08-21 14:20:09
  • Java Http请求方式之RestTemplate常用方法详解

    2021-06-29 02:32:51
  • android自定义View实现简单五子棋游戏

    2022-09-16 14:52:30
  • java中javamail收发邮件实现方法

    2022-12-15 02:03:03
  • asp之家 软件编程 m.aspxhome.com