日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > Android >内容正文

Android

Android 实现布局动态加载

發布時間:2025/6/15 Android 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Android 实现布局动态加载 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Android 動態加載布局

通過使用LayoutInflater 每次點擊按鈕時候去讀取布局文件,然后找到布局文件里面的各個VIEW 操作完VIEW 后加載進我們setContentView 方面里面的要放的布局文件里面,每次動態加載文件必需 調用 removeAllViews方法,清除之前的加載進來的 View 。是不是很簡單?當然動態加載VIEW 還有許多種方法,多嘗試不同寫法。可能會領會不一樣的心得,祝你早上掌握android 的開發技術。 主要原理:在一個分割出來的大的Layout中(如圖中的白色區域),使用layout.removeAllViews();和layout.addView();實現動態加載,其中要使用的LayoutInflater等。

首先,我們先把界面的框架圖畫出來,示意圖如下:

中間白色部門是一個線性布局文件,我喜歡在畫圖的時候用不同的顏色將一塊布局標示出來,方便查看。布局文件代碼如下:

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


<LinearLayoutandroid:orientation="horizontal"
android:layout_width="wrap_content" android:layout_height="wrap_content">
<Buttonandroid:text="加載ListView" android:id="@+id/Button01"
android:layout_width="wrap_content" android:layout_height="wrap_content">
</Button>
<Buttonandroid:text="加載另外一個頁面" android:id="@+id/Button02"
android:layout_width="wrap_content" android:layout_height="wrap_content"></Button>
</LinearLayout>
<LinearLayoutandroid:id="@+id/LinearLayout01" android:background="#FFFFFF"
android:layout_width="fill_parent" android:layout_height="fill_parent"></LinearLayout>
</LinearLayout>

從上面的效果圖可以看出,那塊白色的線性布局是用來動態加載傳進來的布局文件。好了,我們就來做如果把布局文件動態的加載進來。下面我們一步一步來實現這個效果,首先,先把需要的 XML 勾畫出來,分為步驟如下。

  • 新建一個布局用來存放 ListView 頁面,代碼如下:
    <?xml version="1.0" encoding="UTF-8"?>
    <LinearLayout android:id="@+id/layout"
    android:layout_width="fill_parent" android:layout_height="fill_parent"
    xmlns:android="http://schemas.android.com/apk/res/android">
    <ListViewandroid:id="@+id/ListView01" android:layout_width="wrap_content"
    android:layout_height="wrap_content"></ListView>
    </LinearLayout>
  • 新建一個 ListView 每一行數據的樣式,代碼如下:
    <?xml version="1.0" encoding="UTF-8"?>
    <LinearLayout android:id="@+id/LinearLayout01"
    android:layout_width="fill_parent" android:layout_height="fill_parent"
    xmlns:android="http://schemas.android.com/apk/res/android">
    <TextViewandroid:text="@+id/TextView01" android:id="@+id/TextView01"
    android:layout_width="wrap_content" android:layout_height="wrap_content"></TextView>
    </LinearLayout>
  • 新建另外一個頁面,用來區分此頁面是動態加載的,代碼如下:
    <?xml version="1.0" encoding="UTF-8"?>
    <LinearLayout android:id="@+id/hellolayout"
    android:layout_width="fill_parent" android:layout_height="fill_parent"
    xmlns:android="http://schemas.android.com/apk/res/android">
    <TextViewandroid:text="HELLO"
    android:layout_width
    ="wrap_content" android:layout_height="wrap_content"></TextView>
    </LinearLayout>
  • 實現ListView 的添充數據,這里不詳細介紹如何填充ListView 每行數據,有不解的朋友可以回頭看我寫的文章:點擊這里 ,代碼如下:
    package com.terry;

    import java.util.ArrayList;
    import java.util.HashMap;

    import android.content.Context;
    import android.view.LayoutInflater;
    import android.view.View;
    import android.view.ViewGroup;
    import android.widget.BaseAdapter;
    import android.widget.TextView;

    public class listAdapterextends BaseAdapter {

    ArrayList
    <HashMap<String, Object>> list= new ArrayList<HashMap<String, Object>>();

    private LayoutInflater inflater;
    public listAdapter(Context contex)
    {
    inflater
    =LayoutInflater.from(contex);
    HashMap
    <String, Object> map=new HashMap<String, Object>();
    for (int i= 0; i< 10; i++) {
    map.put(
    "name","例子");
    list.add(map);
    }

    }

    @Override
    public int getCount() {
    // TODO Auto-generated method stub
    return list.size();
    }

    @Override
    public Object getItem(int position) {
    // TODO Auto-generated method stub
    return list.get(position);
    }

    @Override
    public long getItemId(int position) {
    // TODO Auto-generated method stub
    return position;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
    // TODO Auto-generated method stub
    final viewHolder myHolder;
    if (convertView==null) {
    myHolder
    =new viewHolder();
    convertView
    =inflater.inflate(R.layout.list_view_row,null);
    myHolder.tv
    =(TextView)convertView.findViewById(R.id.TextView01);
    convertView.setTag(myHolder);
    }
    else
    {
    myHolder
    =(viewHolder)convertView.getTag();
    }
    myHolder.tv.setText(list.get(position).get(
    "name").toString());
    return convertView;
    }

    }
  • 項目大綱如下圖:
  • 好了,到此我們的準備工作就己經完成,接下來就是要教大家如何實現動態加載上面所畫的布局頁面了,先看一下效果圖:

    點擊第一個按鈕


    點擊第二個按鈕
  • 動態加載代碼如下:
    package com.terry;

    import android.app.Activity;
    import android.graphics.Color;
    import android.os.Bundle;
    import android.view.LayoutInflater;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.widget.Button;
    import android.widget.LinearLayout;
    import android.widget.ListView;
    import android.widget.TextView;

    public class dynaActivityextends Activity {
    /** Called when the activity is first created.*/
    @Override
    public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    final LayoutInflater inflater= LayoutInflater.from(this);
    Button btn
    = (Button) findViewById(R.id.Button01);
    Button btn2
    = (Button) findViewById(R.id.Button02);
    final LinearLayout lin= (LinearLayout) findViewById(R.id.LinearLayout01);
    btn.setOnClickListener(
    new OnClickListener() {

    @Override
    public void onClick(View v) {
    // TODO Auto-generated method stub
    LinearLayout layout = (LinearLayout) inflater.inflate(
    R.layout.listview,
    null).findViewById(R.id.layout);
    ListView lv
    =(ListView)layout.getChildAt(0);
    lv.setAdapter(
    new listAdapter(dynaActivity.this));
    lin.removeAllViews();
    lin.addView(layout);
    }
    });

    btn2.setOnClickListener(
    new OnClickListener() {

    @Override
    public void onClick(View v) {
    // TODO Auto-generated method stub
    LinearLayout layout = (LinearLayout) inflater.inflate(
    R.layout.hello,
    null).findViewById(R.id.hellolayout);
    TextView lv
    =(TextView)layout.getChildAt(0);
    lv.setTextColor(Color.RED);
    lin.removeAllViews();
    lin.addView(layout);
    }
    });
    }
    }

Tip:因為是基于VIEW 操作,因此你可以用 Animation 的動畫效果使其更換界面更為自然,觀賞性更強。

總結

以上是生活随笔為你收集整理的Android 实现布局动态加载的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。