日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
android側(cè)滑,Android側(cè)滑兩段刪除

android實(shí)現(xiàn)RecyclerView的Item側(cè)滑菜單

1、引入組件

創(chuàng)新互聯(lián)是專業(yè)的贊皇網(wǎng)站建設(shè)公司,贊皇接單;提供成都做網(wǎng)站、成都網(wǎng)站制作,網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行贊皇網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!

2、布局中添加組件

使用該組件替換普通的RecyclerView即可

3、activity中進(jìn)行設(shè)置

android側(cè)滑菜單怎么禁止滑動(dòng)

行數(shù)),從開(kāi)始到結(jié)束,中途有一個(gè)過(guò)渡(即移動(dòng)中顯示更多的畫(huà)面細(xì)節(jié)); 禁用時(shí):在網(wǎng)頁(yè)上滾動(dòng)一次,從開(kāi)始到結(jié)束,中途沒(méi)有過(guò)渡?!¢_(kāi)啟平滑滾動(dòng)在瀏覽網(wǎng)頁(yè)上下滾動(dòng)時(shí),比禁用的畫(huà)面效果更平滑舒服,但是CPU使用率更高。(追求畫(huà)質(zhì):開(kāi)啟 / 追求性能:禁用) 單擊“Internet 選項(xiàng)”打開(kāi)“In

android 如何實(shí)現(xiàn)邊緣拖動(dòng)側(cè)滑?

據(jù)需求需要自己自定義一個(gè)ListView來(lái)實(shí)現(xiàn)該功能,接下來(lái)先貼出代碼再講解具體的實(shí)現(xiàn)

package com.example.slidecutlistview;

import android.content.Context;

import android.util.AttributeSet;

import android.view.MotionEvent;

import android.view.VelocityTracker;

import android.view.View;

import android.view.ViewConfiguration;

import android.view.WindowManager;

import android.widget.AdapterView;

import android.widget.ListView;

import android.widget.Scroller;

/**

* @blog

*

* @author xiaanming

*

*/

