这个学期学校开了安卓的课程,因为自己一直学习wp的开发,一直用的是.net和Silverlight这一套,也着实没有太多时间投入安卓的方向去,因为想着毕业也不从事安卓的工作,所以也一直没有怎么研究。但是期末了,要交作品了,我想不如就做个RSS阅读器交吧,因为在学习wp的时候觉得RSS阅读器还是相对简单的,安卓上应该也是用的一样的思路。所以昨天晚上,在我们宿舍安卓大神的帮助下(主要是解决一些wp和安卓不同的地方带给我的疑问),我花了4个多小时做了这个应用。

总体思路是获取IT之家的RSS源,保存到一个集合里,然后把数据绑定到ListView上,点击ListView的其中一项,跳转到另一个页面,该页面只有一个WebView,用来显示点击项带过来的网址所对应的网页——当然wp里最简单的RSS阅读器也是这个思路。

首先定义一个文章的模型:

public class Item {

    private String title;
private String description;
private String date;
private String link;
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
public String getDate() {
return date;
}
public void setDate(String date) {
this.date = date;
}
public String getLink() {
return link;
}
public void setLink(String link) {
this.link = link;
} public HashMap<String,String> getMap(){
HashMap<String, String> map = new HashMap<String, String>();
map.put("title", title);
map.put("description", description);
map.put("date", date);
map.put("link", link);
return map;
} }

最后一个方法getMap的作用是把当前对象的属性以HashMap的形式返回。为什么要这么做呢?因为后面要用到。

获取RSS源的实现方法:

public static List<Map<String, String>> readXML(InputStream inStream) {
List<Map<String, String>> data = new ArrayList<Map<String, String>>();
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
try {
DocumentBuilder builder = factory.newDocumentBuilder();
Document dom = builder.parse(inStream);
Element root = dom.getDocumentElement();
NodeList items = root.getElementsByTagName("item");// 查找所有item节点
for (int i = 0; i < items.getLength(); i++) {
Item item = new Item();
// 得到第一个item节点
Element itemNode = (Element) items.item(i);
// 获取item节点下的所有子节点
NodeList childsNodes = itemNode.getChildNodes();
for (int j = 0; j < childsNodes.getLength(); j++) {
Node node = (Node) childsNodes.item(j);
// 判断是否为元素类型
if (node.getNodeType() == Node.ELEMENT_NODE) {
Element childNode = (Element) node;
if ("title".equals(childNode.getNodeName())) {
item.setTitle(childNode.getFirstChild()
.getNodeValue());
} else if ("link".equals(childNode.getNodeName())) {
String computer = childNode.getFirstChild()
.getNodeValue();
String phone = "http://wap.ithome.com/html"
+ computer.substring(computer
.lastIndexOf("/"));
Log.e("jpho", phone);
item.setLink(phone);
} else if ("description"
.equals(childNode.getNodeName())) {
item.setDescription(childNode.getFirstChild()
.getNodeValue());
} else if ("pubDate".equals(childNode.getNodeName())) {
item.setDate(childNode.getFirstChild()
.getNodeValue());
}
}
}
data.add(item.getMap());
}
inStream.close();
} catch (Exception e) {
e.printStackTrace();
}
return data;
}

这个方法把获取到的RSS数据添加到一个List集合里,里面就用到了上面提到的getMap方法。这里做了一个小小的处理,就是把获取到的文章链接转换成手机版的链接。毕竟要在手机上看,一来加载快,二来节省流量。

下面是逻辑:

