文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Android学习教程之分类侧滑菜单(5)

2022-06-06 05:48

关注

本文实例为大家分享了Android分类侧滑菜单的制作方法,供大家参考,具体内容如下

classificmenuActivity.java代码:


package com.siso.crazyworld;
import android.animation.Animator;
import android.content.res.Configuration;
import android.graphics.Color;
import android.graphics.drawable.BitmapDrawable;
import android.os.Bundle;
import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.ActionBarActivity;
import android.support.v7.app.ActionBarDrawerToggle;
import android.support.v7.widget.Toolbar;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.ViewAnimationUtils;
import android.view.animation.AccelerateInterpolator;
import android.widget.LinearLayout;
import com.siso.crazyworld.fragment.ContentFragment;
import java.util.ArrayList;
import java.util.List;
import sidemenu.interfaces.Resourceble;
import sidemenu.interfaces.ScreenShotable;
import sidemenu.model.SlideMenuItem;
import sidemenu.util.ViewAnimator;
public class classificmenuActivity extends ActionBarActivity implements ViewAnimator.ViewAnimatorListener {
 private DrawerLayout drawerLayout;
 private ActionBarDrawerToggle drawerToggle;
 private List<SlideMenuItem> list = new ArrayList<>();
 private ContentFragment contentFragment;
 private ViewAnimator viewAnimator;
 private int res = R.drawable.content_music;
 private LinearLayout linearLayout;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_classificmenu);
  contentFragment = ContentFragment.newInstance(R.drawable.content_music);
  getSupportFragmentManager().beginTransaction()
    .replace(R.id.content_frame, contentFragment)
    .commit();
  drawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
  drawerLayout.setScrimColor(Color.TRANSPARENT);
  linearLayout = (LinearLayout) findViewById(R.id.left_drawer);
  linearLayout.setOnClickListener(new View.OnClickListener() {
   @Override
   public void onClick(View v) {
    drawerLayout.closeDrawers();
   }
  });
  setActionBar();
  createMenuList();
  viewAnimator = new ViewAnimator<>(this, list, contentFragment, drawerLayout, this);
 }
 private void createMenuList() {
  SlideMenuItem menuItem0 = new SlideMenuItem(ContentFragment.CLOSE, R.drawable.icn_close);
  list.add(menuItem0);
  SlideMenuItem menuItem = new SlideMenuItem(ContentFragment.BUILDING, R.drawable.icn_1);
  list.add(menuItem);
  SlideMenuItem menuItem2 = new SlideMenuItem(ContentFragment.BOOK, R.drawable.icn_2);
  list.add(menuItem2);
  SlideMenuItem menuItem3 = new SlideMenuItem(ContentFragment.PAINT, R.drawable.icn_3);
  list.add(menuItem3);
  SlideMenuItem menuItem4 = new SlideMenuItem(ContentFragment.CASE, R.drawable.icn_4);
  list.add(menuItem4);
  SlideMenuItem menuItem5 = new SlideMenuItem(ContentFragment.SHOP, R.drawable.icn_5);
  list.add(menuItem5);
  SlideMenuItem menuItem6 = new SlideMenuItem(ContentFragment.PARTY, R.drawable.icn_6);
  list.add(menuItem6);
  SlideMenuItem menuItem7 = new SlideMenuItem(ContentFragment.MOVIE, R.drawable.icn_7);
  list.add(menuItem7);
 }
 private void setActionBar() {
  Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
  setSupportActionBar(toolbar);
  getSupportActionBar().setHomeButtonEnabled(true);
  getSupportActionBar().setDisplayHomeAsUpEnabled(true);
  drawerToggle = new ActionBarDrawerToggle(
    this,     
    drawerLayout,   
    toolbar, 
    R.string.drawer_open, 
    R.string.drawer_close 
  ) {
   
   public void onDrawerClosed(View view) {
    super.onDrawerClosed(view);
    linearLayout.removeAllViews();
    linearLayout.invalidate();
   }
   @Override
   public void onDrawerSlide(View drawerView, float slideOffset) {
    super.onDrawerSlide(drawerView, slideOffset);
    if (slideOffset > 0.6 && linearLayout.getChildCount() == 0)
     viewAnimator.showMenuContent();
   }
   
   public void onDrawerOpened(View drawerView) {
    super.onDrawerOpened(drawerView);
   }
  };
  drawerLayout.setDrawerListener(drawerToggle);
 }
 @Override
 protected void onPostCreate(Bundle savedInstanceState) {
  super.onPostCreate(savedInstanceState);
  drawerToggle.syncState();
 }
 @Override
 public void onConfigurationChanged(Configuration newConfig) {
  super.onConfigurationChanged(newConfig);
  drawerToggle.onConfigurationChanged(newConfig);
 }
 @Override
 public boolean onCreateOptionsMenu(Menu menu) {
  getMenuInflater().inflate(R.menu.menu_main, menu);
  return true;
 }
 @Override
 public boolean onOptionsItemSelected(MenuItem item) {
  if (drawerToggle.onOptionsItemSelected(item)) {
   return true;
  }
  switch (item.getItemId()) {
   case R.id.action_settings:
    return true;
   default:
    return super.onOptionsItemSelected(item);
  }
 }
 private ScreenShotable replaceFragment(ScreenShotable screenShotable, int topPosition) {
  this.res = this.res == R.drawable.content_music ? R.drawable.content_films : R.drawable.content_music;
  View view = findViewById(R.id.content_frame);
  int finalRadius = Math.max(view.getWidth(), view.getHeight());
  Animator animator = ViewAnimationUtils.createCircularReveal(view, 0, topPosition, 0, finalRadius);
  animator.setInterpolator(new AccelerateInterpolator());
  animator.setDuration(ViewAnimator.CIRCULAR_REVEAL_ANIMATION_DURATION);
  findViewById(R.id.content_overlay).setBackground(new BitmapDrawable(getResources(), screenShotable.getBitmap()));
  animator.start();
  ContentFragment contentFragment = ContentFragment.newInstance(this.res);
  getSupportFragmentManager().beginTransaction().replace(R.id.content_frame, contentFragment).commit();
  return contentFragment;
 }
 @Override
 public ScreenShotable onSwitch(Resourceble slideMenuItem, ScreenShotable screenShotable, int position) {
  switch (slideMenuItem.getName()) {
   case ContentFragment.CLOSE:
    return screenShotable;
   default:
    return replaceFragment(screenShotable, position);
  }
 }
 @Override
 public void disableHomeButton() {
  getSupportActionBar().setHomeButtonEnabled(false);
 }
 @Override
 public void enableHomeButton() {
  getSupportActionBar().setHomeButtonEnabled(true);
  drawerLayout.closeDrawers();
 }
 @Override
 public void addViewToContainer(View view) {
  linearLayout.addView(view);
 }
}