public class SlideCutListView extends ListView {

/**

* 當(dāng)前滑動(dòng)的ListView position

*/

private int slidePosition;

/**

* 手指按下X的坐標(biāo)

*/

private int downY;

/**

* 手指按下Y的坐標(biāo)

*/

private int downX;

/**

* 屏幕寬度

*/

private int screenWidth;

/**

* ListView的item

*/

private View itemView;

/**

* 滑動(dòng)類

*/

private Scroller scroller;

private static final int SNAP_VELOCITY = 600;

/**

* 速度追蹤對(duì)象

*/

private VelocityTracker velocityTracker;

/**

* 是否響應(yīng)滑動(dòng),默認(rèn)為不響應(yīng)

*/

private boolean isSlide = false;

/**

* 認(rèn)為是用戶滑動(dòng)的最小距離

*/

private int mTouchSlop;

/**

* 移除item后的回調(diào)接口

*/

private RemoveListener mRemoveListener;

/**

* 用來(lái)指示item滑出屏幕的方向,向左或者向右,用一個(gè)枚舉值來(lái)標(biāo)記

*/

private RemoveDirection removeDirection;

// 滑動(dòng)刪除方向的枚舉值

public enum RemoveDirection {

RIGHT, LEFT;

}

public SlideCutListView(Context context) {

this(context, null);

}

public SlideCutListView(Context context, AttributeSet attrs) {

this(context, attrs, 0);

}

public SlideCutListView(Context context, AttributeSet attrs, int defStyle) {

super(context, attrs, defStyle);

screenWidth = ((WindowManager) context.getSystemService(Context.WINDOW_SERVICE)).getDefaultDisplay().getWidth();

scroller = new Scroller(context);

mTouchSlop = ViewConfiguration.get(getContext()).getScaledTouchSlop();

}

/**

* 設(shè)置滑動(dòng)刪除的回調(diào)接口

* @param removeListener

*/

public void setRemoveListener(RemoveListener removeListener) {

this.mRemoveListener = removeListener;

}

/**

* 分發(fā)事件,主要做的是判斷點(diǎn)擊的是那個(gè)item, 以及通過(guò)postDelayed來(lái)設(shè)置響應(yīng)左右滑動(dòng)事件

*/

@Override

public boolean dispatchTouchEvent(MotionEvent event) {

switch (event.getAction()) {

case MotionEvent.ACTION_DOWN: {

addVelocityTracker(event);

// 假如scroller滾動(dòng)還沒(méi)有結(jié)束,我們直接返回

if (!scroller.isFinished()) {

return super.dispatchTouchEvent(event);

}

downX = (int) event.getX();

downY = (int) event.getY();

slidePosition = pointToPosition(downX, downY);

// 無(wú)效的position, 不做任何處理

if (slidePosition == AdapterView.INVALID_POSITION) {

return super.dispatchTouchEvent(event);

}

// 獲取我們點(diǎn)擊的item view

itemView = getChildAt(slidePosition - getFirstVisiblePosition());

break;

}

case MotionEvent.ACTION_MOVE: {

if (Math.abs(getScrollVelocity()) SNAP_VELOCITY

|| (Math.abs(event.getX() - downX) mTouchSlop Math

.abs(event.getY() - downY) mTouchSlop)) {

isSlide = true;

}

break;

}

case MotionEvent.ACTION_UP:

recycleVelocityTracker();

break;

}

return super.dispatchTouchEvent(event);

}

/**

* 往右滑動(dòng),getScrollX()返回的是左邊緣的距離,就是以View左邊緣為原點(diǎn)到開(kāi)始滑動(dòng)的距離,所以向右邊滑動(dòng)為負(fù)值

*/

private void scrollRight() {

removeDirection = RemoveDirection.RIGHT;

final int delta = (screenWidth + itemView.getScrollX());

// 調(diào)用startScroll方法來(lái)設(shè)置一些滾動(dòng)的參數(shù),我們?cè)赾omputeScroll()方法中調(diào)用scrollTo來(lái)滾動(dòng)item

scroller.startScroll(itemView.getScrollX(), 0, -delta, 0,

Math.abs(delta));

postInvalidate(); // 刷新itemView

}

/**

* 向左滑動(dòng),根據(jù)上面我們知道向左滑動(dòng)為正值

*/

private void scrollLeft() {

removeDirection = RemoveDirection.LEFT;

final int delta = (screenWidth - itemView.getScrollX());

// 調(diào)用startScroll方法來(lái)設(shè)置一些滾動(dòng)的參數(shù),我們?cè)赾omputeScroll()方法中調(diào)用scrollTo來(lái)滾動(dòng)item

scroller.startScroll(itemView.getScrollX(), 0, delta, 0,

Math.abs(delta));

postInvalidate(); // 刷新itemView

}

/**

* 根據(jù)手指滾動(dòng)itemView的距離來(lái)判斷是滾動(dòng)到開(kāi)始位置還是向左或者向右滾動(dòng)

*/

private void scrollByDistanceX() {

// 如果向左滾動(dòng)的距離大于屏幕的三分之一,就讓其刪除

if (itemView.getScrollX() = screenWidth / 3) {

scrollLeft();

} else if (itemView.getScrollX() = -screenWidth / 3) {

scrollRight();

} else {

// 滾回到原始位置,為了偷下懶這里是直接調(diào)用scrollTo滾動(dòng)

itemView.scrollTo(0, 0);

}

}

/**

* 處理我們拖動(dòng)ListView item的邏輯

*/

@Override

public boolean onTouchEvent(MotionEvent ev) {

if (isSlide slidePosition != AdapterView.INVALID_POSITION) {

addVelocityTracker(ev);

final int action = ev.getAction();

int x = (int) ev.getX();

switch (action) {

case MotionEvent.ACTION_MOVE:

int deltaX = downX - x;

downX = x;

// 手指拖動(dòng)itemView滾動(dòng), deltaX大于0向左滾動(dòng),小于0向右滾

itemView.scrollBy(deltaX, 0);

break;

case MotionEvent.ACTION_UP:

int velocityX = getScrollVelocity();

if (velocityX SNAP_VELOCITY) {

scrollRight();

} else if (velocityX -SNAP_VELOCITY) {

scrollLeft();

} else {

scrollByDistanceX();

}

recycleVelocityTracker();

// 手指離開(kāi)的時(shí)候就不響應(yīng)左右滾動(dòng)

isSlide = false;

break;

}

return true; // 拖動(dòng)的時(shí)候ListView不滾動(dòng)

}

//否則直接交給ListView來(lái)處理onTouchEvent事件

return super.onTouchEvent(ev);

}

@Override

public void computeScroll() {

// 調(diào)用startScroll的時(shí)候scroller.computeScrollOffset()返回true,

if (scroller.computeScrollOffset()) {

// 讓ListView item根據(jù)當(dāng)前的滾動(dòng)偏移量進(jìn)行滾動(dòng)

itemView.scrollTo(scroller.getCurrX(), scroller.getCurrY());

postInvalidate();

// 滾動(dòng)動(dòng)畫(huà)結(jié)束的時(shí)候調(diào)用回調(diào)接口

if (scroller.isFinished()) {

if (mRemoveListener == null) {

throw new NullPointerException(RemoveListener is null, we should called setRemoveListener());

}

itemView.scrollTo(0, 0);

mRemoveListener.removeItem(removeDirection, slidePosition);

}

}

}

/**

* 添加用戶的速度跟蹤器

*

* @param event

*/

private void addVelocityTracker(MotionEvent event) {

if (velocityTracker == null) {

velocityTracker = VelocityTracker.obtain();

}

velocityTracker.addMovement(event);

}

/**

* 移除用戶速度跟蹤器

*/

private void recycleVelocityTracker() {

if (velocityTracker != null) {

velocityTracker.recycle();

velocityTracker = null;

}

}

/**

* 獲取X方向的滑動(dòng)速度,大于0向右滑動(dòng),反之向左

*

* @return

*/

private int getScrollVelocity() {

velocityTracker.computeCurrentVelocity(1000);

int velocity = (int) velocityTracker.getXVelocity();

return velocity;

}

/**

*

* 當(dāng)ListView item滑出屏幕,回調(diào)這個(gè)接口

* 我們需要在回調(diào)方法removeItem()中移除該Item,然后刷新ListView

*

* @author xiaanming

*

*/

public interface RemoveListener {

public void removeItem(RemoveDirection direction, int position);

}

}


網(wǎng)頁(yè)題目:android側(cè)滑,Android側(cè)滑兩段刪除
URL分享:http://www.dlmjj.cn/article/dsijjjc.html