PopupWindow 实现仿微信底部弹出的分享菜单

来源:互联网 发布:郑州七中分校知乎 编辑:程序博客网 时间:2021/04/12 15:27

运用android PopupWindow实现从底部弹出或滑出选择菜单或窗口

没图没真相。。。




首先是Xml代码

<?xml version="1.0" encoding="utf-8"?>  
<RelativeLayout   
    xmlns:android="http://schemas.android.com/apk/res/android"  
    android:layout_width="fill_parent"  
    android:layout_height="wrap_content"  
    android:gravity="center_horizontal"  
    android:orientation="vertical"  
  >  
  
<LinearLayout   
    android:id="@+id/pop_layout"  
    android:layout_width="fill_parent"  
    android:layout_height="wrap_content"  
    android:gravity="center_horizontal"  
    android:orientation="vertical"  
    android:layout_alignParentBottom="true"  
     android:background="@drawable/exit_dialog_bg"  
     >  
  
      <LinearLayout android:layout_width="fill_parent"
          android:layout_height="wrap_content"
          android:orientation="horizontal">
          <LinearLayout 
              android:layout_width="wrap_content"
              android:layout_height="wrap_content"
              android:layout_marginLeft="20dp"
              android:orientation="vertical">
              <ImageButton android:layout_width="60dp"
                  android:layout_height="60dp"
                  android:src="@drawable/emoji_85"/>
              <TextView android:layout_width="wrap_content"
                  android:layout_height="wrap_content"
                  android:text="分享到微博"
                  android:textColor="@color/white"/>
          </LinearLayout>
          <LinearLayout 
              android:layout_width="wrap_content"
              android:layout_height="wrap_content"
              android:layout_marginLeft="20dp"
              android:orientation="vertical">
              <ImageView android:layout_width="60dp"
                  android:layout_height="60dp"
                  android:src="@drawable/emoji_86"/>
              <TextView android:layout_width="wrap_content"
                  android:layout_height="wrap_content"
                  android:text="收藏"
                  android:textColor="@color/white"/>
          </LinearLayout>
          <LinearLayout 
              android:layout_width="wrap_content"
              android:layout_height="wrap_content"
              android:layout_marginLeft="20dp"
              android:orientation="vertical">
              <ImageView android:layout_width="60dp"
                  android:layout_height="60dp"
                  android:src="@drawable/emoji_87"/>
              <TextView android:layout_width="wrap_content"
                  android:layout_height="wrap_content"
                  android:text="分享到微博"
                  android:textColor="@color/white"/>
          </LinearLayout>
      </LinearLayout>
      <LinearLayout android:layout_width="fill_parent"
          android:layout_height="wrap_content"
          android:orientation="horizontal">
          <LinearLayout 
              android:layout_width="wrap_content"
              android:layout_height="wrap_content"
              android:layout_marginLeft="20dp"
              android:orientation="vertical">
              <ImageView android:layout_width="60dp"
                  android:layout_height="60dp"
                  android:src="@drawable/emoji_85"/>
              <TextView android:layout_width="wrap_content"
                  android:layout_height="wrap_content"
                  android:text="分享到微博"
                  android:textColor="@color/white"/>
          </LinearLayout>
          <LinearLayout 
              android:layout_width="wrap_content"
              android:layout_height="wrap_content"
              android:layout_marginLeft="20dp"
              android:orientation="vertical">
              <ImageView android:layout_width="60dp"
                  android:layout_height="60dp"
                  android:src="@drawable/emoji_86"/>
              <TextView android:layout_width="wrap_content"
                  android:layout_height="wrap_content"
                  android:text="收藏"
                  android:textColor="@color/white"/>
          </LinearLayout>
          <LinearLayout 
              android:layout_width="wrap_content"
              android:layout_height="wrap_content"
              android:layout_marginLeft="20dp"
              android:orientation="vertical">
              <ImageView android:layout_width="60dp"
                  android:layout_height="60dp"
                  android:src="@drawable/emoji_87"/>
              <TextView android:layout_width="wrap_content"
                  android:layout_height="wrap_content"
                  android:text="分享到微博"
                  android:textColor="@color/white"/>
          </LinearLayout>
      </LinearLayout>
      <LinearLayout android:layout_width="fill_parent"
          android:layout_height="wrap_content"
          android:orientation="horizontal">
          <LinearLayout 
              android:layout_width="wrap_content"
              android:layout_height="wrap_content"
              android:layout_marginLeft="20dp"
              android:orientation="vertical">
              <ImageView android:layout_width="60dp"
                  android:layout_height="60dp"
                  android:src="@drawable/emoji_85"/>
              <TextView android:layout_width="wrap_content"
                  android:layout_height="wrap_content"
                  android:text="分享到微博"
                  android:textColor="@color/white"/>
          </LinearLayout>
          <LinearLayout 
              android:layout_width="wrap_content"
              android:layout_height="wrap_content"
              android:layout_marginLeft="20dp"
              android:orientation="vertical">
              <ImageView android:layout_width="60dp"
                  android:layout_height="60dp"
                  android:src="@drawable/emoji_86"/>
              <TextView android:layout_width="wrap_content"
                  android:layout_height="wrap_content"
                  android:text="收藏"
                  android:textColor="@color/white"/>
          </LinearLayout>
          <LinearLayout 
              android:layout_width="wrap_content"
              android:layout_height="wrap_content"
              android:layout_marginLeft="20dp"
              android:orientation="vertical">
              <ImageView android:layout_width="60dp"
                  android:layout_height="60dp"
                  android:src="@drawable/emoji_87"/>
              <TextView android:layout_width="wrap_content"
                  android:layout_height="wrap_content"
                  android:text="分享到微博"
                  android:textColor="@color/white"/>
          </LinearLayout>
      </LinearLayout>
   
  
    <Button  
        android:id="@+id/btn_cancel"  
       android:layout_marginLeft="20dip"  
       android:layout_marginRight="20dip"  
       android:layout_marginTop="15dip"   
       android:layout_marginBottom="15dip"  
       android:layout_width="fill_parent"  
       android:layout_height="wrap_content"  
       android:text="取消"  
       android:background="@drawable/btn_click"  
       android:textColor="#ffffff"  
       android:textStyle="bold"  
         
        />  
