`
wen742538485
  • 浏览: 237587 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

浅谈基于Android平台阅读器的开发心得

阅读更多
阅读页面


首先从布局开始吧,阅读界面采用了RelativeLayout布局方式,目的是有一个菜单键一直在屏幕下方,方便用户触摸操作。


下面就逐步讲解一下屏幕下部分页面布局的代码:

<?xml version="1.0" encoding="utf-8"?><relativelayout xmlns:android="http://schemas.android.com/apk/res/android" androidrientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="#FFdbdbdb"> 


设置全屏和背景色

<webview android:id="@+id/webkit" android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="#FFdbdbdb"></webview> 

全屏的WebView控件,即浏览器控件,同样设置了背景色。

<button android:layout_width="wrap_content" android:id="@+id/Button01" android:layout_centerhorizontal="true" android:layout_centerinparent="true" android:layout_alignparentright="false" android:layout_alignwithparentifmissing="true" android:layout_height="wrap_content" android:layout_alignbottom="@layout/main" android:text="菜单"> </button> 

菜单键的设置,layout_centerHorizontal layout_alignParentRight layout_alignWithParentIfMissing 的设置,就保证菜单键一直出现在中间,android:layout_alignBottom="@layout/main"设定了菜单键在页面最底部。

<button android:layout_width="wrap_content" android:id="@+id/ButtonUp" android:layout_centerhorizontal="true" android:layout_centerinparent="false" android:layout_alignparentleft="true" android:layout_alignwithparentifmissing="true" android:layout_height="wrap_content" android:layout_alignbottom="@layout/main" android:text="上一页"> </button> <button android:layout_width="wrap_content" android:id="@+id/ButtonDown" android:layout_centerhorizontal="true" android:layout_centerinparent="false" android:layout_alignparentright="true" android:layout_alignwithparentifmissing="true" android:layout_height="wrap_content" android:layout_alignbottom="@layout/main" android:text="下一页"> </button> </relativelayout> 

类似的一左一右的设置了上下页按键。

到这里阅读页面就已经准备好了。

RelativeLayout布局的优点就是能够把你需要的button布局在屏幕的相对位置上,适合于不同屏幕大小的手机采用统一代码操作,减轻了移植带来的负担。这里只布局在了屏幕的正下方,同样也可布局在屏幕中央,最上方等位置。



编辑本段 回目录webView控件基本使用

浏览器控件即webView,下面谈谈如何设置和监控webView控件:webView是j2me所没有的,是类似于Symbian和.net CF 里面功能类似的浏览器控件,通过这个控件可以直接访问网页,或者把输入的HTML字符串显示出来,功能比较强大,同Symbian或.net CF 浏览器控件比起来有以下几个优点:

1、功能强大,支持CSS,Java script等HTML语言,这样页面就能更漂亮。
2、能够对浏览器控件进行非常详细的设置,比如字体大小,背景色,滚动条样式,等等。
3、能够捕捉到所有浏览器操作,比如点击URL,打开或关闭URL
4、能够很好的融入布局。
5、甚至webView还能和JS进行交互。

在使用webView布局的页面后,我们首先取得webView实例,browser就是webView的对象:

browser=(WebView)findViewById(R.id.webkit);

取得实例后,我们给browser定义下WebSettings,WebSettings是WebView的具体设置类,可以对WebView进行非常详细的设置。

WebSettings bs = browser.getSettings();
取得了webView设置对象。下面开始设置浏览器控件
举例几个最常用的设置

bs.setSupportMultipleWindows(false); 


浏览器不支持多窗口显示,意思就是说所有页面在单一窗口打开,这样避免了页面布局控制显示问题,也便于操作控制页面。
bs.setSupportZoom(false); 

页面是否可以进行缩放。
bs.setBlockNetworkImage(false) 

是否阻止图像的显示
bs.setCacheMode() 

缓存的模式,分为几种LOAD_CACHE_ELSE_NETWORK(当本地没有缓存时,从网上下载)
        
              LOAD_CACHE_ONLY 只读取本地缓存
              LOAD_DEFAULT默认的缓存模式
              LOAD_NORMAL一般的缓存模式
              LOAD_NO_CACHE不读取缓存,所有内容均从网络下载

      bs.setJavaScriptEnabled(flag)

是否支持JS
其他比如设置字体等更不必详说。通过设置,我们可以获得一个我们需要的浏览器窗口。

另外一方面,我们还设置了一个类叫webNotify 这个类继承自WebViewClient,用来监控浏览器的一系列事件。
webNotify wn = new webNotify(); browser.setWebViewClient(wn) ; 

下面列举了比较常用的4个事件

1,接收到Http请求的事件
onReceivedHttpAuthRequest(WebView view, HttpAuthHandler handler, String host, String realm) 

2,打开链接前的事件
public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url); return true; } 

这个函数我们可以做很多操作,比如我们读取到某些特殊的URL,于是就可以不打开地址,取消这个操作,进行预先定义的其他操作,这对一个程序是非常必要的。

3,载入页面完成的事件
public void onPageFinished(WebView view, String url){ } 

同样道理,我们知道一个页面载入完成,于是我们可以关闭loading条,切换程序动作。

4,载入页面开始的事件
public void onPageStarted(WebView view, String url, Bitmap favicon) { } 

这个事件就是开始载入页面调用的,通常我们可以在这设定一个loading的页面,告诉用户程序在等待网络响应。

通过这几个事件,我们可以很轻松的控制程序操作,一边用着浏览器显示内容,一边监控着用户操作实现我们需要的各种显示方式,同时可以防止用户产生误操作。
     
     
最后我们的浏览器设置好了,可以监控操作了,于是打开一个网址,


browser.loadUrl("http://www.baidu.com/"); 

     
当然也可以是自己设定的一段html字符串,当然你的URL腰符合规范。

browser.loadDataWithBaseURL() 

编辑本段 回目录如何和JS进行交互

好了,到这里基本的webView的基本使用介绍完了。下面介绍下如何和JS进行交互,这个功能非常强大了,能够做出很多意想不到的事情。

首先我们在页面里有这么一段JS代码
&lt;script language="javascript"&gt; function wave() { document.getElementById("droid").src="android_waving.png"; } &lt;/script&gt;<a> <img id="droid" src="android_normal.png"><br> Click me! </a>   function wave()就是我们要调用的函数。然后让browser和页面进行交互 bs.setJavaScriptEnabled(true); 首先让浏览器支持JS。 browser.addJavascriptInterface(new Object() { public void clickOnAndroid() { mHandler.post(new Runnable() { public void run() { mWebView.loadUrl("javascript:wave()"); } }); } }, "index"); 


这里的重点是addJavascriptInterface(Object obj,String interfaceName)方法,该方法将一个java对象绑定到一个javascript对象中,javascript对象名就是interfaceName,作用域是Global。这样初始化webview后,在webview加
载的页面中就可以直接通过javascript:window.demo访问到绑定的java对象了。

这样我们就能在自己的浏览器里实现html页面里面的js代码了,具体能实现什么功能这里就不做详细举例了,实用中你会发现,这个功能太强大了。




编辑本段 回目录View的触摸操作


最基本的在View里面 onTouchEvent,它主要实现的功能是Flip,主要原理就是按下的时候记录坐标(用到MotionEvent.ACTION_DOWN),然后滑动(MotionEvent.ACTION_MOVE),然后在抬起(MotionEvent.ACTION_UP),在抬起的时候在记录坐标,把按下的坐标和抬起的坐标做比较,这样就能判断出是左还是右了,然后作出相应的处理。一般情况下,我们执行程序操作时就在ACTION_UP时进行。

最基本的就是onTouchEvent,同时Android平台还给我们提供了更多彩的操作方式,我们需要android.view.GestureDetector
android.view.GestureDetector.SimpleOnGestureListener 这两个类

新建一个类继承SimpleOnGestureListener,HahaGestureDetectorListener
可以实现以下event事件。
boolean onDoubleTap(MotionEvent e)
解释:双击的第二下Touch down时触发
boolean onDoubleTapEvent(MotionEvent e)
解释:双击的第二下Touch down和up都会触发,可用e.getAction()区分。
boolean onDown(MotionEvent e)
解释:Touch down时触发
boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY)
解释:Touch了滑动一点距离后,up时触发。
void onLongPress(MotionEvent e)
解释:Touch了不移动一直Touch down时触发
boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY)
解释:Touch了滑动时触发。
void onShowPress(MotionEvent e)
解释:Touch了还没有滑动时触发
(与onDown,onLongPress比较
onDown只要Touch down一定立刻触发。
而Touchdown后过一会没有滑动先触发onShowPress再是onLongPress。
所以Touchdown后一直不滑动,onDown-&gt;onShowPress-&gt;onLongPress这个顺序触发。

boolean onSingleTapConfirmed(MotionEvent e)
boolean onSingleTapUp(MotionEvent e)
解释:上面这两个函数都是在touch down后又没有滑动(onScroll),又没有长按(onLongPress),然后Touchup时触发。

点击一下非常快的(不滑动)Touchup:
onDown-&gt;onSingleTapUp-&gt;onSingleTapConfirmed

点击一下稍微慢点的(不滑动)Touchup:
onDown-&gt;onShowPress-&gt;onSingleTapUp-&gt;onSingleTapConfirmed

有了这么多的响应方式,我们能更加方便的对用户的触摸操作进行响应,对各种动作都有所对应。那么这个类如何使用呢,其实非常简单,在view的新建一个GestureDetector的对象。
构造函数里
gestureDetector = new GestureDetector(new HahaGestureDetectorListener());

然后在View的onTouchEvent里以下这样用,就可以在gestureDetector的事件里写自己的代码了。
@Override 
public boolean onTouchEvent(MotionEvent event)

{  
    gestureDetector.onTouchEvent(event);  




这里简单介绍了webView和触摸方法的实现,希望对大家有一定帮助,创造出更加适合用户操作的程序来。

分享到:
评论

相关推荐

    基于Android系统的智能手机取证思路浅谈.pdf

    "基于Android系统的智能手机取证思路浅谈" 本文主要探讨基于Android系统的智能手机取证思路,讨论了信息技术与信息化、Android系统手机取证、手机电子数据作为证据的法律属性等方面的内容。 一、信息技术与信息化 ...

    浅谈基于Android的移动地理信息采集系统建设.pdf

    在移动设备上构建基于Android的地理信息采集系统,首先需要理解Android客户端应用开发的基础。Android是一个开源的操作系统,为开发者提供了丰富的API和工具,使得开发移动应用变得可能。在Android平台上进行GIS...

    浅谈游戏开发平台Unity3D的应用与发展前景.docx

    浅谈游戏开发平台Unity3D的应用与发展前景 Unity3D 作为一款游戏开发平台,已经在游戏行业中崭露头角多年。随着游戏行业的快速发展,Unity3D 的应用前景也变得愈加广阔。在本文中,我们将浅谈 Unity3D 的优势和...

    浅谈基于微信小程序的校园一体化服务平台的设计与开发.pdf

    首先,基于微信小程序的校园服务平台能够为学生的学习和生活带来极大便利。例如,校园百事系统小程序中融合了在线学习、教务管理、校内新闻、二手市场、打印资料、电脑维修等功能。学生能够随时了解校园新闻,方便地...

    Android系统移植与平台开发

    Android系统移植与平台开发涉及到多个方面,包含对Android系统本身的下载、编译、移植过程,以及对开发人员如何针对特定硬件平台进行开发的指导。本篇文档的内容详细描述了Android系统移植与平台开发的前期准备、...

    浅谈MTK平台下Android开发比较学习笔记doc.doc

    ### MTK平台下Android开发比较学习笔记 #### 一、引言 近年来,随着移动互联网技术的迅猛发展,智能手机已成为人们日常生活中不可或缺的一部分。而Android操作系统作为全球市场份额最大的移动操作系统,其背后的...

    Android框架浅谈

    《Android框架浅谈》 **一、Android系统框架概览** Android系统框架是构建于Linux内核之上的,为移动设备提供了一套完整的操作系统环境。它由一系列的组件和服务构成,包括应用程序框架、运行库、应用程序、Linux...

    毕业设计(论文)-基于Android平台的手机应用开发—音乐播放器.doc

    基于 Android 平台的手机应用开发—音乐播放器 Android 是基于 Linux 内核的操作系统,是 Google 公司在 2008 年推出的开源操作系统。 Android 平台的手机应用开发对于计算机科学与技术专业的学生来说是一个非常...

    深入浅出-Android系统移植与平台开发(2)_准备Android开发环境[收集].pdf

    根据提供的文件内容,本部分将围绕Android系统移植与平台开发的前期准备工作进行详细的知识点介绍。 首先,在准备Android开发环境之前,需要对Android系统的构建过程有所了解。Android系统的构建是基于Linux环境的...

    深入浅出Android教程 Android开发经典教材 pdf

    深入浅出Android PDF版,Android开发经典教材,从某种角度来说,Android 代表着一个崭新的开放源代码的智能手机操作系统平台、一个友善的免费应用程序开发环境、一个与世界各地的程序开发者,站在相同起跑点上的公平...

    深入浅出Android

    深入浅出Android「Android」是一个基于 Linux 核心(kernel) 的开放手机平台操作系统。与 Windows Mobile、Symbian 等手机操作系统处在同一级别。 对于设备制造商来说,「Android」是一个免费的平台。「Android」操作...

    浅谈毕业设计外文翻译 通过开发Android平台上的社交应.doc

    浅谈毕业设计外文翻译 通过开发Android平台上的社交应.doc

    浅谈基于Android系统的土地整治核查系统在土地综合整治中的应用.pdf

    在Android平台上,开发了一款专用于土地整治核查的平板电脑应用程序。该系统结合GPS定位技术和GIS技术,以卫星GPS定位设备作为载体,支持现场踏勘、核查和督导工作。通过对现场情况的实时记录,包括影像数据、竣工...

    Android开发\深入浅出Android.pdf

    《深入浅出Android》一书旨在为Android开发者提供全面、深入的指导,涵盖了从入门到高级的各个环节。以下是对该书部分章节所涉及的关键知识点的详细解析: ### 一、入门:初探Android #### 1. Android简介 - **...

    浅谈高职Android应用开发课程的建设.pdf

    Android应用开发课程是针对高职教育阶段的学生,旨在培养他们在Android平台上设计和开发应用程序的能力。课程以实践为导向,强调技能的培养和实际问题的解决,与软件技术专业其他课程形成良好的衔接。课程内容涵盖...

    深入浅出Android软件开发教程.pdf+源码

    本书理论与实践相结合,内容详尽,配有丰富的示例程序,讲解深入浅出,可以使读者在较短的时间内理解Android系统框架及其应用的开发过程,掌握Android应用程序的设计方法。 本书提供所有程序的源代码和电子课件。...

    知乎:浅谈基于COMSOL的锂离子电池仿真.pdf

    基于COMSOL的锂离子电池仿真 COMSOL是基于多物理场耦合的软件,可以对锂离子电池进行仿真模拟。锂离子电池是当前动力电池的最佳选择,其优点在于工作电压高、能量密度高、循环寿命长、无记忆效应,但是它也存在一些...

    深入浅出Android软件开发教程

    但是,我可以基于这个标题“深入浅出Android软件开发教程”来详细讲解相关知识点。 1. Android软件开发概述 Android是由Google主导开发的开源操作系统,主要应用于移动设备,如智能手机和平板电脑。Android系统基于...

    net技术在Android平台下的应用浅谈.pdf

    【标题】:《.NET技术在Android平台下的应用浅谈》 【摘要】:本文探讨了.NET技术在Android系统中的应用,主要介绍了如何利用C#语言和Mono for Android插件在Microsoft Visual Studio环境下进行Android应用的开发。...

    浅谈Android移动开发程序员的职业发展之路

    ### 浅谈Android移动开发程序员的职业发展之路 随着信息技术的快速发展与智能手机的普及,移动应用开发成为了一个备受关注的领域,而Android作为全球最大的移动操作系统之一,其开发人员的需求量也在逐年攀升。本文...

Global site tag (gtag.js) - Google Analytics