Android仿QQ长按弹出删除复制框

本文实例为大家分享了Android仿QQ长按删除弹出框的具体代码,供大家参考,具体内容如下

废话不说,先看一下效果图:

对于列表来说,如果想操作某个列表项,一般会采用长按弹出菜单的形式,默认的上下文菜单比较难看,而QQ的上下文菜单就人性化多了,整个菜单给用户一种气泡弹出的感觉,而且会显示在手指按下的位置,而技术实现我之前是使用popupWindow和RecyclerView实现的,上面一个RecyclerView,下面一个小箭头ImageView,但后来发现没有必要,而且可定制化也不高,还是使用多个TextView更好一点。

我封装了一下,只需要一个PopupList.java文件。源码放在了git上,git地址

使用方式,很简单:

只需要一个PopupList.java文件和几行代码,你就可以为ListView,GridView,甚至任意View绑定一个长按弹出的水平气泡式菜单。
你可以这样使用:

public class MainActivity extends AppCompatActivity {

 private Button btn_long_click;
 private ListView lv_main;
 private List<String> mDataList = new ArrayList<>();
 private ArrayAdapter<String> mDataAdapter;
 private List<String> popupMenuItemList = new ArrayList<>();

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  btn_long_click = (Button) findViewById(R.id.btn_long_click);
  lv_main = (ListView) findViewById(R.id.lv_main);
  mDataAdapter = new ArrayAdapter<>(this, android.R.layout.simple_expandable_list_item_1, mDataList);
  lv_main.setAdapter(mDataAdapter);

  popupMenuItemList.add(getString(R.string.copy));
  popupMenuItemList.add(getString(R.string.delete));
  popupMenuItemList.add(getString(R.string.share));
  popupMenuItemList.add(getString(R.string.more));
  PopupList popupList = new PopupList(this);
  popupList.bind(lv_main, popupMenuItemList, new PopupList.PopupListListener() {
   @Override
   public boolean showPopupList(View adapterView, View contextView, int contextPosition) {
    return true;
   }

   @Override
   public void onPopupListClick(View contextView, int contextPosition, int position) {
    Toast.makeText(MainActivity.this, contextPosition + "," + position, Toast.LENGTH_SHORT).show();
   }
  });

  PopupList normalViewPopupList = new PopupList(this);
  normalViewPopupList.bind(btn_long_click, popupMenuItemList, new PopupList.PopupListListener() {
   @Override
   public boolean showPopupList(View adapterView, View contextView, int contextPosition) {
    return true;
   }

   @Override
   public void onPopupListClick(View contextView, int contextPosition, int position) {
    Toast.makeText(MainActivity.this, contextPosition + "," + position, Toast.LENGTH_SHORT).show();
   }
  });

  lv_main.setOnItemClickListener(new AdapterView.OnItemClickListener() {
   @Override
   public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
    Toast.makeText(MainActivity.this, "onItemClicked:" + position, Toast.LENGTH_SHORT).show();
   }
  });
  btn_long_click.setOnClickListener(new View.OnClickListener() {
   @Override
   public void onClick(View v) {
    startActivity(new Intent(MainActivity.this, SecondaryActivity.class));
   }
  });
  getData();
 }

 private void getData() {
  for (int i = 0; i < 40; i++) {
   mDataList.add("No." + i);
  }
  mDataAdapter.notifyDataSetChanged();
 }

}

注意:`bind()`方法要求你的anchorView不能有touch和longClick/itemLongClick监听,因为`bind()`方法会主动给anchorView设置监听器:

mAnchorView.setOnTouchListener(new View.OnTouchListener() {
  @Override
  public boolean onTouch(View v, MotionEvent event) {
   mRawX = event.getRawX();
   mRawY = event.getRawY();
   return false;
  }
 });
 if (mAnchorView instanceof AbsListView) {
  ((AbsListView) mAnchorView).setOnItemLongClickListener(new AdapterView.OnItemLongClickListener() {
   @Override
   public boolean onItemLongClick(AdapterView<?> parent, View view, int position, long id) {
    if (mPopupListListener != null
      && !mPopupListListener.showPopupList(parent, view, position)) {
     return false;
    }
    mAdapterView = parent;
    mContextView = view;
    mContextPosition = position;
    showPopupListWindow();
    return true;
   }
  });
 } else {
  mAnchorView.setOnLongClickListener(new View.OnLongClickListener() {
   @Override
   public boolean onLongClick(View v) {
    if (mPopupListListener != null
      && !mPopupListListener.showPopupList(v, v, 0)) {
     return false;
    }
    mContextView = v;
    mContextPosition = 0;
    showPopupListWindow();
    return true;
   }
  });
 }

