为了让大家容易理解我做了一个简单的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"?>
最后
总之啊,家里没矿的同学们,如果你们想以后的日子过得好一些,多想想你们的业余时间怎么安排吧;
技术方面的提升肯定是重中之重,但是技术外的一些“软实力”也不能完全忽视,很多时候升职确实是因为你的技术足够强,但也与你的“软实力”密切相关
在这我也分享一份大佬自己收录整理的 Android学习PDF+架构视频+面试文档+源码笔记 ,还有高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料这些都是我闲暇还会反复翻阅并给下属员工学习的精品资料。在脑图中,每个知识点专题都配有相对应的实战项目,可以有效的帮助大家掌握知识点。
总之也是在这里帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习


相信自己,没有做不到的,只有想不到的
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!
图中,每个知识点专题都配有相对应的实战项目,可以有效的帮助大家掌握知识点。
总之也是在这里帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习
[外链图片转存中…(img-TkYdUdyv-1714707362308)]
[外链图片转存中…(img-EnWydjui-1714707362308)]
相信自己,没有做不到的,只有想不到的
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!
1641

被折叠的 条评论
为什么被折叠?



