这个学期学校开了安卓的课程,因为自己一直学习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. [WOJ1318]和最大

    题目链接: WOJ1318 题目分析: 首先我们要知道当这是一个线性的序列的时候应该怎么做:最大子序和 这里是线性的,就把数组复制两遍即可 好像有些细节要处理(也可能是我代码写丑了),具体的都在代码里 ...

  2. Odd sum CodeForces - 797B

    Odd sum CodeForces - 797B 好方法:贪心 贪心2 糟糕(不用动脑)的方法:dp ans[i][0]表示到第i个和为偶数最大,ans[i][1]表示到第i个和为奇数最大. 但是, ...

  3. C++类成员函数与成员变量的内存布局

    一.成员函数 成员函数可以被看作是类作用域的全局函数,不在对象分配的空间里,只有虚函数才会在类对象里有一个指针,存放虚函数的地址等相关信息.

  4. Thymeleaf 总结

    在javaScript中使用表达式 var list = /*[[${list}]]*/ null;   <script th:inline="javascript"> ...

  5. 【转】android技术栈

    android技术栈-现有使用的进行一个汇总(初稿) 2017年04月24日 16:19:40 阅读数:2004 android技术栈 开发工具 Android studio 开发语言 Java 自动 ...

  6. Hibernate懒加载深入分析

    Hibernate懒加载深入分析 懒加载可以提高性能吗?  不可以简单的说"能",因为Hibernate的关系映射拖累了SQL的性能,所以想出懒加载来弥补.只是弥补而以,不会超越. ...

  7. IOS之GCD记录

    在 GCD 中,加入了两个非常重要的概念: 任务 和 队列. 任务:即操作,你想要干什么,说白了就是一段代码,在 GCD 中就是一个 Block,所以添加任务十分方便.任务有两种执行方式: 同步执行 ...

  8. Apache的HttpClient的使用

    Apache的HttpClient可以被用于从客户端发送HTTP请求到服务器端,其中封装了客户端发送http的get和post请求 使用Apache的HttpClient发送GET和POST请求的步骤 ...

  9. mysql利用binlog恢复数据

    需求:需要给开发提供一个2018年9月30号的数据,按照我们公司正常备份策略来说,直接找到对应时间的备份数据,解压导入即可,恰好这个时间节点的数据没有,只备份到2018年9月25号的,糟糕了吧 咋办呢 ...

  10. Node + Express + MySQL 接口开发完整案例

    https://blog.csdn.net/u013216976/article/details/85273770 https://github.com/Apache-Ra/node-express- ...