1. android 侧滑菜单 有谁知道京东商城分类中的侧滑效果是怎样实现的呢希望可以分享一下代码。
这个我给你个代码 你看看主要通过FrameLayout实现的!!
2. android实现RecyclerView的Item侧滑菜单
1、引入组件
2、布局中添加组件
使用该组件替换普通的RecyclerView即可
3、activity中进行设置
3. itemtouchhelper实现recyclerview的侧滑菜单及处理item的子view点击事件
最近项目上要做聊天会话列表,需要侧滑菜单来实现删除,静音等操作,由于这一块儿没有太多经验,于是首先想到了Android API提供的itemtouchhelper。这个类,是用来实现item的拖动,滑动等效果的。怎么用呢,点开源码看一下,
最后一句关键,意思是大多数情况下,你只需要重写onChildDraw方法,并在里面实现你自己的行为即可。
然而,这个类默认效果是需要滑动整个item的宽度的,做侧滑菜单当然不需要滑动这么宽,何如?
此时,就要在继承自itemtouchhelper.callback的子类中的onchilddraw方法中自己定义滑动宽度并实现滑动效果了。
可以看到,该方法提供了viewholder,滑动距离dx等,通过viewholder可以拿到item中的任意子view,那么就可以自定义行为了。
然而,当你给item中的子view设置点击事件时,你会发现,手机点烂了也不会响应你的点击事件。这是因为点击事件的下发被阻止了,view接收不到事件。那只能另辟蹊径了。触摸事件会不会被阻止呢?试一下给recyclerview设置ItemTouchListener,在onInterceptTouchEvent方法中log一下,发现可以响应。那么另一个方法就来了,我们可以根据motionevent的点击位置,即x,y坐标来判断当前点击处于哪一个子view的范围,从而来响应它的点击。
可以看到,此方法提供了recyclerview,那就可以根据recyclerview拿到adapter,viewholder等,然后就可以做子view的点击响应了。
到此,功能基本算是实现了。这种方式有一个小问题,需要右滑隐藏菜单时,滑动距离要很大,基本等于item的宽度才行,总的来说体验不是很完美,有待改进。有想法的朋友欢迎留言一起交流。
4. Android开发中的侧滑菜单都是用slidingmenu实现的吗
如果是学习代码的话,建议还是学习官方的,不过SlidingMenu有很多功能,比如滑出菜单时控制后面的背景动不动,动多少,貌似Navigation Drawer的背景不能动的。开源项目被官方API取代是趋势,因为大家都觉得官方的接口用着放心嘛,但开源项目可能更灵活。
5. android中我使用了drawerlayout实现侧滑菜单,主界面是一个listview,为什么
给侧滑菜单布局添加属性android:clickable="true"
6. android怎么实现类似qq那样的右滑出现侧拉菜单
Android 实现类似QQ侧滑菜单,实现左右侧滑 源码。具有iOS 7/8 parallax effect 风格的侧边菜单,类似于最新版qq的菜单效果。ReisdeMenu 创意灵感来自于Dribbble1还有2,而这个是Android版的ResideMenu,在视觉效果上部分参考了iOS版的RESideMenu
7. 怎样做一个像知乎android版那样的侧滑菜单栏
您好,很高兴能帮助您
slide menu是实现这个效果比较简单的安卓开源库了,读一下readme就可以用了。
可以先不去了解如何实现。
你的采纳是我前进的动力,
记得好评和采纳,答题不易,互相帮助,
8. 怎样做一个像知乎android版那样的侧滑菜单栏
知乎这个用的是谷歌的v4包的drawerlayout吧,这个包默认就是新建project的时候就导入了的。用法很简单的, reference/android/support/v4/widget/DrawerLayout.html 这里面就有示例,也可以网络一下,根布局用drawerlayout,如果想要左边有drawer那么就在里面再写个子布局然后layout_gravity属性写成start,想在右边就是end就这样简单
9. android右边滑动式覆盖菜单是怎么实现的
android.support.v4.widget.DrawerLayout
系统的侧滑菜单 ,当然也有N多的开源的第三方项目比如SlidingMenu等 看你想要什么效果了。。
10. android 怎样让drawerlayout设置的侧滑菜单的内容充满屏幕
现在侧滑菜单使用很多,大都是通过SlidingMenu实现。现在也可以通过DrawerLayout
创建抽屉布局
frament_content.xml
[html] view plain
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<TextView
android:id="@+id/textView"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:textSize="25sp" />
</LinearLayout>
activity_main.xml
[html] view plain
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<!-- The main content view -->
<FrameLayout
android:id="@+id/content_frame"
android:layout_width="match_parent"
android:layout_height="match_parent" >
</FrameLayout>
<!-- The navigation view -->
<ListView
android:id="@+id/left_drawer"
android:layout_width="240dp"
android:layout_height="match_parent"
android:layout_gravity="start"
android:background="#ffffcc"
android:choiceMode="singleChoice"
android:divider="@android:color/transparent"
android:dividerHeight="0dp" >
</ListView>
</android.support.v4.widget.DrawerLayout>
然后新建一个类继承Fragment类
[java] view plain
/**
* ContentFragment.java
* 版权所有(C) 2015
* 创建者:cuiran 2015-1-3 下午3:25:44
*/
package com.cayden.drawerlayoutdemo;
import android.app.Fragment;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;
/**
* TODO
* @author cuiran
* @version 1.0.0
*/
public class ContentFragment extends Fragment {
private TextView textView;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.fragment_content, container, false);
textView = (TextView) view.findViewById(R.id.textView);
String text = getArguments().getString("text");
textView.setText(text);
return view;
}
}
完成Activity代码
[java] view plain
package com.cayden.drawerlayoutdemo;
import java.util.ArrayList;
import android.app.Activity;
import android.app.Fragment;
import android.app.FragmentManager;
import android.content.Intent;
import android.content.res.Configuration;
import android.net.Uri;
import android.os.Bundle;
import android.support.v4.app.ActionBarDrawerToggle;
import android.support.v4.widget.DrawerLayout;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ArrayAdapter;
import android.widget.ListView;
public class MainActivity extends Activity implements OnItemClickListener {
private DrawerLayout mDrawerLayout;
private ListView mDrawerList;
private ArrayList<String> menuLists;
private ArrayAdapter<String> adapter;
private ActionBarDrawerToggle mDrawerToggle;
private String mTitle;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mTitle = (String) getTitle();
mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
mDrawerList = (ListView) findViewById(R.id.left_drawer);
menuLists = new ArrayList<String>();
for (int i = 0; i < 5; i++)
menuLists.add("菜单0" + i);
adapter = new ArrayAdapter<String>(this,
android.R.layout.simple_list_item_1, menuLists);
mDrawerList.setAdapter(adapter);
mDrawerList.setOnItemClickListener(this);
mDrawerToggle = new ActionBarDrawerToggle(this, mDrawerLayout,
R.drawable.ic_drawer, R.string.drawer_open,
R.string.drawer_close) {
@Override
public void onDrawerOpened(View drawerView) {
super.onDrawerOpened(drawerView);
getActionBar().setTitle("请选择");
invalidateOptionsMenu(); // Call onPrepareOptionsMenu()
}
@Override
public void onDrawerClosed(View drawerView) {
super.onDrawerClosed(drawerView);
getActionBar().setTitle(mTitle);
invalidateOptionsMenu();
}
};
mDrawerLayout.setDrawerListener(mDrawerToggle);
//开启ActionBar上APP ICON的功能
getActionBar().setDisplayHomeAsUpEnabled(true);
getActionBar().setHomeButtonEnabled(true);
}
@Override
public boolean onPrepareOptionsMenu(Menu menu) {
boolean isDrawerOpen = mDrawerLayout.isDrawerOpen(mDrawerList);
menu.findItem(R.id.action_websearch).setVisible(!isDrawerOpen);
return super.onPrepareOptionsMenu(menu);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
//将ActionBar上的图标与Drawer结合起来
if (mDrawerToggle.onOptionsItemSelected(item)){
return true;
}
switch (item.getItemId()) {
case R.id.action_websearch:
Intent intent = new Intent();
intent.setAction("android.intent.action.VIEW");
Uri uri = Uri.parse("http://www..com");
intent.setData(uri);
startActivity(intent);
break;
}
return super.onOptionsItemSelected(item);
}
@Override
protected void onPostCreate(Bundle savedInstanceState) {
super.onPostCreate(savedInstanceState);
//需要将ActionDrawerToggle与DrawerLayout的状态同步
//将ActionBarDrawerToggle中的drawer图标,设置为ActionBar中的Home-Button的Icon
mDrawerToggle.syncState();
}
@Override
public void onConfigurationChanged(Configuration newConfig) {
super.onConfigurationChanged(newConfig);
mDrawerToggle.onConfigurationChanged(newConfig);
}
@Override
public void onItemClick(AdapterView<?> arg0, View arg1, int position,
long arg3) {
// 动态插入一个Fragment到FrameLayout当中
Fragment contentFragment = new ContentFragment();
Bundle args = new Bundle();
args.putString("text", menuLists.get(position));
contentFragment.setArguments(args);
FragmentManager fm = getFragmentManager();
fm.beginTransaction().replace(R.id.content_frame, contentFragment)
.commit();
mDrawerLayout.closeDrawer(mDrawerList);
}
}