日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
Android自定義標(biāo)題欄:顯示網(wǎng)頁加載進(jìn)度

這陣子在做lephone的適配,測試組提交一個bug:標(biāo)題欄的文字較長時沒有顯示完全,其實這并不能算個bug,并且這個問題在以前其他機(jī)器也沒有出現(xiàn),只是說在Lephone的這個平臺上顯示得不怎么美觀,因為聯(lián)想將原生的標(biāo)題欄UI進(jìn)行了修改。修改的過程中遇到了一個難題,系統(tǒng)自帶的那個標(biāo)題欄進(jìn)度總能夠到達(dá)100%后漸退,但是我每次***到100%那一段顯示不全,嘗試了用線程程序死了卡主了不說,還是一樣的效果,后來同事一句話提醒了我用動畫。確實是這樣我猜系統(tǒng)的也是這樣實現(xiàn)的,等進(jìn)度到達(dá)100%后,用動畫改變它的透明度就ok了。

實現(xiàn)的效果:標(biāo)題欄顯示網(wǎng)頁標(biāo)題并且滾動,并且用進(jìn)度條顯示網(wǎng)頁的加載進(jìn)度(重新自定義標(biāo)題欄,lephone修改后的都帶有一個返回按鈕,并且標(biāo)題文本和進(jìn)度條是Frame布局的不怎么好看)。

1、首先定義一個RelativeLayout布局文件 broser_custom_title.xml (AlwaysMarqueeTextView這個類重寫了TextView,實現(xiàn)一個跑馬燈的效果,網(wǎng)上能夠找到)

 
 
 
  1.  
  2.   xmlns:Android="http://schemas.android.com/apk/res/android" 
  3.   android:layout_width="fill_parent" 
  4.   android:layout_height="fill_parent">  
  5.       
  6.             android:id="@+id/tvtitle" 
  7.             android:layout_width="fill_parent" 
  8.             android:layout_height="wrap_content" 
  9.  android:focusableInTouchMode="true" 
  10.             android:singleLine="true" 
  11.  android:ellipsize="marquee" 
  12.             android:focusable="false" 
  13.  android:marqueeRepeatLimit="marquee_forever" 
  14.             android:textSize="20sp" 
  15.  android:layout_centerVertical="true"/>  
  16.     
  17.          android:layout_width="fill_parent" 
  18.  android:layout_height="wrap_content" 
  19.         style="?android:attr/progressBarStyleHorizontal" 
  20.         android:visibility="gone" 
  21.  android:layout_alignParentBottom="true" 
  22.  
  23.                 >  
  24.  

2、繼承WebChromeClient,重寫onProgressChanged和onReceivedTitle事件(進(jìn)度條加載完成后使用動畫漸退)

 
 
 
  1. public class MyWebChromeClient extends WebChromeClient {  
  2.     private Activity activity;  
  3.     private ProgressBar pb;  
  4.     private TextView tvtitle;  
  5.     public MyWebChromeClient(Activity activity) {  
  6.         this.activity = activity;  
  7.     }  
  8.     Animation animation;  
  9.       @Override 
  10.     public void onProgressChanged(WebView view, int newProgress) {  
  11.         pb=(ProgressBar)activity.findViewById(R.id.pb);  
  12.         pb.setMax(100);  
  13.         if(newProgress<100){  
  14.             if(pb.getVisibility()==View.GONE)  
  15.                 pb.setVisibility(View.VISIBLE);  
  16.             pb.setProgress(newProgress);  
  17.         }else{  
  18.             pb.setProgress(100);  
  19.             animation=AnimationUtils.loadAnimation(activity, R.anim.animation);  
  20.             // 運(yùn)行動畫 animation  
  21.               pb.startAnimation(animation);  
  22.               // 將 spinner 的可見性設(shè)置為不可見狀態(tài)  
  23.               pb.setVisibility(View.INVISIBLE);  
  24.          }  
  25.                 super.onProgressChanged(view, newProgress);  
  26.     }  
  27.     @Override 
  28.     public void onReceivedTitle(WebView view, String title) {  
  29.         tvtitle=(TextView)activity.findViewById(R.id.tvtitle);  
  30.         tvtitle.setText(title);  
  31.         super.onReceivedTitle(view, title);  
  32.     }  

3、進(jìn)度條的動畫樣式 res/anim/animation.xml

 
 
 
  1.  
  2.      
  3.           
  4.     

4、碼設(shè)置自定義的標(biāo)題欄

 
 
 
  1. private WebView browser;  
  2. @Override 
  3. public void onCreate(Bundle savedInstanceState)  
  4.       super.onCreate(savedInstanceState);  
  5.     getWindow().requestFeature(Window.FEATURE_CUSTOM_TITLE);  
  6.     setContentView(R.layout.main);  
  7.     getWindow().setFeatureInt(Window.FEATURE_CUSTOM_TITLE, R.layout.broser_custom_title);  
  8.     browser = (WebView) findViewById(R.id.my_browser);  
  9.     // currentWebView=browser;  
  10.     browser.setWebChromeClient(new MyWebChromeClient(Main.this));  
  11.     browser.loadUrl("http://www.163.com");  

【編輯推薦】

  1. 深入理解Android消息處理系統(tǒng)原理
  2. Android用戶界面設(shè)計:框架布局
  3. Android游戲開發(fā):如何實現(xiàn)爆炸效果
  4. 盤點(diǎn)Android開發(fā)者必備的十大開發(fā)工具
  5. Android設(shè)計趨勢分析10則

本文名稱:Android自定義標(biāo)題欄:顯示網(wǎng)頁加載進(jìn)度
鏈接URL:http://www.dlmjj.cn/article/coheodp.html