Android圖片處理教程之全景查看效果實現(xiàn)
前言
在玩頭條的時候,現(xiàn)在我們會發(fā)現(xiàn)有很多的全景圖的廣告這樣快看起來非常的酷。今天就來說說這個小效果的實現(xiàn)
PS:Android對于圖片處理這塊資源還是挺多的,之前用OpenGL制作圖片的全景效果,耗時耗力,而且只能點擊進(jìn)去后看到,但是效果是非常的號,今天所寫的是編寫好的一個圖片控件,只要拿來用就可以了。效果不是那么好,處理的之后就是一張圖片截取中間部分放大再顯示在屏幕中間,通過擺動手機查看被遮擋部分
如圖:一開始圖片是這樣的


上面就是效果圖了
實現(xiàn)方法如下
1:添加依賴
//全景圖片 compile 'com.gjiazhe:PanoramaImageView:1.0'
2:使用控件
<com.gjiazhe.panoramaimageview.PanoramaImageView android:id="@+id/panorama_image_view" android:layout_width="match_parent" android:layout_height="match_parent" android:src="@drawable/timg" app:piv_enablePanoramaMode="true" app:piv_show_scrollbar="true" app:piv_invertScrollDirection="false" />
布局的根目錄一定要加上
xmlns:app=http://schemas.android.com/apk/res-auto
這里面有三個屬性(其中三個)
一個是app:piv_enablePanoramaMode,使用全景效果模式,app:piv_show_scrollbar滾動條顯示,app:piv_invertScrollDirection顛倒?jié)L動方向,不同的值就會呈現(xiàn)不同的效果。
3:注冊GyroscopeObserver
在使用PanoramaImageView的Activity或Fragment中,您應(yīng)該在onResume()中注冊GyroscopeObserver,并記得在onPause()中注銷它。
public class MyActivity extends AppCompatActivity {
private GyroscopeObserver gyroscopeObserver;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// Initialize GyroscopeObserver.
gyroscopeObserver = new GyroscopeObserver();
// Set the maximum radian the device should rotate to show image's bounds.
// It should be set between 0 and π/2.
// The default value is π/9.
gyroscopeObserver.setMaxRotateRadian(Math.PI/9);
PanoramaImageView panoramaImageView = (PanoramaImageView) findViewById(R.id.panorama_image_view);
// Set GyroscopeObserver for PanoramaImageView.
panoramaImageView.setGyroscopeObserver(gyroscopeObserver);
}
@Override
protected void onResume() {
super.onResume();
// Register GyroscopeObserver.
gyroscopeObserver.register(this);
}
@Override
protected void onPause() {
super.onPause();
// Unregister GyroscopeObserver.
gyroscopeObserver.unregister();
}
}
設(shè)置OnPanoramaScrollListener以觀察滾動狀態(tài) 如果要在圖像滾動時獲得回調(diào),PanoramaImageView需要設(shè)置OnPanoramaScrollListener。
panoramaImageView.setOnPanoramaScrollListener(new PanoramaImageView.OnPanoramaScrollListener() {
@Override
public void onScrolled(PanoramaImageView view, float offsetProgress) {
// Do something here.
// The offsetProgress range from -1 to 1, indicating the image scrolls
// from left(top) to right(bottom).
}
});
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
Android studio2.3.3升級到3.1.2坑(小記)
這篇文章主要介紹了Android studio2.3.3升級3.1.2坑(小記),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09
基于Android CALL && SendMes Test的相關(guān)介紹
本篇文章小編為大家介紹,Android CALL && SendMes Test 需要的朋友參考下2013-04-04
Android 修改系統(tǒng)關(guān)機動畫的實現(xiàn)
這篇文章主要介紹了Android 修改系統(tǒng)關(guān)機動畫的實現(xiàn)的相關(guān)資料,需要的朋友可以參考下2016-10-10
Android Studio無法改變Button背景顏色解決辦法
今天我來和大家探討一個在Android開發(fā)中常見但可能讓初學(xué)者感到困惑的問題,如何在Android Studio中改變Button的背景顏色,這個問題看似簡單,但實際操作中可能會遇到一些意想不到的挑戰(zhàn),接下來,我將從多個角度為大家提供解決方案,需要的朋友可以參考下2024-05-05
Flutter實現(xiàn)倒計時秒數(shù)轉(zhuǎn)時分秒然后倒計時功能
有一個需求,需要在頁面進(jìn)行顯示倒計時,倒計時結(jié)束后,做相應(yīng)的邏輯處理,這篇文章主要介紹了Flutter實現(xiàn)倒計時功能,秒數(shù)轉(zhuǎn)時分秒,然后倒計時,需要的朋友可以參考下2023-08-08
Android編程實現(xiàn)自定義PopupMenu樣式示例【顯示圖標(biāo)與設(shè)置RadioButton圖標(biāo)】
這篇文章主要介紹了Android編程實現(xiàn)自定義PopupMenu樣式功能,結(jié)合實例形式分析了Android顯示圖標(biāo)與設(shè)置RadioButton圖標(biāo)相關(guān)操作技巧,需要的朋友可以參考下2017-01-01