fragment文件夹下ContentFragment.java代码:


package com.siso.crazyworld.fragment;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;
import com.siso.crazyworld.R;
import sidemenu.interfaces.ScreenShotable;
public class ContentFragment extends Fragment implements ScreenShotable {
 public static final String CLOSE = "Close";
 public static final String BUILDING = "Building";
 public static final String BOOK = "Book";
 public static final String PAINT = "Paint";
 public static final String CASE = "Case";
 public static final String SHOP = "Shop";
 public static final String PARTY = "Party";
 public static final String MOVIE = "Movie";
 private View containerView;
 protected ImageView mImageView;
 protected int res;
 private Bitmap bitmap;
 public static ContentFragment newInstance(int resId) {
  ContentFragment contentFragment = new ContentFragment();
  Bundle bundle = new Bundle();
  bundle.putInt(Integer.class.getName(), resId);
  contentFragment.setArguments(bundle);
  return contentFragment;
 }
 @Override
 public void onViewCreated(View view, @Nullable Bundle savedInstanceState) {
  super.onViewCreated(view, savedInstanceState);
  this.containerView = view.findViewById(R.id.container);
 }
 @Override
 public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  res = getArguments().getInt(Integer.class.getName());
 }
 @Override
 public View onCreateView(LayoutInflater inflater, ViewGroup container,
        Bundle savedInstanceState) {
  View rootView = inflater.inflate(R.layout.fragment_main, container, false);
  mImageView = (ImageView) rootView.findViewById(R.id.image_content);
  mImageView.setClickable(true);
  mImageView.setFocusable(true);
  mImageView.setImageResource(res);
  return rootView;
 }
 @Override
 public void takeScreenShot() {
  Thread thread = new Thread() {
   @Override
   public void run() {
    Bitmap bitmap = Bitmap.createBitmap(containerView.getWidth(),
      containerView.getHeight(), Bitmap.Config.ARGB_8888);
    Canvas canvas = new Canvas(bitmap);
    containerView.draw(canvas);
    ContentFragment.this.bitmap = bitmap;
   }
  };
  thread.start();
 }
 @Override
 public Bitmap getBitmap() {
  return bitmap;
 }
}

