Android自定义标题栏:显示网页加载进度

简介:
+关注继续查看
 

这阵子在做Lephone的适配,测试组提交一个bug:标题栏的文字较长时没有显示完全,其实这并不能算个bug,并且这个问题在以前其他机器也没有出现,只是说在Lephone的这个平台上显示得不怎么美观,因为联想将原生的标题栏UI进行了修改。修改的过程中遇到了一个难题,系统自带的那个标题栏进度总能够到达100%后渐退,但是我每次最后到100%那一段显示不全,尝试了用线程程序死了卡主了不说,还是一样的效果,后来同事一句话提醒了我用动画。确实是这样我猜系统的也是这样实现的,等进度到达100%后,用动画改变它的透明度就ok了。

实现的效果:标题栏显示网页标题并且滚动,并且用进度条显示网页的加载进度(重新自定义标题栏,lephone修改后的都带有一个返回按钮,并且标题文本和进度条是Frame布局的不怎么好看)。

1、首先定义一个RelativeLayout布局文件 broser_custom_title.xml (AlwaysMarqueeTextView这个类重写了TextView,实现一个跑马灯的效果,网上能够找到)


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

.android.customtitletest>

2、继承WebChromeClient,重写onProgressChanged和onReceivedTitle事件(进度条加载完成后使用动画渐退)


  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.             // 运行动画 animation  
  21.               pb.startAnimation(animation);  
  22.               // 将 spinner 的可见性设置为不可见状态  
  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、进度条的动画样式 res/anim/animation.xml


  1. <?xml version="1.0" encoding="utf-8"?> 
  2.     <set xmlns:android="http://schemas.android.com/apk/res/android"> 
  3.          <alpha android:fromAlpha="1.0" android:toAlpha="0.0" android:duration="700"/> 
  4.    </set> 

4、码设置自定义的标题栏


  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");  
相关文章
|
9月前
|
Android开发 C++
Android OpenGL显示任意3D模型文件
Android OpenGL显示任意3D模型文件
Android OpenGL显示任意3D模型文件
|
9月前
|
存储 缓存 Java
Android OpenGL 显示基本图形及相关概念解读
Android OpenGL 显示基本图形及相关概念解读
Android OpenGL 显示基本图形及相关概念解读
|
10月前
|
开发工具 Android开发
Android studio preview不显示
作为一个刚学习Android的小白,装Android studio的过程中就遇到了不少问题,这两天发现preview一直不显示,百度查了一下,很多教程都只是改了一下这里,但是治标不治本啊,新的项目又会出现这个问题。
83 0
Android studio preview不显示
|
11月前
|
XML 缓存 Android开发
Android Studio Dolphin | 2021.3.1不显示布局XML预览
Android Studio Dolphin | 2021.3.1不显示布局XML预览
1828 0
Android Studio Dolphin | 2021.3.1不显示布局XML预览
|
11月前
|
XML SQL 缓存
Android 音乐APP(四)显示专辑图片、本地数据库、自定义通知栏样式、通知栏显示
Android 音乐APP(四)显示专辑图片、本地数据库、自定义通知栏样式、通知栏显示
328 0
Android 音乐APP(四)显示专辑图片、本地数据库、自定义通知栏样式、通知栏显示
|
11月前
|
XML Android开发 数据格式
Android Glide加载网络图片不显示,但用网页打开又正常显示
Android Glide加载网络图片不显示,但用网页打开又正常显示
433 0
Android Glide加载网络图片不显示,但用网页打开又正常显示
|
11月前
|
XML 缓存 API
Android 天气APP(十四)修复UI显示异常、优化业务代码逻辑、增加详情天气显示
Android 天气APP(十四)修复UI显示异常、优化业务代码逻辑、增加详情天气显示
140 0
Android 天气APP(十四)修复UI显示异常、优化业务代码逻辑、增加详情天气显示
|
11月前
|
Android开发
Android 天气APP(六)旋转风车显示风力、风向
Android 天气APP(六)旋转风车显示风力、风向
110 0
Android 天气APP(六)旋转风车显示风力、风向
|
11月前
|
XML Android开发 数据格式
Android控件显示、隐藏时,增加动画效果
Android控件显示、隐藏时,增加动画效果
370 0
Android控件显示、隐藏时,增加动画效果
|
XML Android开发 数据格式
Android ProgressBar进度条,以及自定义显示
Android ProgressBar进度条,以及自定义显示
296 0
Android ProgressBar进度条,以及自定义显示
相关产品
云迁移中心
推荐文章
更多