真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Android實(shí)現(xiàn)頁面翻轉(zhuǎn)和自動翻轉(zhuǎn)功能

1. 效果圖,本功能用了ViewFlipper和GestureDetector (手勢檢測器)兩個關(guān)鍵技術(shù)點(diǎn):

成都創(chuàng)新互聯(lián)公司專注于企業(yè)成都全網(wǎng)營銷、網(wǎng)站重做改版、南城網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5高端網(wǎng)站建設(shè)、商城網(wǎng)站制作、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)營銷網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為南城等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。

Android實(shí)現(xiàn)頁面翻轉(zhuǎn)和自動翻轉(zhuǎn)功能

2. 先寫好布局文件,這里用到了ViewFlipper類,用于切換視圖,畢竟ViewFlipper見得少,先介紹一下。

在xml布局中的方法介紹:

android:autoStart: 設(shè)置自動加載下一個View 
android:flipInterval:設(shè)置View之間切換的時(shí)間間隔
android:inAnimation: 設(shè)置切換View的進(jìn)入動畫
android:outAnimation:設(shè)置切換View的退出動畫

當(dāng)然同樣的在代碼中也可以設(shè)置:

isFlipping: 判斷View切換是否正在進(jìn)行
setFilpInterval:設(shè)置View之間切換的時(shí)間間隔
startFlipping: 開始View的切換,而且會循環(huán)進(jìn)行
stopFlipping: 停止View的切換
setOutAnimation:設(shè)置切換View的退出動畫
setInAnimation: 設(shè)置切換View的進(jìn)入動畫
showNext: 顯示ViewFlipper里的下一個View
showPrevious: 顯示ViewFlipper里的上一個View

<?xml version="1.0" encoding="utf-8"?>

 
  

3. 接下來是代碼部分,首頁介紹一下GestureDetector :

GestureDetector.OnGestureListener里包含的事件處理方法如下:
➢boolean onDown(MotionEvent e):當(dāng)觸碰事件按下時(shí)觸發(fā)該方法。
➢boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY):當(dāng)用戶手指在觸摸屏_上“拖過”時(shí)觸發(fā)該方法。其中velocityX、velocityY 代表“拖過”動作在橫向、縱向,上的速度。
➢abstract void onL ongPress(MotionEvente):當(dāng)用戶手指在屏幕上長按時(shí)觸發(fā)該方法。
➢boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY):當(dāng)用戶手指在屏幕上“滾動”時(shí)觸發(fā)該方法。
➢void onShowPress(MotionEvent e):當(dāng)用戶手指在觸摸屏上按下,而且還未移動和松開時(shí)觸發(fā)該方法。
➢boolean onSingleTapUp(MotionEvent e): 用戶手指在觸摸屏上的輕擊事件將會觸發(fā)該方法。

*使用Android的手勢檢測只需兩個步驟。

➊創(chuàng)建一個GestureDetector 對象。創(chuàng)建該對象時(shí)必須實(shí)現(xiàn)一個GestureDetector.OnGestureListener監(jiān)聽器實(shí)例。

❷為應(yīng)用程序的Activity (偶爾也可為特定組件)的TouchEvent事件綁定監(jiān)聽器(對應(yīng)gestureDetector = new GestureDetector(this, this);),在事件處理中指定把Activity (或特定組件),上的TouchEvent事件交給GestureDetector處理。(對應(yīng)return gestureDetector.onTouchEvent(event);)*

package com.example.mygesture.slide;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.GestureDetector;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.ImageView;
import android.widget.ViewFlipper;
import com.example.mygesture.R;
public class Main2Activity extends AppCompatActivity implements GestureDetector.OnGestureListener { //實(shí)現(xiàn)手勢檢測器接口
 GestureDetector gestureDetector; //定義手勢檢測器
 ViewFlipper viewFlipper;  
// Animation[] animations=new Animation[4]; //注釋的部分為添加動畫效果
 int distance=50;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main2);
  init();
 }
 private void init() {
  gestureDetector = new GestureDetector(this, this);//實(shí)例化GestureDetector
  viewFlipper=findViewById(R.id.activity_main2_vf);
  viewFlipper.addView(addImageView(R.drawable.q1));//添加圖片
  viewFlipper.addView(addImageView(R.drawable.q2));
  viewFlipper.addView(addImageView(R.drawable.q3));
  viewFlipper.addView(addImageView(R.drawable.q4));
//  animations[0]=AnimationUtils.loadAnimation(this,R.anim.left_in);
//  animations[1]=AnimationUtils.loadAnimation(this,R.anim.left_out);
//  animations[2]=AnimationUtils.loadAnimation(this,R.anim.right_in);
//  animations[3]=AnimationUtils.loadAnimation(this,R.anim.right_out);
 }
 private View addImageView(int resId) {
  ImageView imageView=new ImageView(this);
  imageView.setImageResource(resId);
  imageView.setScaleType(ImageView.ScaleType.CENTER);
  return imageView;
 }
 @Override
 public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
  viewFlipper.stopFlipping();  //當(dāng)滑動時(shí)停止自動翻轉(zhuǎn)
  if (e1.getX()-e2.getX()>distance){  //當(dāng)從右向左滑動時(shí)
//   viewFlipper.setInAnimation(animations[0]); 
//   viewFlipper.setOutAnimation(animations[1]);
   viewFlipper.showPrevious();  //返回上一張視圖
   return true;
  }if (e2.getX()-e1.getX()>distance){  //當(dāng)從左向右滑動時(shí)
//   viewFlipper.setInAnimation(animations[2]);
//   viewFlipper.setOutAnimation(animations[3]);
   viewFlipper.showNext();  //切換下一張視圖
   return true;
  }
  return false;
 }
 @Override
 public boolean onTouchEvent(MotionEvent event) {
  return gestureDetector.onTouchEvent(event); //綁定觸摸事件
 }
 public void start(View view) {
  viewFlipper.startFlipping();  //開始自動翻轉(zhuǎn),與flipInterval配套使用,缺一不可 
 }
 public void stop(View view) {
  viewFlipper.stopFlipping();  //停止自動翻轉(zhuǎn) 
 }
 @Override
 public boolean onDown(MotionEvent e) {
  return false;
 }
 @Override
 public void onShowPress(MotionEvent e) {
 }
 @Override
 public boolean onSingleTapUp(MotionEvent e) {
  return false;
 }
 @Override
 public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
  return false;
 }
 @Override
 public void onLongPress(MotionEvent e) {
 }
}

簡單的翻頁效果已經(jīng)完成了

總結(jié)

以上所述是小編給大家介紹的Android實(shí)現(xiàn)頁面翻轉(zhuǎn)和自動翻轉(zhuǎn)功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!


名稱欄目:Android實(shí)現(xiàn)頁面翻轉(zhuǎn)和自動翻轉(zhuǎn)功能
轉(zhuǎn)載來于:http://weahome.cn/article/pcdjsd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部