聚合了博客园新闻、infoq新闻、36kr新闻、oschina新闻、51cto新闻、csdn新闻;
争取做到随时刷随时有开发者的新闻!
目前还只支持安卓APP
但用的人多了,我会发布苹果版的APP
最新版本的下载地址:http://shumanu.com/DeveloperNews.apk
开源代码的地址(包含采集程序、守护程序、APP客户端和WEB服务端):https://github.com/xland/DeveloperNews
扫码下载:
来看看系统截图:
这次更新的主要内容有:
一个屏幕只显示一条新闻;并且字体加大,方便用户在公车上刷新闻,(这样就不会晕车了!亲测!)
向上滑动家在更多新闻,向下滑动刷新新闻!
只提供了用系统浏览器打开新闻正文的功能!
去掉了用不到的权限!
修改了升级逻辑
升级部分的关键代码:
(正如你所见,客户端是JS写的,全部代码去GITHUB上看吧)
function updateAndroid(fPath) {
var date = new Date().getTime();
var fileN = "";
fileN = "_doc/dn_" + date + ".apk";
var options = {
method: "GET",
filename: fileN
};
var watiting = plus.nativeUI.showWaiting("开始下载:0%");
var dtask = plus.downloader.createDownload(fPath, options);
dtask.addEventListener("statechanged", function(task, status) {
if (!dtask) {
return;
}
switch (task.state) {
case 1: // 开始
break;
case 2: // 已连接到服务器
break;
case 3: // 已接收到数据
var nowData = Math.floor(task.downloadedSize * 100 / task.totalSize);
if (nowData % 10 == 0) {
watiting.setTitle("已下载:" + nowData + "%");
if (nowData == 100) {
plus.nativeUI.toast("正在准备环境,请稍后!");
plus.runtime.openFile(dtask.filename);
plus.runtime.quit();
}
}
break;
case 4: // 下载完成
break;
}
});
dtask.start();
} function checkVersion() {
mui.get(baseUrl + '/Default.aspx?Action=CheckVersion', {}, function(data) {
if (data != plus.runtime.version) {
plus.nativeUI.confirm("有新版本,是否更新?", function(msg) {
if (msg.index == 1) {
if ('iOS' == plus.os.name) {
plus.runtime.openURL(baseUrl + "/update/ios.aspx");
} else {
updateAndroid(baseUrl+"/DeveloperNews.apk");
}
}
}, "友情提醒:", ["取消", "确定"]);
}
});
}
webservice的代码页有更新,如下:
var pageSize = 8;
var Index = Request["Index"];
if (string.IsNullOrWhiteSpace(Index))
{
Index = "0";
}
var start = Convert.ToInt32(Index);
var dbFactory = new OrmLiteConnectionFactory(ConfigurationManager.AppSettings["dbConnStr"], MySqlDialect.Provider);
var db = dbFactory.Open();
List<allen_news> obj;
if(start == 0)
{
obj = db.Select<allen_news>("select * from allen_news order by news_id desc limit 0,"+(pageSize*2).ToString());
}
else
{
obj = db.Select<allen_news>("select * from allen_news where news_id < "+start.ToString()+" order by news_id desc limit 0," + pageSize.ToString());
}
db.Close();
db.Dispose();
if (obj.Count < 1)
{
Response.Write("Sorry...我们不打算把不算“新”闻的内容提供给您,您收藏的内容可以在“我的收藏”中找到。");
Response.End();
return;
}
Response.Write(JsonConvert.SerializeObject(obj));
Response.End();
喜欢的朋友请帮忙点个推荐,或者到github上给我一颗星星,谢谢!