</LinearLayout>  
</RelativeLayout>  

然后是继承PopupWindow的类代码:

package com.stcyclub.testhtmlgetlinkman;




import android.app.Activity;  
import android.content.Context;  
import android.graphics.drawable.ColorDrawable;  
import android.view.LayoutInflater;  
import android.view.MotionEvent;  
import android.view.View;  
import android.view.View.OnClickListener;  
import android.view.View.OnTouchListener;  
import android.view.ViewGroup.LayoutParams;  
import android.widget.Button;  
import android.widget.PopupWindow;  
  
public class SelectPicPopupWindow extends PopupWindow {  
  
  
    private Button  btn_cancel;  
    private View mMenuView;  
  
    public SelectPicPopupWindow(Activity context,OnClickListener itemsOnClick) {  
        super(context);  
        LayoutInflater inflater = (LayoutInflater) context  
                .getSystemService(Context.LAYOUT_INFLATER_SERVICE);  
        mMenuView = inflater.inflate(R.layout.mult, null);  
       btn_cancel = (Button) mMenuView.findViewById(R.id.btn_cancel);  
        //取消按钮  
        btn_cancel.setOnClickListener(new OnClickListener() {  
  
            public void onClick(View v) {  
                //销毁弹出框  
                dismiss();  
            }  
        });  
        //设置按钮监听  
//        btn_pick_photo.setOnClickListener(itemsOnClick);  
//        btn_take_photo.setOnClickListener(itemsOnClick);  
        //设置SelectPicPopupWindow的View  
        this.setContentView(mMenuView);  
        //设置SelectPicPopupWindow弹出窗体的宽  
        this.setWidth(LayoutParams.FILL_PARENT);  
        //设置SelectPicPopupWindow弹出窗体的高  
        this.setHeight(LayoutParams.WRAP_CONTENT);  
        //设置SelectPicPopupWindow弹出窗体可点击  
        this.setFocusable(true);  
        //设置SelectPicPopupWindow弹出窗体动画效果  
        this.setAnimationStyle(R.anim.in_from_botton);  
        //实例化一个ColorDrawable颜色为半透明  
        ColorDrawable dw = new ColorDrawable(0xb0000000);  
        //设置SelectPicPopupWindow弹出窗体的背景  
        this.setBackgroundDrawable(dw);  
        //mMenuView添加OnTouchListener监听判断获取触屏位置如果在选择框外面则销毁弹出框  
        mMenuView.setOnTouchListener(new OnTouchListener() {  
              
            public boolean onTouch(View v, MotionEvent event) {  
                  
                int height = mMenuView.findViewById(R.id.pop_layout).getTop();  
                int y=(int) event.getY();  
                if(event.getAction()==MotionEvent.ACTION_UP){  
                    if(y<height){  
                        dismiss();  
                    }  
                }                 
                return true;  
            }  
        });  
  
    }  
  
}  

最后是activity代码,因为同时在练习其他知识,所有这块包含其他代码

  1. import android.app.Activity;  
  2. import android.os.Bundle;  
  3. import android.view.Gravity;  
  4. import android.view.View;  
  5. import android.view.View.OnClickListener;  
  6. import android.widget.TextView;  
  7.   
  8. public class MainActivity extends Activity {  
  9.   
  10.     //自定义的弹出框类  
  11.     SelectPicPopupWindow menuWindow;  
  12.       
  13.     @Override  
  14.     public void onCreate(Bundle savedInstanceState) {  
  15.         super.onCreate(savedInstanceState);  
  16.         setContentView(R.layout.activity_main);  
  17.         TextView tv = (TextView) this.findViewById(R.id.text);  
  18.         //把文字控件添加监听,点击弹出自定义窗口  
  19.         tv.setOnClickListener(new OnClickListener() {             
  20.             public void onClick(View v) {  
  21.                 //实例化SelectPicPopupWindow  
  22.                 menuWindow = new SelectPicPopupWindow(MainActivity.this, itemsOnClick);  
  23.                 //显示窗口  
  24.                 menuWindow.showAtLocation(MainActivity.this.findViewById(R.id.main), Gravity.BOTTOM|Gravity.CENTER_HORIZONTAL, 00); //设置layout在PopupWindow中显示的位置  
  25.             }  
  26.         });  
  27.     }  
  28.       
  29.     //为弹出窗口实现监听类  
  30.     private OnClickListener  itemsOnClick = new OnClickListener(){  
  31.   
  32.         public void onClick(View v) {  
  33.             menuWindow.dismiss();  
  34.             switch (v.getId()) {  
  35.             
  36.             default:  
  37.                 break;  
  38.             }  
  39.               
  40.                   
  41.         }  
  42.           
  43.     };  
  44.       
  45. }  

功能能并没有完成,但是框架就是这样搭建的!如果您想复制核能会有问题,因为图片,还有一些样式并不能放在这上面。希望能帮助到需要帮助的人!

11 0