String[] from = new String[] { "title", "date", "description", "link" };
int[] to = new int[] { R.id.title, R.id.date, R.id.description,
R.id.link };
URL url;
List<Map<String, String>> data = new ArrayList<Map<String, String>>();
try {
url = new URL("http://www.ithome.com/rss/");
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
InputStream isr = conn.getInputStream();
data = readXML(isr);
} catch (MalformedURLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
SimpleAdapter adapter = new SimpleAdapter(this, data, R.layout.item,
from, to);
this.getListView().setAdapter(adapter);
this.getListView().setOnItemClickListener(this);

这里的数据绑定跟wp的写法有点不同,这里是通过适配器来把属性绑定到相应控件里,在wp里我们直接写Bingding就可以了。getListView().setAdapter(adatper)跟wp里的设置数据上下文有点类似,不过这里是设置数据适配器。

接下来是Item的点击事件:

@Override
public void onItemClick(AdapterView<?> parent, View view, int position,
long id) {
// TODO Auto-generated method stub ListView listView = (ListView) parent;
HashMap<String, String> map = (HashMap<String, String>) listView
.getItemAtPosition(position);
String url = map.get("link");
Intent intent = new Intent(getApplicationContext(), ItemActivity.class);
intent.putExtra("url", url);
startActivity(intent);
}

Intent有点像是wp里的应用程序设置,也是通过键值对得方式把数据保存到独立存储空间里,然后在别的页面获取它。下面是文章页面的逻辑:

@SuppressLint("SetJavaScriptEnabled")
public class ItemActivity extends Activity {
private WebView mWebView; @Override
protected void onCreate(Bundle icicle) {
super.onCreate(icicle);
setContentView(R.layout.activity_item);
Intent intent = getIntent();
mWebView = (WebView) findViewById(R.id.webView);
mWebView.getSettings().setJavaScriptEnabled(true);
mWebView.loadUrl(intent.getStringExtra("url"));
}
}

要使WebView能加载js,就要添加这句话:@SuppressLint("SetJavaScriptEnabled"),还有这句:mWebView.getSettings().setJavaScriptEnabled(true),然后在onCreate方法里获取传过来的链接,并用WebView显示之。

这就是总体思路。毕竟是第一次写安卓应用,写得不好之处还望指正。不过真的跟wp的思路是一样的,所以只要掌握了一种移动开发方法,转向其他平台只是语言问题,还有一些不一样的特性,主要思路还是一摸一样的。不过以后不打算从事安卓开发,这可能是第一次,也是最后一次开发安卓的应用。仅以此文纪念那些还未开始便结束的东西。

有需要的可以在这里下载项目代码。

记第一次开发安卓应用——IT之家RSS阅读器的更多相关文章

  1. CozyRSS开发记录9-快速实现一个RSS解析器

    CozyRSS开发记录9-快速实现一个RSS解析器 1.再读RSS标准 既然需要自己实现一个RSS解析器,那自然需要仔细的读一读RSS的标准文档.在网上随便找了两份,一份英文一份中文: http:// ...

  2. android rss阅读器开发一点小技巧

    这几天一直在学习开发Rss阅读器,遇到一个很坑的问题,InputSource这里总是出错.弄了好久,终于让我找到一个解决方法----看代码: new Thread(){ @Override publi ...

  3. 开发微信小程序——古龙小说阅读器

    概述 由于面试的关系接触了一下微信小程序,花了2晚上开发了一个带书签功能的古龙小说阅读器,并且已经提交审核等待发布.这篇博文记录了我的开发过程和对微信小程序的看法,供以后开发时参考,相信对其他人也有用 ...

  4. 使用ReactiveCocoa开发RSS阅读器

    目前已经完成的功能有对RSS的解析和Atom解析,RSS内容本地数据库存储和读取,抓取中状态进度展示,标记阅读状态,标记全部已读等.这些功能里我对一些异步操作产生的数据采用了ReactiveCocoa ...

  5. CozyRSS开发记录8-解析一份RSS

    CozyRSS开发记录8-解析一份RSS 1.使用Rss20FeedFormatter解析RSS 使用Rss20FeedFormatter配合XmlReader来解析RSS非常的简单,几行搞定: 来试 ...

  6. CozyRSS开发记录0-RSS阅读器开坑

    CozyRSS开发记录0-RSS阅读器开坑 1.RSS RSS,全名是Really Simple Syndication,简易信息聚合. 关于RSS相关的介绍,网上可以很容易的找到.RSS阅读器是我几 ...

  7. Xamrin开发安卓笔记(三)

    http://www.cnblogs.com/minCS/p/4118170.html Xamrin开发安卓笔记(三)   安装片 Xamrin开发安卓笔记(一) Xamrin开发安卓笔记(二) 这次 ...

  8. Xamrin开发安卓笔记(二)

    http://www.cnblogs.com/minCS/p/4112617.html Xamrin开发安卓笔记(二)   安装篇 Xamrin开发安卓笔记(一) 昨天调理一天AAPT.EXE 被推出 ...

  9. intellij开发安卓与genymotion配合

    原文:intellij开发安卓与genymotion配合 [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http: ...

随机推荐

  1. 洛谷 P2158 [SDOI2008]仪仗队 && 洛谷 P1447 [NOI2010]能量采集

    https://www.luogu.org/problemnew/show/P2158 以人所在位置为(0,0)建立坐标系, 显然除了(0,1)和(1,0)外,可以只在坐标(x,y)的gcd(x,y) ...

  2. html2canvas如何将div转成图片并下载,如何将滚动条的内容截取下来

    <!DOCTYPE html> <html lang="en"> <head> <meta name="layout" ...

  3. 488 Zuma Game 祖玛游戏

    回忆一下祖玛游戏.现在桌上有一串球,颜色有红色(R),黄色(Y),蓝色(B),绿色(G),还有白色(W). 现在你手里也有几个球.每一次,你可以从手里的球选一个,然后把这个球插入到一串球中的某个位置上 ...

  4. LSP

    Liskov Substitution Principle里氏替换原则,OCP作为OO的高层原则,主张使用“抽象(Abstraction)”和“多态(Polymorphism)”将设计中的静态结构改为 ...

  5. Spring-aop(一)

    写一个计算类,计算前后需要打印日志. interface ArithmeticCalculator { public int add(int i, int j); public int sub(int ...

  6. P1967 货车运输 未完成

    #include<iostream> #include<cstdio> #include<cstring> #include<cmath> #inclu ...

  7. C/C++ static

    C/C++中static关键字作用总结 1.先来介绍它的第一条也是最重要的一条:隐藏.(static函数,static变量均可) 当同时编译多个文件时,所有未加static前缀的全局变量和函数都具有全 ...

  8. Linux 从源码编译安装 Nginx

    Nginx 是一个高性能的 HTTP 和 反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器.Nginx 编译安装比较简单,难点在于配置.下面是 Nignx 0.8.54 编译安装和简 ...

  9. dede网站目录权限设置

    如果你的网站数据十分重要(那种两天就能弄好的垃圾站就算了),建议按本文所说的安全步骤进行严格的设置.1.目录权限 我们不建议用户把栏目目录设置在根目录, 原因是这样进行安全设置会十分的麻烦, 在默认的 ...

  10. 数据库系统概论(2)——Chap. 2 关系数据库基础

    数据库系统概论(2)--Chap.2 关系数据库基础 一.关系数据结构及形式化定义 1.关系 关系模型的数据结构只包含单一的数据结构--关系.在关系模型中,现实世界的实体及实体间的各种联系均用单一的结 ...