activity_classificmenu.xml内容:


<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">
 <io.codetail.widget.RevealFrameLayout
  android:id="@+id/container_frame"
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent">
  <LinearLayout
   android:id="@+id/content_overlay"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:orientation="vertical"/>
  <LinearLayout
   android:id="@+id/content_frame"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:orientation="vertical"/>
  <android.support.v7.widget.Toolbar
   android:id="@+id/toolbar"
   android:layout_height="wrap_content"
   android:layout_width="match_parent"
   android:minHeight="?attr/actionBarSize"
   android:background="?attr/colorPrimary"/>
 </io.codetail.widget.RevealFrameLayout>
 <ScrollView
  android:id="@+id/scrollView"
  android:scrollbarThumbVertical="@android:color/transparent"
  android:layout_width="@dimen/sliding_menu_width"
  android:layout_height="match_parent"
  android:layout_gravity="start|bottom">
  <LinearLayout
   android:id="@+id/left_drawer"
   android:orientation="vertical"
   android:layout_width="@dimen/sliding_menu_width"
   android:layout_height="wrap_content"
   android:divider="@android:color/transparent"
   android:background="@android:color/transparent">
  </LinearLayout>
 </ScrollView>
</android.support.v4.widget.DrawerLayout>

.xml内容:


<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
 <item android:state_pressed="true" android:drawable="@drawable/item_down"/>
 <item android:state_selected="true" android:drawable="@drawable/item_down"/>
 <item android:state_focused="true" android:drawable="@drawable/item_down"/>
 <item android:drawable="@drawable/item_up"/>
</selector>

fragment_main.xml内容:


<?xml version="1.0" encoding="utf-8"?>
<io.codetail.widget.RevealFrameLayout
 xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="match_parent">
 <FrameLayout
  android:id="@+id/container"
  android:layout_width="match_parent"
  android:layout_height="match_parent">
  <ImageView
   android:scaleType="fitXY"
   android:id="@+id/image_content"
   android:src="@drawable/content_films"
   android:layout_width="match_parent"
   android:layout_height="match_parent"/>
 </FrameLayout>
</io.codetail.widget.RevealFrameLayout>

strings.xml:


<?xml version="1.0" encoding="utf-8"?>
<resources>
 <string name="app_name">CrazyWorld</string>
 <string name="action_settings">设置</string>
 <string name="drawer_open">Open</string>
 <string name="drawer_close">Close</string>
</resources>

styles.xml


<resources>
 <!-- Base application theme. -->
 <style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
 </style>
</resources>

运行结果:

您可能感兴趣的文章:Android仿京东分类模块左侧分类条目效果Android使用Scroll+Fragment仿京东分类效果Android 仿京东、拼多多商品分类页的示例代码Android实现网易Tab分类排序控件实现Android使用分类型RecyclerView仿各大商城首页Android编程实现仿美团或淘宝的多级分类菜单效果示例【附demo源码下载】android使用 ScrollerView 实现 可上下滚动的分类栏实例Android 仿网易新闻客户端分类排序功能Android实现qq列表式的分类悬浮提示Android实现京东App分类页面效果


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-移动开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