为了让大家容易理解我做了一个简单的Demo,主布局main.xml里有一个TextView和一个Button,当点击Button,出现 Dialog,而这个Dialog的布局方式是我们在layout目录下定义的custom_dialog.xml文件(里面左右分布,左边 ImageView,右边TextView)。
效果图如下:
下面我将详细的说明Demo的实现过程:
1、新建一个 Android工程,我们命名为LayoutInflaterDemo.
2、修改main.xml布局,里面主要在 原来基础上增加了一个Button.代码如下:
[java] view plain copy
- <?xml version="1.0"
-
encoding=“utf-8”?>
-
<LinearLayout
-
xmlns:android=“http://schemas.android.com/apk/res/android”
-
android:orientation=“vertical”
-
android:layout_width=“fill_parent”
-
android:layout_height=“fill_parent”
-
>
-
<TextView
-
android:layout_width=“fill_parent”
-
android:layout_height=“wrap_content”
-
android:text=“@string/hello”
-
/>
-
<Button
-
android:id=“@+id/button”
-
android:layout_width=“wrap_content”
-
android:layout_height=“wrap_content”
-
android:text=“ShowCustomDialog”
-
/>
3.定义对话框的布局方式,我们在layout目录下,新建一个名为 custom_dialog.xml文件具体代码如下:
[java] view plain copy
- <?xml version="1.0"
-
encoding=“utf-8”?>
-
<LinearLayout
-
xmlns:android=“http://schemas.android.com/apk/res/android”
-
android:orientation=“horizontal”
-
android:layout_width=“fill_parent”
-
android:layout_height=“fill_parent”
-
android:padding=“10dp”
-
>
-
<ImageView android:id=“@+id/image”
-
android:layout_width=“wrap_content”
-
android:layout_height=“fill_parent”
-
android:layout_marginRight=“10dp”
-
/>
-
<TextView android:id=“@+id/text”
-
android:layout_width=“wrap_content”
-
android:layout_height=“fill_parent”
-
android:textColor=“#FFF”
-
/>
4.修改主程序LayouInflaterDemo.java代码如下:
[java] view plain copy
-
package com.android.tutor;
-
import android.app.Activity;
-
import android.app.AlertDialog;
-
import android.content.Context;
-
import android.os.Bundle;
-
import android.view.LayoutInflater;
-
import android.view.View;
-
import android.view.View.OnClickListener;
-
import android.widget.Button;
-
import android.widget.ImageView;
-
import android.widget.TextView;
-
public class LayoutInflaterDemo extends Activity implements
-
OnClickListener {
-
private Button button;
-
public void onCreate(Bundle savedInstanceState) {
-
super.onCreate(savedInstanceState);
-
setContentView(R.layout.main);
-
button = (Button)findViewById(R.id.button);
-
button.setOnClickListener(this);
-
}
-
@Override
-
public void onClick(View v) {
-
showCustomDialog();
-
}
-
public void showCustomDialog()
-
{
-
AlertDialog.Builder builder;
-
AlertDialog alertDialog;
-
Context mContext = LayoutInflaterDemo.this;
-
//下面俩种方法都可以
-
LayoutInflater inflater = getLayoutInflater();
-
LayoutInflater inflater = (LayoutInflater)
-
mContext.getSystemService(LAYOUT_INFLATER_SERVICE);
-
View layout = inflater.inflate(R.layout.custom_dialog,null);
-
TextView text = (TextView) layout.findViewById(R.id.text);
-
text.setText(“Hello, Welcome to Mr Wei’s blog!”);
-
ImageView image = (ImageView) layout.findViewById(R.id.image);
-
image.setImageResource(R.drawable.icon);
-
builder = new AlertDialog.Builder(mContext);
-
builder.setView(layout);
-
alertDialog = builder.create();
-
alertDialog.show();
-
}
-
}
5、最后执行之,点击Button,将得到上述效果。
上一节讲的是LayoutInflater 的 使用,而这一节我将讲一下MenuInflater ,顾名思义,LayoutInflater 是用来解析定义在layout 下的布局文件,那么MenuInflater 是不是用来解析定义在menu目录下的菜单布局文件呢? 恭喜你答对了!(*__*) 嘻嘻……
我们传统意义上 的定义菜单感觉比较繁琐,当我们使用MenuInflater 来生成菜单,你会发现是多么的爽朗,呵呵,我今天的小Demo,是定义四个菜单,并且实现了一个菜单事件。就是我们点击设置 (Setting )菜单,进入手机设置状态!下面看一下效果图:
下面是实现Demo 的详细步骤:
一、建立一个Android 工程我们命名为MenuInflaterDemo .
二、在res 目录下创建menu 目录,并且创建options_menu.xml (我们定义的菜单)文件,代码如下:
[java] view plain copy
- <?xml version="1.0" encoding="utf-8"?>
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
(img-YFqDgXoR-1715024261913)]
[外链图片转存中…(img-DAXommTH-1715024261913)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!