一直用墨迹的天气,好用。可是最经发现墨迹的天气越做越复杂,整个屏幕塞满了东西,这还不够,滑动翻页拖拉等翻出来的页面也是塞满了东西。我只想看看天气预报啊,我懒得玩那个巨费电的动画效果,懒得看那些个复杂的专业词汇,曲线图什么的。我就想几秒钟看下最近的天气情况,我了个去,又不是打游戏,设这么多的剧情干毛啊。到处都是菜单按钮,要闹哪样啊亲,我该点哪个啊亲。
还是自己写个吧,正好最近在学ps,连美工都可以省了,到时候一定要吐槽一下墨迹,真是磨叽啊。
整个芯片有3个时钟:FCLK、HCLK和PCLK
(1)FCLK:用于CPU
(2)HCLK:用于AHB(Advanced High Performance Bus)总线上的设备,比如存储控制器、中断控制器、DMA等(高性能模块)
(3)PCLK:用于APB(Advanced Peripheral Bus)总线上的设备,比如WATCHDOG、IIS、IIC等(低宽带外设)
开发板上电时,FCLK等于外部输入的时钟(即振晶频率),若要提高系统时钟,需要软件来启动PLL,而PLL包括UPLL和MPLL,UPLL专用于USB设备,MPLL用于设置FCLK、HCLK和PCLK
如何通过控制MPLL来设置FCLK、HCLK和PCLK呢?主要设置好3个主要寄存器的值就能搞定,他们分别是:LOCKTIME寄存器、MPLLCON寄存器、CLKDIVN寄存器和CAMDIVN寄存器
(1)LOCKTIME寄存器:用于设置MPLL启动后稳定前所需等待的时间(Lock time),一般使用默认值就行。
(2)MPLLCON寄存器:用于设置FCLK与Fin的倍数
位[19:12]的值称为MDIV,位[9:4]的值称为PDIV,位[1:0]的值称为SDIV
MPLL(FCLK)=(m*Fin)/(p*2^s)
其中:m=MDIV+8,p=PDIV+2,s=SDIV
(3)CLKDIVN寄存器、CAMDIVN寄存器:用于设置FCLK、HCLK和PCLK三者的比例
HDIVN=CLKDIVN[2:1]
PDIVN=CLKDIVN[0]
HCLK4_HALF=CAMDIVN[9]
HCLK3_HALF=CAMDIVN[8]
OAuth的基本概念,OAUTH协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式不同之处是OAUTH的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此OAUTH是安全的。同样新浪微博提供OAuth认证也是为了保证用户账号和密码的安全,在这里通过OAuth建立普通新浪微博用户、客户端程序(我们正在开发的这个android客户端程序)、新浪微博三者之间的相互信任关系,让客户端程序(我们正在开发的这个android客户端程序)不需要知道用户的账号和密码也能浏览、发布微博,这样有效的保护了用户账号的安全性不需要把账号密码透露给客户端程序又达到了通过客户端程序写微博看微博目的。这个是OAuth的作用。
结合新浪微博的OAuth认证来说说具体的功能实现,首先罗列一下关键字组,下面四组关键字跟我们接下来OAuth认证有非常大的关系。
第一组:(App Key和App Secret),这组参数就是本系列文本第一篇提到的建一个新的应用获取App Key和App Secret。
第二组:(Request Token和Request Secret)
第三组:(oauth_verifier)
第四组:(user_id、Access Token和Access Secret)
新浪微博的OAuth认证过程,当用户第一次使用客户端软件时,客户端程序用第一组作为参数向新浪微博发起请求,然后新浪微博经过验证后返回第二组参数给客户端软件同时表示新浪微博信任本客户端软件,当客户端软件获取第二组参数时作为参数引导用户浏览器跳至新浪微博的授权页面,然后用户在新浪的这个授权页面里输入自己的微博账号和密码进行授权,完成授权后根据客户端设定的回调地址把第三组参数返回给客户端软件并表示用户也信任本客户端软件,接下客户端软件把第二组参数和第三组参数作为参数再次向新浪微博发起请求,然后新浪微博返回第四组参数给客户端软件,第四组参数需要好好的保存起来这个就是用来代替用户的新浪账号和密码用的,在后面调用api时都需要。从这个过程来看用户只是在新浪微博的认证网页输入过账户和密码并没有在客户端软件里输入过账户和密码,客户端软件只保存了第四组数据并没有保存用户的账户和密码,这样有效的避免了账户和密码透露给新浪微博之外的第三方应用程序,保证 了安全性。
新浪微博的SDK的导入: 新浪微博的SDK是源码方式开放的,和我们平时使用的有些不一样,导入步骤如下:
1)新浪微博官方的SDK包中一般有2个目录,一个是SDK的源码包(此包中有Android平台微博SDK说明文档),另一个是例子。首先需要将源码包导入到eclipse中。SDK工程的编码格式为UTF-8。
2)在需要集成新浪微博SDK包的工程项目中添加Library,右键 -> Properties -> Android。设置Library属性。
认证的代码如下,也可以直接参考例子中的AuthorizeActivity类的代码
private static final String CONSUMER_KEY = "*******";// 替换成你自己申请的KEY private static final String CONSUMER_SECRET = "**************************"; // 替换陈你自己申请的SECRET Weibo weibo = Weibo.getInstance(); weibo.setupConsumerConfig(CONSUMER_KEY, CONSUMER_SECRET); // Oauth2.0 隐式授权认证方式 weibo.setRedirectUrl("http://www.sina.com");// 此处使用的URL必须和新浪微博上应用提供的回调地址一样 weibo.authorize(OAuthWeiboActivity.this, new AuthDialogListener());
对于Mobile客户端应用来说,是不存在Server的,故此处的应用回调页地址只要与新浪微博开放平台->我的应用->应用信息->高级应用->授权设置->应用回调页中的url地址保持一致就可以了。
以下代码实现WeiboDialogListener接口,授权成功后可在onComplete函数中获得AccessToken信息。具体如何保存、使用AccessToken信息由开发者自行处理,比如存放在SharedPreferences中,但是AccessToken的有效期有限制,一般正常情况下是7天存活期,过期后需要重新获得。如果保存在SharedPreferences或者db文件中,则需要另外实现方法判断AccessToken是否过期(以最近保存过的时间为准),未过期则直接使用,过期后则按照正常流程重新获取.class AuthDialogListener implements WeiboDialogListener { @Override public void onComplete(Bundle values) { String token = values.getString("access_token"); String expires_in = values.getString("expires_in"); Log.i(“info”,"access_token : " + token + " expires_in: " + expires_in); AccessToken accessToken = new AccessToken(token, CONSUMER_SECRET); accessToken.setExpiresIn(expires_in); Weibo.getInstance().setAccessToken(accessToken); Intent intent = new Intent(); intent.setClass(OAuthWeiboActivity.this, MySinaWeiboActivity.class); startActivity(intent); } @Override public void onError(DialogError e) { Toast.makeText(getApplicationContext(), "Auth error : " + e.getMessage(), Toast.LENGTH_LONG).show(); } @Override public void onCancel() { Toast.makeText(getApplicationContext(), "Auth cancel", Toast.LENGTH_LONG).show(); } @Override public void onWeiboException(WeiboException e) { Toast.makeText(getApplicationContext(), "Auth exception : " + e.getMessage(), Toast.LENGTH_LONG).show(); } }