Android仿微信长按菜单效果

本文实例为大家分享了Android仿微信长按菜单展示的具体代码,供大家参考,具体内容如下

FloatMenu

A menu style pop-up window that mimics WeChat。仿微信的长按菜单。

效果如下

引入方法:

Github地址:https://github.com/JavaNoober/FloatMenu

dependencies {
  ....

  compile 'com.noober.floatmenu:common:1.0.2'
}

使用说明

使用方法1:

Activity 重写dispatchTouchEvent,并且新建一个Point对象,show的时候传入改对象

 private Point point = new Point();
 @Override
 public boolean dispatchTouchEvent(MotionEvent ev) {
  if(ev.getAction() == MotionEvent.ACTION_DOWN){
   point.x = (int) ev.getRawX();
   point.y = (int) ev.getRawY();
  }
  return super.dispatchTouchEvent(ev);
 }

调用:

 listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
  @Override
  public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
   FloatMenu floatMenu = new FloatMenu(MainActivity.this);
   floatMenu.items("菜单1", "菜单2", "菜单3");
   floatMenu.show(point);
  }
 });

使用方法2:

不需要重写dispatchTouchEvent,但是需要在初始化的时候传入所点击的view,floatment初始化必须在点击事件外部

 final FloatMenu floatMenu = new FloatMenu(this, btn1);
  floatMenu.items("菜单1", "菜单2", "菜单3");
  floatMenu.setOnItemClickListener(new FloatMenu.OnItemClickListener() {
   @Override
   public void onClick(View v, int position) {
    Toast.makeText(MainActivity.this, "菜单"+position, Toast.LENGTH_SHORT).show();
   }
  });

设置菜单的方式:

1.代码设置

floatMenu.items("菜单1", "菜单2", "菜单3");
  ...
  List<String> list = new ArrayList<>();
  list.add("菜单1"); list.add("菜单2"); list.add("菜单3");
  floatMenu.items(list);

2.menu.xml设置

<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">
   <item app:menu_title="Send to Chat" app:icon = "@drawable/brush"></item>
   <item
    app:menu_title="Add to Favorites" app:icon = "@drawable/barrage"/>
   <item
    app:menu_title="Delete" app:icon = "@drawable/clock"/>
   <item
    app:menu_title="More" app:icon = "@drawable/collection"/>

</menu>

 floatMenu.inflate(R.menu.popup_menu);

方法都提供参数设置菜单的宽度:

public void items(List<MenuItem> itemList, int itemWidth)
public void items(int itemWidth, String... items)
public void inflate(int menuRes, int itemWidth)

创建菜单:

注意点:

显示floatmenu有两种方法:

floatmenu.show(point)与floatmenu.show()的区别

区别在于,创建floatmenu对象的位置,如果使用第2种方法,创建floatmenu必须在点击事件的外面

第一种则没有这种限制,如下所示:

final FloatMenu floatMenu = new FloatMenu(this, btn2);
floatMenu.inflate(R.menu.popup_menu);
floatMenu.setOnItemClickListener(new FloatMenu.OnItemClickListener() {
 @Override
 public void onClick(View v, int position) {
  Toast.makeText(MainActivity.this, "菜单"+position, Toast.LENGTH_SHORT).show();
 }
});

listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
  @Override
  public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
   FloatMenu floatMenu = new FloatMenu(MainActivity.this);
   floatMenu.items("菜单1", "菜单2", "菜单3");
   floatMenu.show(point);
  }
 });

new FloatMenu(this, view) 与 new FloatMenu(this)区别

使用第二种方法创建对象在,必须重写dispatchTouchEvent

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

