横向滑动菜单

来源:互联网 发布:windows 10 multiple 编辑:程序博客网 时间:2024/05/21 00:52
package com.example.day_02_horizontalscrollview;import java.util.ArrayList;import java.util.List;import com.slidingmenu.lib.SlidingMenu;import android.os.Bundle;import android.support.v4.app.Fragment;import android.support.v4.app.FragmentActivity;import android.support.v4.view.ViewPager;import android.util.DisplayMetrics;import android.util.Log;import android.view.Gravity;import android.view.View;import android.widget.HorizontalScrollView;import android.widget.LinearLayout;import android.widget.RadioGroup;import android.widget.TextView;public class MainActivity extends FragmentActivity {private HorizontalScrollView hsv;// 横向滑动的控件private LinearLayout nav_ll;// 线性布局容器private ViewPager nav_vp;private int itemWidth;// 获取每个item的宽度private int selectItemIndex = 0;private int screenWidth;private List<String> type;@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);setSlidingMenu();type = MyTools.getType();// 找控件hsv = (HorizontalScrollView) findViewById(R.id.nav_HorizontalScrollView);hsv.setHorizontalScrollBarEnabled(false);nav_ll = (LinearLayout) findViewById(R.id.nav_ll);nav_vp = (ViewPager) findViewById(R.id.nav_vp);// 设置导航栏菜单setNav();// 设置viewpagersetViewPager();}private void setViewPager() {// 实例化list集合存放fragmentList<Fragment> fragmentList = new ArrayList<Fragment>();for (int i = 0; i < MyTools.getType().size(); i++) {MyFragment frame = new MyFragment(type.get(i));// 存入list集合fragmentList.add(frame);}// 设置vp适配器MyFragmentAdapter fragmentAdapter = new MyFragmentAdapter(getSupportFragmentManager(), fragmentList);nav_vp.setAdapter(fragmentAdapter);// 设置vp滑动监听nav_vp.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {@Overridepublic void onPageScrolled(int position, float positionOffset,int positionOffsetPixels) {}@Overridepublic void onPageSelected(int position) {nav_vp.setCurrentItem(position);selectType(position);}@Overridepublic void onPageScrollStateChanged(int state) {}});}private void setNav() {// 获得屏幕总宽度DisplayMetrics metrics = new DisplayMetrics();getWindowManager().getDefaultDisplay().getMetrics(metrics);screenWidth = metrics.widthPixels;// 设置每一个item的宽度itemWidth = screenWidth / type.size();Log.i("---->", MyTools.getType().toString());for (int i = 0; i < MyTools.getType().size(); i++) {LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(itemWidth, RadioGroup.LayoutParams.WRAP_CONTENT);// 设置外边距params.leftMargin = 10;params.rightMargin = 10;// 创建TextView的实例TextView localTextView = new TextView(this);// 设置tv的属性localTextView.setText(MyTools.getType().get(i));localTextView.setTextSize(16.0f);localTextView.setBackgroundResource(R.drawable.nav_tv_bg);localTextView.setPadding(5, 15, 5, 15);localTextView.setGravity(Gravity.CENTER);if (selectItemIndex == i) {localTextView.setSelected(true);}// 设置每一个tv的监听localTextView.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {for (int i = 0; i < nav_ll.getChildCount(); i++) {TextView tv = (TextView) nav_ll.getChildAt(i);if (tv == v) {tv.setSelected(true);nav_vp.setCurrentItem(i);} else {tv.setSelected(false);}}}});nav_ll.addView(localTextView, i, params);}}public void selectType(int tab_position) {selectItemIndex = tab_position;// 通过自动滚动for (int i = 0; i < nav_ll.getChildCount(); i++) {TextView tv0 = (TextView) nav_ll.getChildAt(tab_position);int k = tv0.getMeasuredWidth();int l = tv0.getLeft();int i2 = l + k / 2 - screenWidth / 2;// 计算要滚动到的位置hsv.smoothScrollTo(i2, 0);View view = nav_ll.getChildAt(i);if (tab_position == i) {view.setSelected(true);} else {view.setSelected(false);}}// 判断哪一个tv被选中设置背景颜色for (int i = 0; i < nav_ll.getChildCount(); i++) {}}/** *  */private void setSlidingMenu() {    SlidingMenu menu=new SlidingMenu(this);menu.setMode(SlidingMenu.RIGHT);//2menu.setMenu(R.layout.leftmenu);//------!!!为侧滑菜单设置布局// 设置触摸屏幕的模式menu.setTouchModeAbove(SlidingMenu.TOUCHMODE_MARGIN);//3滑出菜单的模式menu.setShadowWidth(50);//4//menu.setShadowDrawable(R.drawable.shadow);//5是个渐变shape文件// 设置滑动菜单打开后内容页所留的可滑动部分的宽为80dpmenu.setBehindOffset(120);// 设置渐入渐出效果的变化程度1.0为关闭时纯黑menu.setFadeDegree(1.0f);menu.setBehindScrollScale(0.2f);//7// 把SlidingMenu附加在Activity上  可取值为:SLIDING_CONTENT,SLIDING_WINDOW// SlidingMenu.SLIDING_WINDOW:菜单拉开后高度是全屏的  // SlidingMenu.SLIDING_CONTENT:菜单拉开后高度是不包含Title/ActionBar的内容区域  menu.attachToActivity(this, SlidingMenu.SLIDING_WINDOW);//8 左菜单有title栏-------!!!}}

==========================================================================================================

/** *  */package com.example.day_02_horizontalscrollview;import android.os.Bundle;import android.support.v4.app.Fragment;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.widget.TextView;/** * @author WJL *  */public class MyFragment extends Fragment {String text;public MyFragment(String text) {this.text = text;}@Overridepublic View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState) {View view = View.inflate(getActivity(), R.layout.fragment, null);TextView tv = (TextView) view.findViewById(R.id.tv);tv.setText(text);return view;}}
========================================================================================================