这就限制了anchorView不能再添加touch监听,不能添加longClick监听,如果你需要添加监听可以使用`showPopupListWindow`方法主动来显示弹出框,而不是使用`bind()`方法:

public class SecondaryActivity extends AppCompatActivity {

 private ListView lv_main;
 private List<String> mDataList = new ArrayList<>();
 private ArrayAdapter<String> mDataAdapter;
 private List<String> popupMenuItemList = new ArrayList<>();
 private float mRawX;
 private float mRawY;

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_secondary);
  lv_main = (ListView) findViewById(R.id.lv_main);
  mDataAdapter = new ArrayAdapter<>(this, android.R.layout.simple_expandable_list_item_1, mDataList);
  lv_main.setAdapter(mDataAdapter);

  popupMenuItemList.add(getString(R.string.copy));
  popupMenuItemList.add(getString(R.string.delete));
  popupMenuItemList.add(getString(R.string.share));
  popupMenuItemList.add(getString(R.string.more));

  lv_main.setOnTouchListener(new View.OnTouchListener() {
   @Override
   public boolean onTouch(View v, MotionEvent event) {
    mRawX = event.getRawX();
    mRawY = event.getRawY();
    return false;
   }
  });
  lv_main.setOnItemClickListener(new AdapterView.OnItemClickListener() {
   @Override
   public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
    Toast.makeText(SecondaryActivity.this, "onItemClicked:" + position, Toast.LENGTH_SHORT).show();
   }
  });
  lv_main.setOnItemLongClickListener(new AdapterView.OnItemLongClickListener() {
   @Override
   public boolean onItemLongClick(AdapterView<?> parent, View view, int position, long id) {
    PopupList popupList = new PopupList(view.getContext());
    popupList.showPopupListWindow(view, position, mRawX, mRawY, popupMenuItemList, new PopupList.PopupListListener() {
     @Override
     public boolean showPopupList(View adapterView, View contextView, int contextPosition) {
      return true;
     }

     @Override
     public void onPopupListClick(View contextView, int contextPosition, int position) {
      Toast.makeText(contextView.getContext(), contextPosition + "," + position, Toast.LENGTH_SHORT).show();
     }
    });
    return true;
   }
  });
  getData();
 }

 private void getData() {
  for (int i = 0; i < 40; i++) {
   mDataList.add("No." + i);
  }
  mDataAdapter.notifyDataSetChanged();
 }

}

