android仿知乎ScrollView滾動(dòng)改變標(biāo)題欄透明度
刷知乎的時(shí)候看到,專(zhuān)題欄里面 往下滾動(dòng)標(biāo)題欄會(huì)由透明逐漸變藍(lán)色,覺(jué)得這個(gè)效果不錯(cuò),就想自己寫(xiě)一下
這是自己實(shí)現(xiàn)的效果圖:
說(shuō)下實(shí)現(xiàn)思路:
1、先獲取頂部圖片的高度height,這個(gè)有3種方式獲取,我用的是監(jiān)聽(tīng)onGlobalLayout方法的回調(diào)
2、監(jiān)聽(tīng)scrollview的滾動(dòng)坐標(biāo),原生的沒(méi)有這個(gè)監(jiān)聽(tīng),需要我們自己寫(xiě)個(gè)view繼承scrollview,然后重寫(xiě)onScrollChanged()方法,創(chuàng)建一個(gè)監(jiān)聽(tīng),在這個(gè)方法里面回調(diào)
3、根據(jù)圖片高度height和滾動(dòng)的縱坐標(biāo)y進(jìn)行判斷,算出比例,透明度范圍0~255,根據(jù)比例設(shè)置改變的透明度,當(dāng)y>height是不做改變
實(shí)現(xiàn)代碼:
import com.example.d_changealphabyscroll.widget.ObservableScrollView; import com.example.d_changealphabyscroll.widget.ObservableScrollView.ScrollViewListener; import android.app.Activity; import android.graphics.Color; import android.os.Bundle; import android.util.Log; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.view.ViewTreeObserver; import android.view.ViewTreeObserver.OnGlobalLayoutListener; import android.webkit.WebSettings; import android.webkit.WebView; import android.webkit.WebViewClient; import android.widget.ImageView; import android.widget.ScrollView; public class MainActivity extends Activity implements ScrollViewListener{ private View layoutHead; private ObservableScrollView scrollView; private ImageView imageView; private WebView webView; private int height ; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initView(); } private void initView() { webView = (WebView) findViewById(R.id.webview1); scrollView = (ObservableScrollView) findViewById(R.id.scrollview); layoutHead = findViewById(R.id.view_head); imageView = (ImageView) findViewById(R.id.imageView1); layoutHead.setBackgroundColor(Color.argb(0, 0xfd, 0x91, 0x5b)); //初始化webview //啟用支持javascript WebSettings settings = webView.getSettings(); settings.setJavaScriptEnabled(true); webView.loadUrl("http://www.topit.me/"); //覆蓋WebView默認(rèn)使用第三方或系統(tǒng)默認(rèn)瀏覽器打開(kāi)網(wǎng)頁(yè)的行為,使網(wǎng)頁(yè)用WebView打開(kāi) webView.setWebViewClient(new WebViewClient(){ @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { //返回值是true的時(shí)候控制去WebView打開(kāi),為false調(diào)用系統(tǒng)瀏覽器或第三方瀏覽器 view.loadUrl(url); return true; } }); //獲取頂部圖片高度后,設(shè)置滾動(dòng)監(jiān)聽(tīng) ViewTreeObserver vto = imageView.getViewTreeObserver(); vto.addOnGlobalLayoutListener(new OnGlobalLayoutListener() { @Override public void onGlobalLayout() { imageView.getViewTreeObserver().removeGlobalOnLayoutListener(this); height = imageView.getHeight(); imageView.getWidth(); scrollView.setScrollViewListener(MainActivity.this); } }); } @Override public void onScrollChanged(ObservableScrollView scrollView, int x, int y, int oldx, int oldy) { // Log.i("TAG","y--->"+y+" height-->"+height); if(y<=height){ float scale =(float) y /height; float alpha = (255 * scale); // Log.i("TAG","alpha--->"+alpha); //layout全部透明 // layoutHead.setAlpha(scale); //只是layout背景透明(仿知乎滑動(dòng)效果) layoutHead.setBackgroundColor(Color.argb((int) alpha, 0xfd, 0x91, 0x5b)); } } }
帶滾動(dòng)監(jiān)聽(tīng)的scrollview
import android.content.Context; import android.util.AttributeSet; import android.widget.ScrollView; /** * 帶滾動(dòng)監(jiān)聽(tīng)的scrollview * */ public class ObservableScrollView extends ScrollView { public interface ScrollViewListener { void onScrollChanged(ObservableScrollView scrollView, int x, int y, int oldx, int oldy); } private ScrollViewListener scrollViewListener = null; public ObservableScrollView(Context context) { super(context); } public ObservableScrollView(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } public ObservableScrollView(Context context, AttributeSet attrs) { super(context, attrs); } public void setScrollViewListener(ScrollViewListener scrollViewListener) { this.scrollViewListener = scrollViewListener; } @Override protected void onScrollChanged(int x, int y, int oldx, int oldy) { super.onScrollChanged(x, y, oldx, oldy); if (scrollViewListener != null) { scrollViewListener.onScrollChanged(this, x, y, oldx, oldy); } } }
Demo下載地址:點(diǎn)擊打開(kāi)鏈接
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
android采用FFmpeg實(shí)現(xiàn)音視頻合成與分離
這篇文章主要為大家詳細(xì)介紹了android采用FFmpeg實(shí)現(xiàn)音視頻合成與分離,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12Flutter?Android多窗口方案落地實(shí)戰(zhàn)
這篇文章主要為大家介紹了Flutter?Android多窗口方案落地實(shí)戰(zhàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02解析:繼承ViewGroup后的子類(lèi)如何重寫(xiě)onMeasure方法
本篇文章是對(duì)繼承ViewGroup后的子類(lèi)如何重寫(xiě)onMeasure方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06Android開(kāi)發(fā)實(shí)現(xiàn)加載網(wǎng)絡(luò)圖片并下載至本地SdCard的方法
這篇文章主要介紹了Android開(kāi)發(fā)實(shí)現(xiàn)加載網(wǎng)絡(luò)圖片并下載至本地SdCard的方法,涉及Android圖片文件的讀取、保存及權(quán)限相關(guān)操作技巧,需要的朋友可以參考下2018-01-01Android中通過(guò)反射實(shí)現(xiàn)圓角ImageView代碼實(shí)例
這篇文章主要介紹了Android中通過(guò)反射實(shí)現(xiàn)圓角ImageView代碼實(shí)例,本文直接給出核心實(shí)現(xiàn)代碼,需要的朋友可以參考下2015-04-04Android WebView的使用方法及與JS 相互調(diào)用
這篇文章主要介紹了Android WebView的使用方法及與JS 相互調(diào)用的相關(guān)資料,WebView 是 Android 中一個(gè)非常實(shí)用的組​件, WebView 可以使得網(wǎng)頁(yè)輕松的內(nèi)嵌到app里,還可以直接跟js相互調(diào)用,需要的朋友可以參考下2017-07-07Android布局技巧之創(chuàng)建可重用的UI組件
這篇文章主要為大家詳細(xì)介紹了Android布局技巧之創(chuàng)建可重用的UI組件,文中提到了include標(biāo)簽的使用方法,感興趣的小伙伴們可以參考一下2016-05-05Android動(dòng)畫(huà)之漸變動(dòng)畫(huà)(Tween Animation)詳解 (漸變、縮放、位移、旋轉(zhuǎn))
這篇文章主要介紹了Android動(dòng)畫(huà)之漸變動(dòng)畫(huà)(Tween Animation)用法,結(jié)合實(shí)例形式詳細(xì)分析了Android漸變動(dòng)畫(huà)Tween Animation實(shí)現(xiàn)漸變,縮放,位移,旋轉(zhuǎn)等技巧,需要的朋友可以參考下2016-01-01