Android 自定義標(biāo)題欄 顯示網(wǎng)頁(yè)加載進(jìn)度的方法實(shí)例
這陣子在做Lephone的適配,測(cè)試組提交一個(gè)bug:標(biāo)題欄的文字較長(zhǎng)時(shí)沒(méi)有顯示完全,其實(shí)這并不能算個(gè)bug,并且這個(gè)問(wèn)題在以前其他機(jī)器也沒(méi)有出現(xiàn),只是說(shuō)在Lephone的這個(gè)平臺(tái)上顯示得不怎么美觀(guān),因?yàn)槁?lián)想將原生的標(biāo)題欄UI進(jìn)行了修改。修改的過(guò)程中遇到了一個(gè)難題,系統(tǒng)自帶的那個(gè)標(biāo)題欄進(jìn)度總能夠到達(dá)100%后漸退,但是我每次最后到100%那一段顯示不全,嘗試了用線(xiàn)程程序死了卡主了不說(shuō),還是一樣的效果,后來(lái)同事一句話(huà)提醒了我用動(dòng)畫(huà)。確實(shí)是這樣我猜系統(tǒng)的也是這樣實(shí)現(xiàn)的,等進(jìn)度到達(dá)100%后,用動(dòng)畫(huà)改變它的透明度就ok了。
實(shí)現(xiàn)的效果:標(biāo)題欄顯示網(wǎng)頁(yè)標(biāo)題并且滾動(dòng),并且用進(jìn)度條顯示網(wǎng)頁(yè)的加載進(jìn)度(重新自定義標(biāo)題欄,lephone修改后的都帶有一個(gè)返回按鈕,并且標(biāo)題文本和進(jìn)度條是Frame布局的不怎么好看)。
1、首先定義一個(gè)RelativeLayout布局文件 broser_custom_title.xml (AlwaysMarqueeTextView這個(gè)類(lèi)重寫(xiě)了TextView,實(shí)現(xiàn)一個(gè)跑馬燈的效果,網(wǎng)上能夠找到
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<com.android.CustomTitleTest.AlwaysMarqueeTextView
android:id="@+id/tvtitle"
android:layout_width="fill_parent"
android:layout_height="wrap_content" android:focusableInTouchMode="true"
android:singleLine="true" android:ellipsize="marquee"
android:focusable="false" android:marqueeRepeatLimit="marquee_forever"
android:layout_centerVertical="true"/>
<ProgressBar android:id="@+id/pb"
android:layout_width="fill_parent" android:layout_height="2sp"
style="?android:attr/progressBarStyleHorizontal"
android:visibility="gone" android:layout_alignParentBottom="true"
></ProgressBar>
</RelativeLayout>
2、繼承WebChromeClient,重寫(xiě)onProgressChanged和onReceivedTitle事件(進(jìn)度條加載完成后使用動(dòng)畫(huà)漸退)
public class MyWebChromeClient extends WebChromeClient {
private Activity activity;
private ProgressBar pb;
private TextView tvtitle;
public MyWebChromeClient(Activity activity) {
this.activity = activity;
}
Animation animation;
@Override
public void onProgressChanged(WebView view, int newProgress) {
pb=(ProgressBar)activity.findViewById(R.id.pb);
pb.setMax(100);
if(newProgress<100){
if(pb.getVisibility()==View.GONE)
pb.setVisibility(View.VISIBLE);
pb.setProgress(newProgress);
}else{
pb.setProgress(100);
animation=AnimationUtils.loadAnimation(activity, R.anim.animation);
// 運(yùn)行動(dòng)畫(huà) animation
pb.startAnimation(animation);
// 將 spinner 的可見(jiàn)性設(shè)置為不可見(jiàn)狀態(tài)
pb.setVisibility(View.INVISIBLE);
}
super.onProgressChanged(view, newProgress);
}
@Override
public void onReceivedTitle(WebView view, String title) {
tvtitle=(TextView)activity.findViewById(R.id.tvtitle);
tvtitle.setText(title);
super.onReceivedTitle(view, title);
}
}
3、進(jìn)度條的動(dòng)畫(huà)樣式 res/anim/animation.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
<alpha android:fromAlpha="1.0" android:toAlpha="0.0" android:duration="700"/>
</set>
4、碼設(shè)置自定義的標(biāo)題欄
private WebView browser;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
getWindow().requestFeature(Window.FEATURE_CUSTOM_TITLE);
setContentView(R.layout.main);
getWindow().setFeatureInt(Window.FEATURE_CUSTOM_TITLE, R.layout.broser_custom_title);
browser = (WebView) findViewById(R.id.my_browser);
// currentWebView=browser;
browser.setWebChromeClient(new MyWebChromeClient(Main.this));
browser.loadUrl("http://chabaoo.cn");
}
相關(guān)文章
Android音樂(lè)播放器制作 加入控制臺(tái)(三)
這篇文章主要為大家詳細(xì)介紹了Android音樂(lè)播放器的制作方法,如何加入控制臺(tái),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02
很贊的引導(dǎo)界面效果Android控件ImageSwitcher實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了Android控件ImageSwitcher如何實(shí)現(xiàn)很贊的引導(dǎo)界面的具體代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-05-05
Android通過(guò)訪(fǎng)問(wèn)網(wǎng)頁(yè)查看網(wǎng)頁(yè)源碼實(shí)例詳解
這篇文章主要介紹了Android通過(guò)訪(fǎng)問(wèn)網(wǎng)頁(yè)查看網(wǎng)頁(yè)源碼的相關(guān)資料,需要的朋友可以參考下2017-06-06
Android Gradle Build Error:Some file crunching failed, see l
這篇文章主要介紹了Android Gradle Build Error:Some file crunching failed, see logs for details解決辦法的相關(guān)資料,需要的朋友可以參考下2016-11-11
Android實(shí)現(xiàn)手寫(xiě)板功能
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)手寫(xiě)板功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06
Kotlin學(xué)習(xí)筆記之const val與val
這篇文章主要給大家介紹了關(guān)于Kotlin學(xué)習(xí)筆記之const val與val的相關(guān)資料,并給大家介紹了const val和val區(qū)別以及Kotlin中var和val的區(qū)別,需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-05-05
Android下SDL2實(shí)現(xiàn)五子棋游戲
這篇文章主要為大家詳細(xì)介紹了Android下SDL2實(shí)現(xiàn)五子棋游戲的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-02-02
android手機(jī)端與PC端使用adb forword通信
這篇文章主要介紹了android手機(jī)端與PC端使用adb forword通信的相關(guān)資料,需要的朋友可以參考下2017-04-04

