壁纸随着桌面的滑动而滑动,这个是android的一个特点,但是有时候很不方便,尤其是桌面设置成一张自己喜欢的图片的时候,老是看不到一整张的图片,这里介绍下设置成不随桌面滑动而滑动的方法。
1.自定义壁纸的位置
将一个mtz格式的主题包命名为zip文件解压,然后将其中的com.android.launcher后缀该为.zip然后解压,找到其中的theme_values.xml(有时候旧的主题没有该文件,可以下载附件中的xml替换进去即可),用记事本打开,会发现里面有各种各样的标签。
找到其中的<string name="wallpaper_scrolling">。。。</string>标签,将中间的内容按如下修改:
all——全范围滚动(默认设置)
left——壁纸固定在左侧不滚动
center——壁纸固定在中心不滚动
right——壁纸固定在右侧不滚动
2.自定义桌面滚动条
MIUI的滚动条设计虽然提供了快速定位桌面的功能,但同时也增加了误操作的机会。对主题的美观也造成了障碍。如果想要修改滚动条,可以在theme_values中找到如下语句<string name="home_indicator">。。。</string>标签,将中间的内容按如下修改:
slider——使用滚动条(默认设置)
none——禁用滚动条
bottom_point——使用下方点状桌面指示器
top_point——使用上方点状桌面状指示器
详细的步骤就是:
一、从手机的MIUI/theme目录下面找到对应的主题,我这里找到的是“四叶草_(807720.2).mtz”
二、将上面的主题后缀名由.mtz更改为.zip,然后双击解压可以找到“com.android.launcher”
三、将上面提到的com.android.launcher后面加上后缀.zip,然后将下载的theme_values.xml拷贝到com.android.launcher.zip包中。其中com.android.launcher.zip中与res目录同级,如下所示:
四、将com.android.launcher.zip后缀.zip去掉,然后放回“四叶草_(807720.2).zip”中,接着将“四叶草_(807720.2).zip”后缀更改为.mtz,即"四叶草_(807720.2).mtz“,重新将文件放置到手机的MIUI的theme目录下面。
五、打开手机自定义主题页面,手机会自动加载更改过的主题,修改即完毕。
由于没有找到附件的上传方式,这里贴出theme_values.xml的代码,请知晓
<MIUI_Theme_Values> <color name="icon_title_text">#ffffffff</color> <color name="icon_title_text_shadow">#ff000000</color> <color name="icon_message_text">#ffffffff</color> <color name="folder_title_text">#ffffffff</color> <color name="folder_title_text_shadow">#99000000</color> <color name="icon_shadow">#99333333</color> <string name="home_indicator">bottom_point</string> <string name="wallpaper_scrolling">center</string> </MIUI_Theme_Values>
秘钥的生成:可以利用机器码生成秘钥。例如:IOS端在注册用户名密码的时候,同时将iPad的机器码保存在对应账户里(数据库里),这样当往指定iPad端传输数据的时候,就用保存在数据库中的此iPad机器码生成秘钥,而在iPad的程序里则直接调用此iPad机器码生成秘钥进行解密。
加密算法
/* * @param encryptString 待加密的字符串 * @param encryptKey 生成秘钥的字符串,例如:机器码 * @return 加密后的字符串 */ public String encrypt(String encryptString,String encryptKey) throws Exception { SecretKeySpec key = new SecretKeySpec(encryptKey.getBytes(),"DES"); Cipher cipher = Cipher.getInstance("DES"); cipher.init(Cipher.ENCRYPT_MODE,key);//Cipher.ENCRYPT_MODE(加密标识) byte[] encryptedData = cipher.doFinal(encryptString.getBytes("UTF-8"));DES//加密 return Base64.encode(encryptedData);//Base64加密生成在Http协议中传输的字符串 }
解密算法
/* * @param decryptString 待解密的字符串 * @param decryptKey 生成秘钥的字符串,例如:机器码 * @return 解密后的字符串 */ public String decrypt(String decryptString, String decryptKey) throws Exception { byte[] byteMi = Base64.decode(decryptString); SecretKeySpec key = new SecretKeySpec(decryptKey.getBytes(),"DES"); Cipher cipher = Cipher.getInstance("DES"); cipher.init(Cipher.DECRYPT_MODE,key); byte[] decryptData = cipher.doFinal(byteMi); return new String(decryptData); }
是什么
提供一部分UI逻辑(主要为UI逻辑,非UI逻辑为UI逻辑服务),就像完整的UI逻辑的一部分碎片
each frgment defines
its own layout and
its own behavior
with its own lifecycle callbacks
设计它,是为了:
封装一些彼此相关的UI逻辑
使得这部分逻辑可以复用
一个例子:
you can reuse your fragments in different layout configurations to optimize the user experience based on the available screen spac
to continue with the news application example—the application can embed two fragments inActivity A, when running on a tablet-sized device. However, on a handset-sized screen, there's not enough room for both fragments, so Activity A includes only the fragment for the list of articles, and when the user selects an article, it starts Activity B, which includes the second fragment to read the article. Thus, the application supports both tablets and handsets by reusing fragments in different combinations
它要attach到一个activity上
时机:Once the activity reaches the resumed state, you can freely add and remove fragments to the activity
它被关联到一个container(该activity的viewgroup)上(fragment.view成为container的孩子,该container还可以有其他的孩子,还可能关联其他的fragment),且,一旦关联上,在整个生命周期内(create-destroy),不能改变这种关联
改变关联,修改fragment.container.parent
--
Vs activity:
Activity对象并不允许用户自行构建,且其生命周期由android来控制
Fragment对象要用户自行构建,其还定义了生命周期方法,其由android控制
--
标识:
Ui类型的fragment可由id,tag标识
对于layout.xml类型,你可以直接设置android:id
对于非layout.xml类型,你可以通过container.id来找到fragment
非Ui类型的fragment可由tag标识
vs 被封装的view提供器
我们可以写自己的viewmaker,所以,为什么需要fragment呢
因为:
Android控制了Fragment的生命(状态转换,生命周期回调),帮你考虑更多的情况,如:
Activity的状态迁移,将直接影响,fragment的状态迁移
when the activity receives onPause(), each fragment in the activity receives onPause().
生命周期
当一个fragment attach到一个activity上
当activity进入stop状态,则,fragment进入stop状态(ondestroyview以及之后的回调 不会被调用)
当activity又恢复到resume状态,fragment进入start状态
--
onSaveInstanceState:
you can retain the state of a fragment using a Bundle, in case the activity's process is killed and you need to restore the fragment state when the activity is recreated. You can save the state during the fragment'sonSaveInstanceState() callback and restore it during either onCreate(), onCreateView(), or onActivityCreated().
Managing Fragments:
● fragmentmanager
● fragmentTransacton
是什么:Each set of changes that you commit to the activity is called a transaction
能做什么:add, remove, or replace a fragment, .etc.
--
Add/remove vs attach/detach:
→ Add()
当你要添加一个fragment时,你需要使用add来表示:该fragment要被attach到activity上
虽然fragment对象由用户构建,但是标准的生命周期回调由android控制。此时,oncreate…会被调用,就好像,该fragment是刚出生的一样
→ Remove()
当你认为activity的那个fragment不需要再存在了,你会调用remove,fragment会被android认为是“垃圾”,并试图“回收”(ondestroyxxx),(但是,这仅是概念上给人的感觉,该fragment对象还依然存在,并未被当作垃圾回收,因为fragment对象是由我们手动产生,而不是交由android自动)
之后,android将不再控制该fragment的生命(任何回调)
→ Detach()
fragment要被attach到一个activity上,那么detach意味着,该fragment不再“attach”到activity上,那么意味着什么:fragment定义的view将不再被认为有用,那么 构建view所涉及的资源 将被释放(ondestroyview)
不要被搞乱了:
真实的detach为:fragment脱离了activity,即是:不再有用,要被销毁
但是,android并不认为detach()之后,fragment要成为垃圾,要被destroy(也意味着:Android依然会控制该fragment的生命)
所以,只能理解,detach()仅仅是为了表达:fragment的view应该被回收(这在逻辑上,也是通的)
→ Attach()
对比于detach(),attach()意味着:fragment的view再次有用:需要再次构建(oncreateview),并呈现出来
--
Backstack:
You can save each transaction to a back stack managed by the activity
Vs activity
An activity is placed into a back stack of activities that's managed by the system when it's stopped, by default (so that the user can navigate back to it with the Back button, as discussed in Tasks and Back Stack). However, a fragment is placed into a back stack managed by the host activity only when you explicitly request that the instance be saved by calling addToBackStack() during a transaction that removes the fragment.
猜想:一个transact被放入到backstack,那么点击back时,就让transact做一个相反的操作,如:之前做的是detach,那么back时,做的就是attac
通信:
● Fragment和activity间的通信
Fragment.getactivity()得到activity
Fragmentmanager.findfragmentby…()得到fragment
● Fragment之间
请使用设计模式中的 观察者模式(设置好依赖关系)
样式:
● 包含Ui的fragment
The android:name attribute in the <fragment> specifies the Fragment class to instantiate in the layout.
When the system creates this activity layout, it instantiates each fragment specified in the layout and calls the onCreateView() method for each one, to retrieve each fragment's layout.
The system inserts the Viewreturned by the fragment directly in place of the <fragment> element.
● 无UI的fragment
you can also use a fragment to provide a background behavior for the activity without presenting additional UI.