package com.example.day_02_horizontalscrollview;import android.support.v4.app.Fragment;import android.support.v4.app.FragmentManager;import android.support.v4.app.FragmentPagerAdapter;import java.util.List;/** * Created by Administrator on 2016/2/18. */public class MyFragmentAdapter extends FragmentPagerAdapter {    private List<Fragment> fragmentList;    public MyFragmentAdapter(FragmentManager fm, List<Fragment> fragmentList) {        super(fm);        this.fragmentList = fragmentList;    }    @Override    public Fragment getItem(int position) {        return fragmentList.get(position);    }    @Override    public int getCount() {        return fragmentList.size();    }}

==================================================================================================

package com.example.day_02_horizontalscrollview;import java.util.Arrays;import java.util.List;import java.util.Map;import java.util.TreeMap;/** * Created by Administrator on 2016/2/22. */public class MyTools {    public static Map<String, String> getData() {        Map<String, String> map = new TreeMap<String, String>();        map.put("推荐", "http://ic.snssdk.com/2/article/v14/stream/?image=1&count=20&min_behot_time=1455594227&iid=3641392726&device_id=10789635067&ac=wifi&channel=dearclick31&aid=13&app_name=news_article&version_code=330&device_platform=android&device_type=Coolpad%208297&os_api=17&os_version=4.2.2&uuid=863777029390464&openudid=17de2106c58527f4&detail=");        map.put("热点", "http://ic.snssdk.com/2/article/v14/stream/?image=1&category=news_hot&count=20&iid=3641392726&device_id=10789635067&ac=wifi&channel=dearclick31&aid=13&app_name=news_article&version_code=330&device_platform=android&device_type=Coolpad%208297&os_api=17&os_version=4.2.2&uuid=863777029390464&openudid=17de2106c58527f4&detail=");        map.put("北京", "http://ic.snssdk.com/2/article/v14/stream/?image=1&category=news_local&count=20&iid=3641392726&device_id=10789635067&ac=wifi&channel=dearclick31&aid=13&app_name=news_article&version_code=330&device_platform=android&device_type=Coolpad%208297&os_api=17&os_version=4.2.2&uuid=863777029390464&openudid=17de2106c58527f4&detail=");        map.put("社会", "http://ic.snssdk.com/2/article/v14/stream/?image=1&category=news_society&count=20&iid=3641392726&device_id=10789635067&ac=wifi&channel=dearclick31&aid=13&app_name=news_article&version_code=330&device_platform=android&device_type=Coolpad%208297&os_api=17&os_version=4.2.2&uuid=863777029390464&openudid=17de2106c58527f4&detail=");        map.put("娱乐", "http://ic.snssdk.com/2/article/v14/stream/?image=1&category=news_entertainment&count=20&iid=3641392726&device_id=10789635067&ac=wifi&channel=dearclick31&aid=13&app_name=news_article&version_code=330&device_platform=android&device_type=Coolpad%208297&os_api=17&os_version=4.2.2&uuid=863777029390464&openudid=17de2106c58527f4&detail=");        map.put("科技", "http://ic.snssdk.com/2/article/v14/stream/?image=1&category=news_tech&count=20&min_behot_time=1455786887&tt_from=tip&iid=3641392726&device_id=10789635067&ac=wifi&channel=dearclick31&aid=13&app_name=news_article&version_code=330&device_platform=android&device_type=Coolpad%208297&os_api=17&os_version=4.2.2&uuid=863777029390464&openudid=17de2106c58527f4&detail=");        map.put("视频", "http://c.m.163.com/nc/video/home/0-10.html");        return map;    }    public static List<String> getType() {        List<String> typeList = Arrays.asList("推荐", "热点", "北京", "社会", "娱乐", "科技", "视频");//        Set<String> keySet = getData().keySet();//        Collection<String> values = getData().values();//        Iterator<String> stringIterator = values.iterator();//        while (stringIterator.hasNext()){//            String next = stringIterator.next();//        }//        TreeSet<String> treeSet=new TreeSet<>();//        treeSet.addAll(keySet);//////        Iterator<String> iterator = keySet.iterator();//        while (iterator.hasNext()) {//            String next = iterator.next();//            typeList.add(next);//        }        return typeList;    }}
===============================================================================================

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:tools="http://schemas.android.com/tools"    android:layout_width="match_parent"    android:layout_height="match_parent"    android:orientation="vertical">    <LinearLayout        android:layout_width="match_parent"        android:layout_height="50dp"        android:orientation="horizontal">        <HorizontalScrollView            android:id="@+id/nav_HorizontalScrollView"            android:layout_width="0dp"            android:layout_height="50dp"            android:layout_weight="9"                        android:fillViewport="true">            <LinearLayout                android:id="@+id/nav_ll"                android:layout_width="match_parent"                android:layout_height="wrap_content"                android:orientation="horizontal">                                                                                            </LinearLayout>        </HorizontalScrollView>    </LinearLayout>    <android.support.v4.view.ViewPager        android:id="@+id/nav_vp"        android:layout_width="match_parent"        android:layout_height="0dp"        android:layout_weight="1" /></LinearLayout>
==================================================================================

<?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/tv"        android:layout_gravity="center"        android:layout_width="200dp"        android:textSize="50sp"        android:layout_height="200dp"        android:text="类型" /></LinearLayout>
============================================================================================

<?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:background="#ff0"    android:orientation="vertical" >    <TextView        android:layout_width="match_parent"        android:layout_height="match_parent"        android:gravity="center"        android:text="Hello Sliding Menu!" /></LinearLayout>

===============================================================================================

res文件下drawable中的nav_tv_bg.xml文件

<?xml version="1.0" encoding="utf-8"?><selector xmlns:android="http://schemas.android.com/apk/res/android">    <item android:state_selected="true">        <shape>            <gradient android:angle="270.0" android:endColor="#ffcc3131" android:startColor="#ffcc3131" />            <corners android:radius="2.0dip" />        </shape>    </item>    <item>        <shape>            <gradient android:angle="270.0" android:endColor="#00000000" android:startColor="#00000000" />            <corners android:radius="2.0dip" />        </shape>    </item></selector>






0 0