Android中通過ImageSwitcher實現相冊滑動查看照片功能(附代碼下載)

来源:https://www.cnblogs.com/badaoliumangqizhi/archive/2020/01/06/12159135.html
-Advertisement-
Play Games

場景 效果 註: 博客: https://blog.csdn.net/badao_liumang_qizhi 關註公眾號 霸道的程式猿 獲取編程相關電子書、教程推送與免費下載。 實現 將需要滾動查看的照片複製到res/drawable下 這裡只准備了兩張bg01.jpg和bg02.jpg 在滾動時需 ...


場景

效果

 

 

 

註:

博客:
https://blog.csdn.net/badao_liumang_qizhi
關註公眾號
霸道的程式猿
獲取編程相關電子書、教程推送與免費下載。

實現

將需要滾動查看的照片複製到res/drawable下

這裡只准備了兩張bg01.jpg和bg02.jpg

 

 

 

在滾動時需要用到左進右出和左出右進的動畫,所以在res下新建anim目錄,在目錄下新建四種動畫的xml文件

 

 

 

具體代碼參照示例代碼。

然後打開佈局文件activity_image_switcher.xml

將佈局修改為相對佈局RelativeLayout,並添加一個ImageSwitcher,設置其ID屬性。

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".ImageSwitcherActivity">


    <ImageSwitcher
        android:id="@+id/imageSwitcher"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>

</RelativeLayout>

 

然後來到ImageSwitcherActivity

首先聲明一些私有變數,用來存儲照片資源數組、數組索引、滑鼠放下和離開的X坐標等。  

   //圖片資源數組
    private int[] arrayPicture = new int[]{
            R.drawable.bg01,R.drawable.bg02
    };
    private ImageSwitcher imageSwitcher;
    private  int index;
    private  float touchDowmX;
    private  float touchUpX;

 

然後通過id獲取ImageSwitcher並設置其視圖工廠

        //獲取imageSwitch
        imageSwitcher =(ImageSwitcher) findViewById(R.id.imageSwitcher);
        //設置視圖工廠
        imageSwitcher.setFactory(new ViewSwitcher.ViewFactory() {
            @Override
            public View makeView() {
                ImageView imageView = new ImageView(ImageSwitcherActivity.this);
                imageView.setImageResource(arrayPicture[index]);
                return imageView;
            }
        });

然後設置ImageSwitcher的觸碰的監聽器

通過

event.getAction() == MotionEvent.ACTION_DOWN

 

判斷如果是滑鼠按下,則記錄滑鼠按下時的坐標。

否則通過

event.getAction() ==MotionEvent.ACTION_UP

 

判斷如果是滑鼠抬起,則記錄抬起時的X坐標。

此時再通過

touchUpX-touchDowmX >100

 

即抬起時的X坐標減去落下時的X坐標大於100則認為是從左往右滑動。

此時圖片的索引通過三目表達式進行判斷。

index = index==0?arrayPicture.length-1:index-1;

 

如果當前索引為0,即為第一張照片時,則從左往右滑動後,應該是最後一張照片,即照片索引為圖片數組的長度減一。

然後通過

 imageSwitcher.setInAnimation(AnimationUtils.loadAnimation(ImageSwitcherActivity.this, R.anim.slide_in_left));

 

設置左邊滑進的動畫

再通過

imageSwitcher.setOutAnimation(AnimationUtils.loadAnimation(ImageSwitcherActivity.this, R.anim.slide_out_right));

 

設置右邊滑出的動畫

最後通過

imageSwitcher.setImageResource(arrayPicture[index]);

 

設置圖片索引。

同理如果通過

touchDowmX - touchUpX >100

 

則認為是從右往左滑。

同樣通過三目表達式

index = index==arrayPicture.length -1?0:index+1;

 

如果是最後一張照片,即索引為數組的長度 -1 ,則再往左滑 該是第一張照片,即索引為0  否則就索引+1。

然後通過

imageSwitcher.setInAnimation(AnimationUtils.loadAnimation(ImageSwitcherActivity.this, R.anim.slide_in_right));

 

設置右邊滑進的動畫

再通過

imageSwitcher.setOutAnimation(AnimationUtils.loadAnimation(ImageSwitcherActivity.this, R.anim.slide_out_left));

 

設置左邊滑出的動畫

最後通過

imageSwitcher.setImageResource(arrayPicture[index]);

 

設置圖片

完整示例代碼

package com.badao.relativelayouttest;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.view.MotionEvent;
import android.view.View;
import android.view.animation.AnimationUtils;
import android.widget.ImageSwitcher;
import android.widget.ImageView;
import android.widget.ViewSwitcher;

public class ImageSwitcherActivity extends AppCompatActivity {

