转自:http://blog.csdn.net/wukunting/archive/2010/01/24/5251302.aspx
每次我们锁键盘的时候,都看到如下页面:
看多了就产生审美疲劳, 手机是追求个性化的消费品,想到就是替换她,再找一个。
如何替换呢?Android 提供如下函数:
KeyguardManager mKeyguardManager = (KeyguardManager)getSystemService(Context.KEYGUARD_SERVICE);
KeyguardLock mKeyguardLock = mKeyguardManager.newKeyguardLock("");
mKeyguardLock.disableKeyguard();
拿到键盘守护锁,屏蔽她既可。接下来就是在合适的时机替代她, 这个合适的时机就是接收Intent.ACTION_SCREEN_OFF.
IntentFilter filter = new IntentFilter(Intent.ACTION_SCREEN_OFF);
registerReceiver(mReceiver, filter);
这里有点奇怪的是,如果通过android.manifest 配置receiver的话,就得不到Action_screen_off 事件,我现在还纳闷了……
最后就是再找一个她(个性化屏保)了, 我目前在模仿Hero屏保,所以就以她来说了。
首先用一个服务启动一个Activity.
如下:
Intent it = new Intent();
it.setClass(this, ScreenShow.class);
it.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
this.startActivity(it);
还要设置该Activity为单态,并且为透明, 属性如下:
android:launchMode="singleTask" android:theme="@style/Theme.nd_Dialog" 其中透明Activity的Style设置为
<style name="Theme.nd_Dialog" parent="android:style/Theme.Translucent">
<item name="android:windowNoTitle">true</item>
</style>
我们体验过Hero屏保界面,就会发现,屏保的移动与手势的用力大小相关。用力重的时候,屏保界面自动往下滑。
VelocityTracker mVelocityTracker;
if (mVelocityTracker == null) {
mVelocityTracker = VelocityTracker.obtain();
}
mVelocityTracker.addMovement(event);
mVelocityTracker.computeCurrentVelocity(1000);
float yVel = mVelocityTracker.getYVelocity();
其中屏保自动往下滑的动作不是用Animation来做的,而是通过Handler, 隔一段时间发送一个消息达到动画的效果:
mHandler.sendMessageAtTime(mHandler.obtainMessage(MSG_ANIMATE),
mCurAnimationTime);
比起Animation, 通过Handle可以达到自如地控制动画.
最后,讲讲屏保内容用到Receiver,
// 时间Receiver
intentFilter.addAction(Intent.ACTION_TIME_CHANGED);
intentFilter.addAction(Intent.ACTION_TIME_TICK);
intentFilter.addAction(Intent.ACTION_TIMEZONE_CHANGED);
// 配置变化, 关闭系统,
intentFilter.addAction(Intent.ACTION_CONFIGURATION_CHANGED);
intentFilter.addAction(Intent.ACTION_CLOSE_SYSTEM_DIALOGS);
//网络名称Receiver(比如中国移动等) intentFilter.addAction(Telephony.Intents.SPN_STRINGS_UPDATED_ACTION);
// 电量改变Receiver
intentFilter.addAction(Intent.ACTION_BATTERY_CHANGED);
// Sim状态Receiver intentFilter.addAction(TelephonyIntents.ACTION_SIM_STATE_CHANGED;
哈…… 慕然回首,那人却在灯火阑珊处……
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/wukunting/archive/2010/01/24/5251302.aspx
100409
今天碰到两部手机安装都有问题,一部是山寨的mobile(牌子hto),安装时显示"无法安装 ,因为网站记录的关键信息与MIDlet所记录的不符-31请联系整个MIDlet的制造商,以"便获得更详细的信息",经测试发现是破解过的虚拟机,安装了破解过的证书,没有签名的包默认允许所有操作,签过名的包反而不能安装.
另外一部是se610c,测试了签名,不签名,不混淆等,并把jad中授权和其他等操作都去除之后,还是不能安装.显示"操作错误"
通过简单的demo测试,确认确实vs的签名不能安装,但是没有签名的可以.为何移动OA的包不行呢,难道真的是太大所致?再测试混淆包,混淆包确认可以安装.
还有一个可能的原因,原来的短信端口已经被第三方占用了,但是系统无法给出确定提示.确认,原来我的一个程序占用了短信端口,把测试程序卸载后,就可以安装了.另外单独的t和双签名都不能安装.
不支持签名的手机可以直接执行jar安装,部分手机需要删除jad才能安装jar,入华为的cdma手机
mobile的蓝牙不太稳定,较大的包(400k)容易出现掉线,掉线的情况下取消不了,过几分钟可以取消
WAP好像是中国特色的,也就是要通过运营商的代理才能连接网络。所以要连接WAP的网络必须要设置代理。
Proxy proxy=new Proxy(java.net.Proxy.Type.HTTP,new InetSocketAddress("10.0.0.172",80)); HttpURLConnection connection=(HttpURLConnection) url.openConnection(proxy);
这是java.net包的联网方式。还可以用Apache的HttpClient连接网络。
DefaultHttpClient httpClient = new DefaultHttpClient(); HttpHost proxy = new HttpHost("10.0.0.172", 80); httpClient.getParams().setParameter(ConnRouteParams.DEFAULT_PROXY, proxy);
以上的是连接CMWAP的,如果是CDMA的CTWAP,代理是10.0.0.200,联通的uniwap代理和移动的一样。
多谢了~~~~