这阵子在做Lephone的适配,测试组提交一个bug:标题栏的文字较长时没有显示完全,其实这并不能算个bug,并且这个问题在以前其他机器也没有出现,只是说在Lephone的这个平台上显示得不怎么美观,因为联想将原生的标题栏UI进行了修改。修改的过程中遇到了一个难题,系统自带的那个标题栏进度总能够到达100%后渐退,但是我每次最后到100%那一段显示不全,尝试了用线程程序死了卡主了不说,还是一样的效果,后来同事一句话提醒了我用动画。确实是这样我猜系统的也是这样实现的,等进度到达100%后,用动画改变它的透明度就ok了。
实现的效果:标题栏显示网页标题并且滚动,并且用进度条显示网页的加载进度(重新自定义标题栏,lephone修改后的都带有一个返回按钮,并且标题文本和进度条是Frame布局的不怎么好看)。
1、首先定义一个RelativeLayout布局文件 broser_custom_title.xml (AlwaysMarqueeTextView这个类重写了TextView,实现一个跑马灯的效果,网上能够找到
<?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,重写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.163.com"); }
分享到:
相关推荐
通过上述步骤,你可以在Android应用中实现一个自定义标题栏,不仅能够显示网页标题,还能实时展示加载进度。这样的设计可以提供更好的用户体验,让用户清楚地了解网页的加载状态。在实际开发中,你可能还需要根据...
而EventBus则可能被用来在用户交互或者网络请求完成后更新UI,例如刷新订单状态或显示加载进度。Retrofit2则负责处理网络请求,比如获取菜品信息、下单、支付等操作。 综上所述,这个项目展示了如何在Android应用中...
- **自定义设计**:FinestWebView支持自定义标题栏、工具栏颜色、字体等,以匹配应用的整体视觉风格。 - **加载速度**:优化的加载机制使得网页加载速度更快,提高用户满意度。 - **交互体验**:提供前进、后退、...
4. 用户个性化:部分应用允许用户自定义标题栏的样式,以满足个人偏好。 总结来说,标题栏变化特效是提升用户界面吸引力和用户体验的重要手段。通过合理运用CSS3、JavaScript、响应式框架或移动平台原生技术,...
根据提供的文档信息,我们可以深入探讨Android标题栏的高级实现方法及其相关知识点。下面将详细介绍TitleBar类的设计原理、实现方式以及关键组件的功能。 ### TitleBar类设计与实现 #### 继承关系 TitleBar类继承...
双击标题栏回到顶部的功能,可能通过自定义ToolBar并监听触摸事件来实现,这涉及到对View的事件处理机制的掌握。 2. **WebView集成与交互**: 知乎日报的内容部分通常需要展示网页内容,因此项目中使用了WebView...
这样,在WebView加载内容时,标题栏就会显示一个进度条来指示加载进度。 ##### 2. 自定义进度条 除了使用系统自带的标题栏进度条外,还可以根据需求自定义进度条。自定义进度条通常涉及到布局设计和事件监听,可以...
### Android标题栏(TitleBar)介绍 在Android应用开发中,`TitleBar`是一个非常重要的UI组件,它位于应用程序界面的顶部,用于显示应用名称、当前活动页面的标题以及一些功能按钮等信息。通过合理的设计与实现,...
这种方法需要在布局文件中设置Activity全屏无标题栏,然后在代码中控制Activity的透明度和显示状态,以达到类似对话框的效果。 总的来说,自定义ProgressDialog可以让开发者在Android应用中创建更符合设计要求的...
2. `this`: 可能是指代当前类实现了某个回调接口,例如用于处理加载进度、错误等事件。 3. `this`: 同上,可能表示当前类也需要实现另一个回调接口,处理其他交互或状态变更。 4. `fileUrl`: 这是一个字符串,表示...
在Android应用开发中,Title ProgressBar 是一种常见的用户界面...通过自定义标题栏布局和使用ProgressBar组件,开发者可以创建具有加载指示功能的标题栏,同时,对相关源码的学习有助于加深对Android UI编程的理解。
而当WebView加载网页时,为了提供良好的用户体验,我们通常会添加一个进度条来显示加载进度。以下是一个关于如何在Android中使用WebView加载网页并设置进度条的详细教程。 首先,我们需要在布局XML文件中创建一个...
- 条形进度条在标题栏显示,需要`requestWindowFeature(Window.FEATURE_PROGRESS)`和`setProgressBarVisibility(true)`,并且可以通过`setProgress(int)`设置当前进度。 4. ProgressBar的常用属性: - `android:...
- `FEATURE_PROGRESS` (2):表示在标题栏上显示加载进度,通常用于Web视图加载页面时显示进度条。 - `FEATURE_LEFT_ICON` (3):表示在标题栏左侧显示一个图标。 - `FEATURE_RIGHT_ICON` (4):表示在标题栏右侧显示一...
3. `FEATURE_CUSTOM_TITLE`: 这个选项允许开发者自定义标题栏的外观,比如将其变为一个按钮或其他复杂的视图。通过使用这个特性,你可以完全控制标题的布局和样式。 4. `FEATURE_INDETERMINATE_PROGRESS`: 这个功能...
在Android程序设计中,对话框作为与用户进行互动的重要工具之一,被广泛应用于各种场景。本文将深入探讨Android对话框的相关知识点,包括`Toast`提示框、`Dialog`对话框、特色对话框、自定义对话框以及`Notification...
这可能涉及到ListView或者RecyclerView的使用,以及自定义Adapter来显示音乐信息,如歌曲名、艺术家、专辑等。 "MediaPlayer"类是Android系统提供的核心音频播放组件。通过创建MediaPlayer对象,我们可以加载音乐...
11. **通知(Notification)**:在状态栏显示消息,可以包含图标、标题、正文和操作按钮。 12. **对话框(Dialog/FloatingActionButton)**:提供额外信息或操作的弹出窗口,`FloatingActionButton`是浮动动作按钮,...