• Android listview 制作表格样式+由下往上动画弹出效果实现


    效果是这样的:点击按下弹出表格的按钮,会由下往上弹出右边的列表,按下返回按钮就由上往下退出界面。

    布局文件:

    activity_main.xml

    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent" >
    
        <Button
            android:id="@+id/btnPopup"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentBottom="true"
            android:layout_centerHorizontal="true"
            android:background="@drawable/bg"
            android:layout_marginLeft="8dp"
            android:layout_marginRight="8dp"
            android:layout_marginBottom="8dp"
            android:textColor="@color/white"
            android:text="按下弹出表格" />
    
      
        <LinearLayout
            android:id="@+id/ll_popupLayout"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_alignParentBottom="true"
            android:visibility="gone" >
    
            <include layout="@layout/business_list" />
        </LinearLayout>
    
    </RelativeLayout>

    /Demo1/res/layout/business_list_item.xml

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="300dp"
        android:layout_height="wrap_content"
        android:layout_gravity="center_horizontal"
        android:orientation="horizontal" >
    
        <TextView
            android:id="@+id/tv_business"
            android:layout_width="wrap_content"
            android:layout_height="40dp"
            android:layout_weight="1"
            android:gravity="center"
            android:text="@string/tv_business"
            android:textColor="#ff000000"
            android:textSize="15sp" />
    
        <TextView
            android:id="@+id/tv_business_pay"
            android:layout_width="90dp"
            android:layout_height="40dp"
            android:layout_marginLeft="9dp"
            android:layout_marginRight="9dp"
            android:gravity="center"
            android:text="@string/tv_business_pay"
            android:textColor="#ff000000"
            android:textSize="15sp" />
    
    </LinearLayout>

    /Demo1/res/layout/business_list.xml

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@+id/ll_popupLayout"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="#ffffff"
        android:orientation="vertical" >
    
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center_horizontal"
            android:layout_marginBottom="5dp"
            android:layout_marginTop="5dp"
            android:text="已开通查分业务列表"
            android:textColor="#ff000000"
            android:textSize="15sp" />
    
        <FrameLayout
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1" >
    
            <LinearLayout
                android:layout_width="300dp"
                android:layout_height="wrap_content"
                android:layout_gravity="center_horizontal"
                android:background="@drawable/banner_bg"
                android:orientation="horizontal" >
    
                <TextView
                    android:id="@+id/tv_business"
                    android:layout_width="wrap_content"
                    android:layout_height="40dp"
                    android:layout_weight="1"
                    android:gravity="center"
                    android:text="@string/tv_business"
                    android:textColor="#ff000000"
                    android:textSize="15sp" />
    
                <TextView
                    android:id="@+id/tv_business_pay"
                    android:layout_width="90dp"
                    android:layout_height="40dp"
                    android:layout_marginLeft="9dp"
                    android:layout_marginRight="9dp"
                    android:gravity="center"
                    android:text="@string/tv_business_pay"
                    android:textColor="#ff000000"
                    android:textSize="15sp" />
            </LinearLayout>
    
            <ListView
                android:id="@+id/lv_business"
                android:layout_width="300dp"
                android:layout_height="match_parent"
                android:layout_gravity="center_horizontal"
                android:layout_marginTop="40dp"
                android:background="@drawable/score_list_bg"
                android:cacheColorHint="@color/transparent"
                android:divider="@drawable/horizontal_line"
                android:listSelector="@color/transparent" />
    
            <ImageView
                android:layout_width="wrap_content"
                android:layout_height="match_parent"
                android:layout_gravity="center_horizontal"
                android:layout_marginBottom="2dp"
                android:layout_marginLeft="50dp"
                android:layout_marginTop="2dp"
                android:background="@drawable/vertical_line" />
        </FrameLayout>
    
        <Button
            android:id="@+id/btnBack"
            android:layout_width="80dp"
            android:layout_height="48dp"
            android:layout_gravity="center_horizontal"
            android:layout_marginBottom="5dp"
            android:layout_marginTop="5dp"
            android:background="@drawable/back_btn_bg"
            android:text="返回"
            android:textColor="#ffffff" />
    
    </LinearLayout>

    动画文件:

     /Demo1/res/anim/score_business_query_enter.xml

    <?xml version="1.0" encoding="utf-8"?>
    <set xmlns:android="http://schemas.android.com/apk/res/android">
        
        <translate
            android:fromYDelta="100%p"      
            android:duration="600"
            />
    </set>

    /Demo1/res/anim/score_business_query_exit.xml

    <?xml version="1.0" encoding="utf-8"?>
    <set xmlns:android="http://schemas.android.com/apk/res/android">
         
          <translate
              android:toYDelta="100%p"
              android:duration="600"   
              />
    </set>

    Acitivity

    package com.wwj.demo1;
    
    import java.util.ArrayList;
    import java.util.HashMap;
    import java.util.List;
    import java.util.Map;
    
    import android.app.Activity;
    import android.os.Bundle;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.view.animation.Animation;
    import android.view.animation.AnimationUtils;
    import android.widget.Button;
    import android.widget.LinearLayout;
    import android.widget.ListView;
    import android.widget.SimpleAdapter;
    
    public class MainActivity extends Activity {
    
        Button btnPopup;
        Button btnBack;
        ListView listView;
        LinearLayout ll_Popup;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
    
            btnPopup = (Button) findViewById(R.id.btnPopup);
    
            ll_Popup = (LinearLayout) findViewById(R.id.ll_popupLayout);
            // 加载动画
            final Animation animation1 = AnimationUtils.loadAnimation(this,
                    R.anim.score_business_query_enter);
            final Animation animation2 = AnimationUtils.loadAnimation(this,
                    R.anim.score_business_query_exit);
            btnPopup.setOnClickListener(new OnClickListener() {
    
                @Override
                public void onClick(View arg0) {
                    ll_Popup.setVisibility(View.VISIBLE);    // 显示布局
                    ll_Popup.startAnimation(animation1);    // 开始动画
    
                }
            });
    
            btnBack = (Button) findViewById(R.id.btnBack);
            btnBack.setOnClickListener(new OnClickListener() {
    
                @Override
                public void onClick(View v) {
                    // TODO Auto-generated method stub
                    ll_Popup.setVisibility(View.GONE);     // 取出布局
                    ll_Popup.startAnimation(animation2); // 开始退出动画
                }
            });
    
            setListAdapter();
    
        }
    
        /**
         * 填充列表
         */
        private void setListAdapter() {
    
            List<Map<String, String>> data = new ArrayList<Map<String, String>>();
    
            // 测试数据
            for (int i = 0; i < 10; i++) {
                Map<String, String> map = new HashMap<String, String>();
                map.put("tv_business", "武汉中考查询测试");
                map.put("tv_business_pay", "0元/次");
                data.add(map);
            }
    
            listView = (ListView) findViewById(R.id.lv_business);
            SimpleAdapter adapter = new SimpleAdapter(this, data,
                    R.layout.business_list_item, new String[] { "tv_business",
                            "tv_business_pay" }, new int[] { R.id.tv_business,
                            R.id.tv_business_pay });
            listView.setAdapter(adapter);
        }
    }

    文章转载于:http://blog.csdn.net/wwj_748/article/details/9854655

  • 相关阅读:
    音频设备的接线图了解
    学习感悟
    音频系统操作文档
    通讯型高清视频会议摄像机
    网络继电器控制板
    linx命令 1
    28岁应该怎么样规划职业?
    Python的数值类型与序列类型
    Mysql数据库笔记
    内部类
  • 原文地址:https://www.cnblogs.com/NeilLing/p/4031532.html
Copyright © 2020-2023  润新知