Android HorizontalScrollView滑动与ViewPager切换案例详解
作者:豆豆呢 时间:2023-06-05 00:48:27
layout布局
<RelativeLayout 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"
tools:context=".MainActivity" >
<HorizontalScrollView
android:id="@+id/sc"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:scrollbars="none" >
<LinearLayout
android:id="@+id/line_sc"
android:layout_width="match_parent"
android:layout_height="wrap_content" >
</LinearLayout>
</HorizontalScrollView>
<LinearLayout
android:id="@+id/view"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@id/sc"
/>
<android.support.v4.view.ViewPager
android:id="@+id/vp"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_below="@id/view" >
</android.support.v4.view.ViewPager>
</RelativeLayout>
MainActivity.java
package com.bwie.test;
import java.util.ArrayList;
import com.bwie.adapter.MyAdapter;
import com.bwie.fragment.F1;
import com.bwie.utils.Myutil;
import android.os.Bundle;
import android.app.Activity;
import android.graphics.Color;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentManager;
import android.support.v4.view.ViewPager;
import android.support.v4.view.ViewPager.OnPageChangeListener;
import android.util.DisplayMetrics;
import android.view.Menu;
import android.view.View;
import android.widget.HorizontalScrollView;
import android.widget.LinearLayout;
import android.widget.LinearLayout.LayoutParams;
import android.widget.TextView;
public class MainActivity extends FragmentActivity {
private LinearLayout line_sc;
private HorizontalScrollView sc;
private String[] column = new String[] { "舍内要闻", "本社介绍", "履行职能", "自身建设",
"社员风采", "自我介绍", "校内趣闻", "爆料" };
private ArrayList<Fragment> list;
private ViewPager vp;
private int widthPixels;
private ArrayList<TextView> list_view;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
/**
* 获取窗口的 宽度
*/
// 创建DisplayMetrics类对象
DisplayMetrics dm = new DisplayMetrics();
// 将当前窗口的一些信息放在DisplayMetrics类中
getWindowManager().getDefaultDisplay().getMetrics(dm);
widthPixels = dm.widthPixels;
// 初始化数据
init();
// 获取栏目的数据
getColumn();
// 创建fragment数据
setFragment();
// 为vp设置数据
FragmentManager fm = getSupportFragmentManager();
vp.setAdapter(new MyAdapter(fm, list));
setTitle_1(vp.getCurrentItem());
// 为vp设置页面滑动监听
vp.setOnPageChangeListener(new OnPageChangeListener() {
@Override
public void onPageSelected(int arg0) {
//设置游标
setTitle_1(arg0);
//设置滑动
setAutoScroll(arg0);
}
@Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
// TODO Auto-generated method stub
}
@Override
public void onPageScrollStateChanged(int arg0) {
// TODO Auto-generated method stub
}
});
}
protected void setAutoScroll(int p) {
// TODO Auto-generated method stub
//获取当前要展示的游标
TextView textView = list_view.get(p);
//获取其宽度
int w = textView.getMeasuredWidth();
int left = textView.getLeft();
int address=left-widthPixels/2;
sc.smoothScrollTo(address, 0);
}
private void setFragment() {
// 创建集合存放fragment对象
list = new ArrayList<Fragment>();
for (int i = 0; i < column.length; i++) {
F1 f1 = new F1();
// 传值
Bundle b = new Bundle();
b.putInt("column", i);
f1.setArguments(b);
// 将创建的fragment添加到集合中
list.add(f1);
}
}
private void setTitle_1(int arg0) {
//设置当前显示的textview控件
TextView textView = list_view.get(arg0);
//将当前的textview显示
textView.setVisibility(View.VISIBLE);
for(int i=0;i<list_view.size();i++)
{
TextView tv = list_view.get(i);
if(tv!=textView)
{
tv.setVisibility(View.GONE);
}
}
}
private void getColumn() {
// TODO Auto-generated method stub
list_view = new ArrayList<TextView>();
for (int i = 0; i < column.length; i++) {
// 创建线性布局来整体作为水平滚动的子布局
LinearLayout sc = new LinearLayout(MainActivity.this);
// 设置线性布局的排列方式(垂直)
sc.setOrientation(1);
sc.setPadding(30, 0, 0, 0);
// 1.首先向线性布局中添加textview
// 创建textview
TextView tv = new TextView(MainActivity.this);
// 为tv设置数据
tv.setText(column[i]);
LinearLayout.LayoutParams params = new LayoutParams(
widthPixels / 5, LayoutParams.WRAP_CONTENT);
sc.addView(tv, params);
// 2.向线性布局中添加下面的横线
TextView tv_line = new TextView(MainActivity.this);
LinearLayout.LayoutParams params_2 = new LayoutParams(
widthPixels / 5, 10);
tv_line.setBackgroundColor(Color.GRAY);
tv_line.setVisibility(View.INVISIBLE);
list_view.add(tv_line);
sc.addView(tv_line, params_2);
// 将数据添加到 线性布局中
line_sc.addView(sc);
}
}
private void init() {
line_sc = (LinearLayout) findViewById(R.id.line_sc);
sc = (HorizontalScrollView) findViewById(R.id.sc);
vp = (ViewPager) findViewById(R.id.vp);
}
}
horizontalScrollView viewpager 字体颜色 滑动距离
FragmentManager fm = getSupportFragmentManager();
viewPager.setAdapter(new MyFragmentAdapter(fm, getData()));
viewPager.setOnPageChangeListener(new OnPageChangeListener() {
public void onPageSelected(int arg0) {
// TODO Auto-generated method stub
setTag(arg0);
}
public void onPageScrolled(int arg0, float arg1, int arg2) {
// TODO Auto-generated method stub
}
public void onPageScrollStateChanged(int arg0) {
// TODO Auto-generated method stub
}
});
public ArrayList<Fragment> getData() {
ArrayList<Fragment> list = new ArrayList<Fragment>();
for (int i = 0; i < str.length; i++) {
list.add(new F1(str[i]));
}
return list;
}
private void setData() {
// TODO Auto-generated method stub
List<String> list = new ArrayList<String>();
for (int i = 0; i < str.length; i++) {
View view = View.inflate(MainActivity.this,
android.R.layout.simple_list_item_1, null);
TextView textView = (TextView) view
.findViewById(android.R.id.text1);
list.add(str[i]);
textView.setText(list.get(i));
scroll_ly.addView(view);
textView.setTag(i);
textView.setOnClickListener(this);
}
TextView childAt = (TextView) scroll_ly.getChildAt(0);
// childAt.setTextColor(Color.RED);
childAt.setBackgroundColor(Color.RED);
childAt.setTextColor(Color.WHITE);
}
// 设置scrollview中textview的变化
public void setTag(int position) {
for (int i = 0; i < scroll_ly.getChildCount(); i++) {
/**
* textView滑动的位置
*/
// 获取textview的viewpager滑动的当前子类
TextView textView = (TextView) scroll_ly.getChildAt(position);
int k = textView.getMeasuredWidth();
int l = textView.getLeft();
int s = k / 2 + l - wid / 2;
// 设置scrollView x轴的距离
scrollView.smoothScrollTo(s, 0);
/**
* textview滑动变色
*/
TextView textView2 = (TextView) scroll_ly.getChildAt(i);
if (position == i) {
textView2.setBackgroundColor(Color.RED);
textView2.setTextColor(Color.WHITE);
} else {
textView2.setTextColor(Color.BLACK);
textView2.setBackgroundColor(Color.WHITE);
}
}
}
public void onClick(View v) {
// TODO Auto-generated method stub
if (v.getTag() != null) {
int i = (Integer) v.getTag();
View childAt = scroll_ly.getChildAt(i);
if (v == childAt) {
viewPager.setCurrentItem(i);
}
}
}
来源:https://www.cnblogs.com/ldou/p/5322662.html
标签:Android,HorizontalScrollView
0
投稿
猜你喜欢
Java实现inputstream流的复制代码实例
2021-08-30 11:52:11
Android Studio 3.1.3升级至3.6.1后旧项目的兼容操作方法
2022-03-27 10:15:41
flutter仿微信底部图标渐变功能的实现代码
2023-08-18 14:31:39
Android通过AIDL在两个APP之间Service通信
2022-04-15 23:58:27
一篇文章带你深入了解Java封装
2023-11-20 00:37:45
IDEA插件之Mybatis Log plugin 破解及安装方法
2023-09-24 22:30:16
使用Java程序模拟实现新冠病毒传染效果
2022-09-12 20:26:14
为Android应用增加渠道信息 自动化不同渠道的打包过程的使用详解
2022-06-01 11:38:22
C# 泛型接口的抗变和协变
2022-05-07 09:34:31
java使用动态代理来实现AOP(日志记录)的实例代码
2023-11-28 22:34:45
Android开发之DialogFragment用法实例总结
2023-08-30 13:20:21
Java基础学习之IO流应用案例详解
2022-09-11 17:04:42
java中struts2实现简单的文件上传与下载
2022-12-23 22:53:21
C#使用struct直接转换下位机数据的示例代码
2023-06-07 01:49:01
Android实用的代码片段 常用代码总结
2022-02-02 20:29:53
Android中三种注入事件方法比较
2022-11-20 18:17:23
Android 获取判断是否有悬浮窗权限的方法
2023-11-04 22:48:18
Springboot整合微信支付(订单过期取消及商户主动查单)
2023-05-15 23:40:50
WebService教程详解(二)
2022-02-24 02:26:54
Java自动生成趋势比对数据的方法分享
2023-11-25 18:29:18