    //圖片資源數組
    private int[] arrayPicture = new int[]{
            R.drawable.bg01,R.drawable.bg02
    };
    private ImageSwitcher imageSwitcher;
    private  int index;
    private  float touchDowmX;
    private  float touchUpX;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_image_switcher);
        //獲取imageSwitch
        imageSwitcher =(ImageSwitcher) findViewById(R.id.imageSwitcher);
        //設置視圖工廠
        imageSwitcher.setFactory(new ViewSwitcher.ViewFactory() {
            @Override
            public View makeView() {
                ImageView imageView = new ImageView(ImageSwitcherActivity.this);
                imageView.setImageResource(arrayPicture[index]);
                return imageView;
            }
        });

        //設置imageSwitcher 觸碰監聽器
        imageSwitcher.setOnTouchListener(new View.OnTouchListener() {
            @Override
            public boolean onTouch(View v, MotionEvent event) {
                //如果是滑鼠按下
                if(event.getAction() == MotionEvent.ACTION_DOWN)
                {
                    //記錄按下時的X坐標
                    touchDowmX = event.getX();
                    return  true;
                }else if(event.getAction() ==MotionEvent.ACTION_UP) //如果是滑鼠抬起
                {
                    //記錄抬起時的X坐標
                    touchUpX = event.getX();
                    //如果是從左向右滑動
                    if(touchUpX-touchDowmX >100)
                    {
                        //如果是第一張圖片則從左向右滑後下標是數組的長度-1,即最後一張,如果不是則索引-1
                        index = index==0?arrayPicture.length-1:index-1;
                        //設置左邊滑進的動畫
                        imageSwitcher.setInAnimation(AnimationUtils.loadAnimation(ImageSwitcherActivity.this, R.anim.slide_in_left));
                        //設置右邊滑出的動畫
                        imageSwitcher.setOutAnimation(AnimationUtils.loadAnimation(ImageSwitcherActivity.this, R.anim.slide_out_right));
                        //設置圖片索引
                        imageSwitcher.setImageResource(arrayPicture[index]);
                    }
                    //否則認為是從右往左滑
                    else if(touchDowmX - touchUpX >100)
                    {
                        //如果是最後一張照片,即索引為數組的長度 -1 ,則再往左滑 該是第一張照片,即索引為0  否則就索引+1
                        index = index==arrayPicture.length -1?0:index+1;
                        //設置右邊滑進的動畫
                        imageSwitcher.setInAnimation(AnimationUtils.loadAnimation(ImageSwitcherActivity.this, R.anim.slide_in_right));
                        //設置左邊滑出的動畫
                        imageSwitcher.setOutAnimation(AnimationUtils.loadAnimation(ImageSwitcherActivity.this, R.anim.slide_out_left));
                        //設置圖片索引
                        imageSwitcher.setImageResource(arrayPicture[index]);
                    }
                }
                return false;
            }
        });

    }
}

 

示例代碼下載

關註公眾號:

霸道的程式猿

回覆:

Android相冊滑動代碼


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 目錄 一、安裝前準備 二、安裝MySQL 三、設置遠程登錄 四、安裝問題解決 五、設置MySQL開機自啟 一、安裝前準備 1、在官網下載MySQL安裝包(註意下載的安裝包類型) 2、查看是否安裝mariadb # rpm -qa | grep mariadb 3、卸載mariadb # rpm -e ...
  • 目錄 一、###MySQL登錄和退出 二、###MySQL常用命令 三、###MySQL語法規範 四、###基礎查詢 五、###條件查詢 六、###排序查詢 七、###常見函數的學習 八、###分組查詢 九、###連接查詢 十、###子查詢 十一、###分頁查詢 十二、###聯合查詢 十三、###D ...
  • 這裡的Redis主從結構可以是簡單的主從,sentinel,redis cluster中的主從等。wait命令的作用:此命令將阻塞當前客戶端,直到當前Session連接(主節點上)所有的寫命令都被傳送到指定數據量的slave節點。如果到達超時(以毫秒為單位),則即使尚未完全傳送到達指定數量的salv ...
  • 函數語法:FIND_IN_SET(str,strlist) 直接上圖: ...
  • 使用數據泵技術實現邏輯備份 數據泵概述 數據泵(DATA PUMP)是一種在資料庫之間、資料庫與操作系統之間,高速傳輸數據的技術(10g推出)。 邏輯備份概述 邏輯備份是對資料庫對象(如用戶、表、存儲過程等)利用EXPORT等工具進行導出 物理備份對比 物理備份是轉儲ORACLE物理文件(如數據文件 ...
  • ## 鏈接資料庫 ``` ## -h/-u這些後面沒有空格 ./bin/mysql -h[ip地址] -P[埠號] -u[用戶名] -p[密碼] ``` ## 查看建表語句 ```sql show create table [table_name] ``` ## 列出所有的資料庫 ```sql s... ...
  • 問題出現情景: 三節點12C rac某次擴存儲,兩個節點同時重啟,其中一個節點 ora.rac1.vip 1 ONLINE INTERMEDIATE rac2 FAILED OVER 出現原因可能是同時啟動造成VIP資源搶奪所致。重啟集群監聽,解決 srvctl stop listener -l L ...
  • 本文源碼: "GitHub·點這裡" || "GitEE·點這裡" 一、存儲過程 1、概念簡介 存儲程式是被存儲在伺服器中的組合SQL語句,經編譯創建並保存在資料庫中,用戶可通過存儲過程的名字調用執行。存儲過程核心思想就是資料庫SQL語言層面的封裝與重用性。使用存儲過程可以較少應用系統的業務複雜性, ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...