android實(shí)現(xiàn)上下左右滑動(dòng)界面布局
本文實(shí)例為大家分享了android實(shí)現(xiàn)滑動(dòng)界面布局的具體代碼,供大家參考,具體內(nèi)容如下
1.我使用的是ScrollView嵌套HorizontalScrollView讓ScrollView負(fù)責(zé)上下滑動(dòng)HorizontalScrollView負(fù)責(zé)左右滑動(dòng)
2.以下代碼提供了思路和完成手段,請(qǐng)根據(jù)具體業(yè)務(wù)去進(jìn)行修改,我試過(guò)使用recyclerview進(jìn)行自定義,發(fā)現(xiàn)一旦有了復(fù)雜業(yè)務(wù)之后會(huì)掉幀卡頓所以使用了這種方法
XML布局
<?xml version="1.0" encoding="utf-8"?>
<test.smartonet.com.myapplication.PagerScrollView
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/main"
android:layout_width="match_parent"
android:layout_height="match_parent">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<HorizontalScrollView
android:id="@+id/hor"
android:layout_width="match_parent"
android:background="#e1f1f1"
android:layout_height="160dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center|left"
android:gravity="center"
android:orientation="horizontal">
<TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A1"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A2"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A3"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A4"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A5"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A6"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A1"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A2"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A3"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A4"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A5"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A6"/>
</LinearLayout>
</HorizontalScrollView>
<HorizontalScrollView
android:id="@+id/hor1"
android:layout_width="match_parent"
android:scrollbars="none"
android:background="#a2f2f2"
android:layout_height="160dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center|left"
android:gravity="center"
android:orientation="horizontal">
<TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A1"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A2"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A3"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A4"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A5"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A6"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A1"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A2"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A3"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A4"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A5"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A6"/>
</LinearLayout>
</HorizontalScrollView>
<HorizontalScrollView
android:id="@+id/hor2"
android:layout_width="match_parent"
android:scrollbars="none"
android:background="#a2a2f2"
android:layout_height="160dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center|left"
android:gravity="center"
android:orientation="horizontal">
<TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A1"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A2"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A3"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A4"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A5"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A6"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A1"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A2"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A3"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A4"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A5"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A6"/>
</LinearLayout>
</HorizontalScrollView>
<HorizontalScrollView
android:id="@+id/hor3"
android:layout_width="match_parent"
android:scrollbars="none"
android:background="#f3f3f3"
android:layout_height="160dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center|left"
android:gravity="center"
android:orientation="horizontal">
<TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A1"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A2"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A3"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A4"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A5"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A6"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A1"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A2"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A3"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A4"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A5"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A6"/>
</LinearLayout>
</HorizontalScrollView>
<HorizontalScrollView
android:id="@+id/hor4"
android:layout_width="match_parent"
android:scrollbars="none"
android:background="#a4f4f4"
android:layout_height="200dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center|left"
android:gravity="center"
android:orientation="horizontal">
<TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A1"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A2"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A3"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A4"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A5"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A6"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A1"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A2"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A3"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A4"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A5"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A6"/>
</LinearLayout>
</HorizontalScrollView>
<HorizontalScrollView
android:id="@+id/hor5"
android:layout_width="match_parent"
android:scrollbars="none"
android:background="#f5f5f5"
android:layout_height="200dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center|left"
android:gravity="center"
android:orientation="horizontal">
<TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A1"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A2"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A3"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A4"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A5"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A6"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A1"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A2"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A3"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A4"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A5"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A6"/>
</LinearLayout>
</HorizontalScrollView>
<HorizontalScrollView
android:id="@+id/hor6"
android:layout_width="match_parent"
android:scrollbars="none"
android:background="#a5f5f5"
android:layout_height="200dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center|left"
android:gravity="center"
android:orientation="horizontal">
<TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A1"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A2"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A3"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A4"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A5"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A6"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A1"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A2"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A3"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A4"/> <TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A5"/><TextView
android:layout_width="160dp"
android:layout_height="60dp"
android:gravity="center"
android:text="A6"/>
</LinearLayout>
</HorizontalScrollView>
</LinearLayout>
</test.smartonet.com.myapplication.PagerScrollView>
mainAvtivity的代碼
package test.smartonet.com.myapplication;
import android.annotation.SuppressLint;
import android.content.Context;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.util.AttributeSet;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.ViewGroup;
import android.widget.HorizontalScrollView;
import android.widget.LinearLayout;
import android.widget.ScrollView;
import android.widget.TextView;
import android.widget.Toast;
import org.w3c.dom.Text;
import java.lang.reflect.Array;
import java.util.ArrayList;
import java.util.List;
/**
* zhaohan creat 2019/3/6
*/
public class MainActivity extends AppCompatActivity {
String TAG = "主程序";
float mPosX;
float mPosY;
float mCurPosX;
float mCurPosY;
int offset=10;//偏移量
int friction = 10;//摩擦力
final List<HorizontalScrollView> list = new ArrayList();
@SuppressLint("ClickableViewAccessibility")
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final PagerScrollView scrollView = findViewById(R.id.main);
list.add((HorizontalScrollView) findViewById(R.id.hor));
list.add((HorizontalScrollView) findViewById(R.id.hor1));
list.add((HorizontalScrollView) findViewById(R.id.hor2));
list.add((HorizontalScrollView) findViewById(R.id.hor3));
list.add((HorizontalScrollView) findViewById(R.id.hor4));
list.add((HorizontalScrollView) findViewById(R.id.hor5));
list.add((HorizontalScrollView) findViewById(R.id.hor6));
for(HorizontalScrollView horizontalScrollView:list){
horizontalScrollView.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
mPosX = event.getX();
mPosY = event.getY();
Log.w(TAG,mPosY+"");
break;
case MotionEvent.ACTION_MOVE:
mCurPosX = event.getX();
mCurPosY = event.getY();
case MotionEvent.ACTION_UP:
if (mCurPosX - mPosX > 0 && (Math.abs(mCurPosX - mPosX) > offset)) {
int speed = 10;//速度
int distance = 20;//滑動(dòng)距離
if((Math.abs(mCurPosX - mPosX))>50){
speed = (int) Math.abs(mCurPosX - mPosX)/friction;
distance = (int) Math.abs(mCurPosX - mPosX)/3;//滑動(dòng)距離
}
//向右滑動(dòng)
Log.w(TAG,"向右滑動(dòng)了!");
while(distance>0) {
distance = distance - speed;
for(HorizontalScrollView horizontalScrollView:list){
horizontalScrollView.smoothScrollBy(distance, 0);
}
}
return true;//true為屏蔽范圍內(nèi)的其他滑動(dòng)監(jiān)聽(tīng)
} else if (mCurPosX - mPosX < 0 && (Math.abs(mCurPosX - mPosX) > offset)) {
int speed = 10;//速度
int distance = 20;//滑動(dòng)距離
if((Math.abs(mCurPosX - mPosX))>50){
speed = (int) Math.abs(mCurPosX - mPosX)/friction;
distance = (int) Math.abs(mCurPosX - mPosX)/3;//滑動(dòng)距離
}
//向左滑動(dòng)
Log.w(TAG,"向左滑動(dòng)了!");
//改為滑動(dòng)
while(distance>0){
distance=distance-speed;
for(HorizontalScrollView horizontalScrollView:list){
horizontalScrollView.smoothScrollBy(-distance,0 );
}
}
return true;//true為屏蔽范圍內(nèi)的其他滑動(dòng)監(jiān)聽(tīng)
}
break;
}
return true;//true為屏蔽范圍內(nèi)的其他滑動(dòng)監(jiān)聽(tīng)
}
});
}
}
}
class PagerScrollView extends ScrollView {
private float xDistance, yDistance, xLast, yLast;
public PagerScrollView(Context context) {
super(context);
}
public PagerScrollView(Context context, AttributeSet attrs) {
super(context, attrs);
}
public PagerScrollView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}
@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {
switch (ev.getAction()) {
case MotionEvent.ACTION_DOWN:
xDistance = yDistance = 0f;
xLast = ev.getX();
yLast = ev.getY();
break;
case MotionEvent.ACTION_MOVE:
final float curX = ev.getX();
final float curY = ev.getY();
xDistance += Math.abs(curX - xLast);
yDistance += Math.abs(curY - yLast);
xLast = curX;
yLast = curY;
/**
* X軸滑動(dòng)距離大于Y軸滑動(dòng)距離,也就是用戶(hù)橫向滑動(dòng)時(shí),返回false,ScrollView不處理這次事件,
* 讓子控件中的TouchEvent去處理,所以橫向滑動(dòng)的事件交由ViewPager處理,
* ScrollView只處理縱向滑動(dòng)事件
*/
if (xDistance > yDistance) {
return false;
}
}
return super.onInterceptTouchEvent(ev);
}
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android開(kāi)發(fā)之資源文件用法實(shí)例總結(jié)
這篇文章主要介紹了Android開(kāi)發(fā)之資源文件用法,結(jié)合實(shí)例形式總結(jié)分析了Android開(kāi)發(fā)過(guò)程中針對(duì)資源文件的常見(jiàn)操作技巧,需要的朋友可以參考下2016-02-02
Android下保存簡(jiǎn)單網(wǎng)頁(yè)到本地(包括簡(jiǎn)單圖片鏈接轉(zhuǎn)換)實(shí)現(xiàn)代碼
這篇文章主要介紹了Android下保存簡(jiǎn)單網(wǎng)頁(yè)到本地(包括簡(jiǎn)單圖片鏈接轉(zhuǎn)換)實(shí)現(xiàn)代碼,需要的朋友可以參考下2014-02-02
android實(shí)現(xiàn)記住用戶(hù)名和密碼以及自動(dòng)登錄
這篇文章主要為大家詳細(xì)介紹了android實(shí)現(xiàn)記住用戶(hù)名和密碼以及自動(dòng)登錄,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-09-09
Android手勢(shì)密碼view學(xué)習(xí)筆記(二)
這篇文章主要為大家詳細(xì)介紹了Android手勢(shì)密碼view的第二篇學(xué)習(xí)筆記,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
Android?使用maven?publish插件發(fā)布產(chǎn)物(aar)流程實(shí)踐
這篇文章主要介紹了Android?使用maven?publish插件發(fā)布產(chǎn)物(aar)流程實(shí)踐,Android?Gradle插件根據(jù)項(xiàng)目gradle中應(yīng)用不同的插件類(lèi)型在編譯組裝后會(huì)生成不同的產(chǎn)物,具體相關(guān)介紹,需要的小伙伴可以參考一下2022-09-09
Android中Gallery和ImageSwitcher的使用實(shí)例
今天小編就為大家分享一篇關(guān)于Android中Gallery和ImageSwitcher的使用實(shí)例,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-03-03
Android動(dòng)畫(huà)之小球擬合動(dòng)畫(huà)實(shí)例
這篇文章主要介紹了Android動(dòng)畫(huà)之小球擬合動(dòng)畫(huà)實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-07-07
Android實(shí)現(xiàn)選擇相冊(cè)圖片并顯示功能
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)選擇相冊(cè)圖片并顯示功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-04-04