您可能感兴趣的文章:

  • Android仿微信菜单(Menu)(使用C#和Java分别实现)
  • Android仿微信顶/底部菜单栏效果
  • Android仿微信滑动弹出编辑、删除菜单效果、增加下拉刷新功能
  • Android仿微信底部菜单栏功能显示未读消息数量
  • Android开发之微信底部菜单栏实现的几种方法汇总
  • Android开发Popwindow仿微信右上角下拉菜单实例代码
  • android自定义popupwindow仿微信右上角弹出菜单效果
  • Android中微信小程序开发之弹出菜单
  • Android制作微信app顶部menu菜单(ActionBar)
  • Android仿微信底部菜单栏效果
(0)

相关推荐

  • Android中微信小程序开发之弹出菜单

    先给大家展示下效果图,具体效果图如下所示: 具体代码如下所示: 1.index.js //index.js //获取应用实例 var app = getApp() Page({ data: { isPopping: false,//是否已经弹出 animationPlus: {},//旋转动画 animationcollect: {},//item位移,透明度 animationTranspond: {},//item位移,透明度 animationInput: {},//item位移,透明度

  • android自定义popupwindow仿微信右上角弹出菜单效果

    微信右上角的操作菜单看起来很好用,就照着仿了一下,不过是旧版微信的,手里刚好有一些旧版微信的资源图标,给大家分享一下. 不知道微信是用什么实现的,我使用popupwindow来实现,主要分为几块内容: 1.窗口布局文件:popwin_share.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com

  • Android开发之微信底部菜单栏实现的几种方法汇总

     实现方式 实现的方式有很多种 这里总结最常见的几种方式,以后再添加其他的. viewPager + RadioGroup viewPager + FragmentTabHost viewpager +TabLayout viewPager+RadioGroup 感觉这是最简单的一个了,我也就不贴代码 说说我理解的思路吧 通过给pager 和RadioGroup 添加监听,监听两个控件的变化 实现联动 当viewPager的显示pager改变就会触发监听 ,在监听中选中对应的RadioButto

  • Android开发Popwindow仿微信右上角下拉菜单实例代码

    先给大家看下效果图: MenuPopwindow: package com.cloudeye.android.cloudeye.view; import android.app.Activity; import android.content.Context; import android.graphics.drawable.ColorDrawable; import android.view.LayoutInflater; import android.view.View; import an

  • Android制作微信app顶部menu菜单(ActionBar)

    使用微信APP的小伙伴对于微信的ActionBar一定有印象,今天就带领大家一起实现以下这个效果. 第一步打开我们的开发工具,这里我使用的是Eclipse+ADT插件,然后创建我们的工程,这里选择Android的最低版本号为3.0或以上. 然后开始我们的"抄袭",首先打开我们微信,我们看到,顶部标题部分,分为左右两部分,左侧为"微信"两字,右侧则为搜索按钮+更多按钮,点击搜索按钮,会出现一个文本输入框.点击更多按钮,则会出现隐藏的menu菜单,分为:添加好友.发起群

  • Android仿微信底部菜单栏功能显示未读消息数量

    底部菜单栏很重要,我看了一下很多应用软件都是用了底部菜单栏,这里使用了tabhost做了一种通用的(就是可以像微信那样显示未读消息数量的,虽然之前也做过但是layout下的xml写的太臃肿,这里去掉了很多不必要的层,个人看起来还是不错的,所以贴出来方便以后使用). 先看一下做出来之后的效果: 以后使用的时候就可以换成自己项目的图片和字体了,主框架不用变哈哈, 首先是要布局layout下xml文件 main.xml: <?xml version="1.0" encoding=&qu

  • Android仿微信顶/底部菜单栏效果

    本文要实现仿微信微信底部菜单栏+顶部菜单栏,采用ViewPage来做,每一个page对应一个XML,当手指在ViewPage左右滑动时,就相应显示不同的page(其实就是xml)并且同时改变底部菜单按钮的图片变暗或变亮,同时如果点击底部菜单按钮,左右滑动page(其实就是xml)并且改变相应按钮的亮度. 一.布局 1.顶部菜单布局,命名为top_layout.xml <?xml version="1.0" encoding="utf-8"?> <R

  • Android仿微信菜单(Menu)(使用C#和Java分别实现)

    本篇是对安卓菜单使用编程方式实现,当然可以使用XML的方式完成同样的功能,基本Java和C#写法都是一致的,所以使用XML的方式在本篇中使用Java演示,需要注意的是,对于如果不是VS开发的话,那么资源文件名称必须以小写开头,否则会报错. 运行效果 C#实现 using Android.App; using Android.OS; using Android.Views; using Android.Widget; namespace MenuDemo { [Activity(Label = "

  • Android仿微信滑动弹出编辑、删除菜单效果、增加下拉刷新功能

    如何为不同的list item呈现不同的菜单,本文实例就为大家介绍了Android仿微信或QQ滑动弹出编辑.删除菜单效果.增加下拉刷新等功能的实现,分享给大家供大家参考,具体内容如下 效果图: 1. 下载开源项目,并将其中的liberary导入到自己的项目中: 2. 使用SwipeMenuListView代替ListView,在页面中布局: <android.support.v4.widget.SwipeRefreshLayout android:id="@+id/swipeRefresh

  • Android仿微信底部菜单栏效果

    前言 在市面上,大多数的APP都需要通过底部菜单栏来将程序的功能进行分类整理,通常都是分为3-5个大模块,从而正确有效地引导用户去使用我们的APP.实现底部菜单栏的方法也有很多种. 1.仿微信底部菜单栏(ViewPager+ImagerView+TextView) ......(其他方式后续会补充) 效果预览 首先来个开胃菜,看看实现效果: 先贴出项目所需的资源文件,这些可随个人自由更改颜色和文字 colors.xml <color name="bg_line_light_gray&quo

随机推荐