更详细的配置:

  • popupList.setIndicatorView(View)
  • popupList.setIndicatorSize(int, int)
  • popupList.setNormalBackgroundColor(int)
  • popupList.setPressedBackgroundColor(int)
  • popupList.setNormalTextColor(int)
  • popupList.setPressedTextColor(int)
  • popupList.setDividerColor(int)
  • popupList.setTextSize(float)
  • popupList.setTextPadding(int, int, int, int)
  • popupList.setTextPaddingLeft(int)
  • popupList.setTextPaddingTop(int)
  • popupList.setTextPaddingRight(int)
  • popupList.setTextPaddingBottom(int)
  • popupList.setBackgroundCornerRadius(int)
  • popupList.setDividerWidth(int)
  • popupList.setDividerHeight(int)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android仿QQ、微信聊天界面长按提示框效果

    先来看看效果图 如何使用 示例代码 PromptViewHelper pvHelper = new PromptViewHelper(mActivity); pvHelper.setPromptViewManager(new ChatPromptViewManager(mActivity)); pvHelper.addPrompt(holder.itemView.findViewById(R.id.textview_content)); 使用起来还是很简单的 首先new一个PromptViewH

  • Android自定义TipView仿QQ长按后的提示窗口

    自定义view--TipView TipView其实就是类似QQ长按消息弹出来的横放的提示框. 通过看书和参考各位大神的博客(再次对大神表示恭敬),我用了一下午时间写完了这么一个view. 先来看图: 1 自定义TipView思路 1 首先我们考虑是继承View还是ViewGroup 其实TipView直观看更像是一个group,里面有子view.但其实我们并不需要继承ViewGroup,因为我们不用像LinearLayout那样在布局文件里面去添加子view,而且TipView的item我们用

  • Android仿QQ长按删除弹出框功能示例

    废话不说,先看一下效果图,如果大家感觉不错,请参考实现代码: 对于列表来说,如果想操作某个列表项,一般会采用长按弹出菜单的形式,默认的上下文菜单比较难看,而QQ的上下文菜单就人性化多了,整个菜单给用户一种气泡弹出的感觉,而且会显示在手指按下的位置,而技术实现我之前是使用popupWindow和RecyclerView实现的,上面一个RecyclerView,下面一个小箭头ImageView,但后来发现没有必要,而且可定制化也不高,还是使用多个TextView更好一点. 我封装了一下,只需要一个P

  • Android仿QQ长按弹出删除复制框

    本文实例为大家分享了Android仿QQ长按删除弹出框的具体代码,供大家参考,具体内容如下 废话不说,先看一下效果图: 对于列表来说,如果想操作某个列表项,一般会采用长按弹出菜单的形式,默认的上下文菜单比较难看,而QQ的上下文菜单就人性化多了,整个菜单给用户一种气泡弹出的感觉,而且会显示在手指按下的位置,而技术实现我之前是使用popupWindow和RecyclerView实现的,上面一个RecyclerView,下面一个小箭头ImageView,但后来发现没有必要,而且可定制化也不高,还是使用

  • Android组件实现长按弹出上下文菜单功能的方法

    本文实例讲述了Android组件实现长按弹出上下文菜单功能的方法.分享给大家供大家参考,具体如下: 简单组件长按弹出上下文菜单总结 第一步:在程序合适位置给一个控件注册上下文菜单 组件可以是按钮,文本框,还可以是列表条目,下以listView列表为例 ListView contentList=(ListView) findViewById(R.id.blackname_manager_listV); contentList.setAdapter(mListAdapter); registerFo

  • Android编程实现长按弹出选项框View进行操作的方法

    本文实例讲述了Android编程实现长按弹出选项框View进行操作的方法.分享给大家供大家参考,具体如下: 长按弹出选项框View进行操作 主要代码解释 private void showPopWindows(View v) { /** pop view */ View mPopView = LayoutInflater.from(this).inflate(R.layout.popup, null); final PopupWindow mPopWindow = new PopupWindow

  • JS实现的仿QQ空间图片弹出效果代码

    本文实例讲述了JS实现的仿QQ空间图片弹出效果代码.分享给大家供大家参考,具体如下: <script type="text/javascript"> function imageShow(which_click) { var image_path = which_click; //alert(image_path); var tag_top = Math.max(document.documentElement.scrollTop, document.body.scroll

  • Android仿微信支付密码弹出层功能

    预览 使用 这个弹出层是一个DialogFragment,逻辑都封装在其内部,使用起来很简单: Bundle bundle = new Bundle(); bundle.putString(PayFragment.EXTRA_CONTENT, "提现:¥ " + 100.00); PayFragment fragment = new PayFragment(); fragment.setArguments(bundle); fragment.setPaySuccessCallBack(

  • Android仿QQ个人标签添加与删除功能

    最近在公司项目开发中,有一个类似于QQ个人标签的需求要完成,具体包括个人标签的添加,删除,添加过程中重复的标签会提示用户,不能够进行添加.先给大家看一下效果图. 点击标签按钮,弹出标签选择的页面,显示所有的标签:点击全部标签里面的item,选择的标签会显示在上方:再次点击相同的标签进行添加,会提示用户"标签已存在,请重新添加":点击上方已经选择好的标签,进行删除操作 业务逻辑就是这样,下面是具体实现过程: 一.界面布局: <LinearLayout android:layout_

  • js实现仿qq消息的弹出窗效果

    在我们的日常开发中,或者生活中,经常需要用到弹出窗.这里我们就用js模拟一下qq消息一样的弹出窗,分享给大家供大家参考,具体内容如下 运行效果截图: 直接贴代码: <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gbk" /> <title>javaScript实现网页右下角弹出窗口代码</title> &l

  • Android仿网易严选底部弹出菜单效果

    在网易严选的看东西的时候在商品详情页里看到他的底部弹出菜单,本能反应是想用DottomSheetDialog或者PopupWindow来实现,可是发现实现不了他那种效果,于是就自己模仿一个像严选这样的底部弹出菜单. 不管是DottomSheetDialog或者PopupWindow他们的阴影背景都是全部覆盖的,这就造成除了菜单内容的View之外其他都是阴影的,而严选不是这样的.唠叨到此,首先展示效果图如下: 是不是还可以呢,由于代码量不多却注释详细,所以先贴出代码再一一详说: BottomPop

  • Android仿QQ首页ListView左滑置顶、删除功能

    Android 仿QQ首页ListView左滑置顶.删除等实现源码,具体内容如下 效果图 实现源码:package com.duguang.baseanimation.ui.listivew.deletelistview; import android.content.Context; import android.util.AttributeSet; import android.util.Log; import android.util.TypedValue; import android.

随机推荐