Android 自定义标题栏 显示网页加载进度的方法实例

Android 自定义标题栏 显示网页加载进度的方法实例,第1张

概述这阵子在做Lephone的适配,测试组提交一个bug:标题栏的文字较长时没有显示完全,其实这并不能算个bug,并且这个问题在以前其他机器也没有出现,只是说在Lephone的这个平台上显示得不怎么美观,因为联想将原生的标题

这阵子在做Lephone的适配,测试组提交一个BUG:标题栏的文字较长时没有显示完全,其实这并不能算个BUG,并且这个问题在以前其他机器也没有出现,只是说在Lephone的这个平台上显示得不怎么美观,因为联想将原生的标题栏UI进行了修改。修改的过程中遇到了一个难题,系统自带的那个标题栏进度总能够到达100%后渐退,但是我每次最后到100%那一段显示不全,尝试了用线程程序死了卡主了不说,还是一样的效果,后来同事一句话提醒了我用动画。确实是这样我猜系统的也是这样实现的,等进度到达100%后,用动画改变它的透明度就ok了。
实现的效果:标题栏显示网页标题并且滚动,并且用进度条显示网页的加载进度(重新自定义标题栏,lephone修改后的都带有一个返回按钮,并且标题文本和进度条是Frame布局的不怎么好看)。
1、首先定义一个relativeLayout布局文件 broser_custom_Title.xml (AlwaysMarqueeTextVIEw这个类重写了TextVIEw,实现一个跑马灯的效果,网上能够找到
 @L_502_0@ 代码如下:
<?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"
       
        androID:visibility="gone" androID:layout_alignParentBottom="true"
        ></Progressbar>
</relativeLayout>
 
2、继承WebChromeClIEnt,重写onProgressChanged和onReceivedTitle事件(进度条加载完成后使用动画渐退)
 复制代码 代码如下:
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);
            // 运行动画 animation
            pb.startAnimation(animation);
            // 将 spinner 的可见性设置为不可见状态
            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、进度条的动画样式 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、码设置自定义的标题栏
 复制代码 代码如下:
    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://www.jb51.net");
    }

总结

以上是内存溢出为你收集整理的Android 自定义标题栏 显示网页加载进度的方法实例全部内容,希望文章能够帮你解决Android 自定义标题栏 显示网页加载进度的方法实例所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/1142535.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-31
下一篇2022-05-31

发表评论

登录后才能评论

评论列表(0条)

    保存