大家用户一些一键清理内存的软件,会发现点击桌面上的“快速清理”快捷方式,就会播放一个动画,然后提示你清理了多少内存和进程,看起来挺酷的,不过这样子更大好处让用户减少了2次不必要的操作:点击执行清理操作,退出软件操作。
我们今天就拿金山电池医生做图解分析:
你用过金山电池医生的话,它会在之一次打开软件的时候,在你手机桌面上流氓地创建一个“快速省电”的快捷方式,如果你想一键清理进程,点它就可以。
起初,我以为这玩意是个widget,但是想想不对,那么搞没必要;当我真的要添加“窗口小部件”的时候,发现了玄机:
你仔细看会发现,快捷方式的图标和播放动画的图片错位了,哈哈,你是不是想说,这不就是骗小孩的把戏吗?
没错,其实就是个障眼法:当用户点击快捷方式的时候,实际上启动了快捷方式指向的activity,只不过这个activity是一个dialog风格,在里面播放一个动画而已,
当执行完清理内存的操作,动画结束,toast结果信息给用户,然后自己finish。
详细的做法如下:
1、现在AndroidManifest.xml里声明一个 activty,也是快捷方式要启动的窗体:
<activity android:name=".onekey.OneKeyActivity" android:excludeFromRecents="true" android:exported="true" android:icon="@drawable/shortcut_onekey" android:label="@string/shortcut_onekey" android:taskAffinity="com.souapp.screenlockmanager" android:theme="@android:style/Theme.Translucent.NoTitleBar" > <intent-filter> <action android:name="android.intent.category.MAIN" /> <action android:name="android.intent.action.CREATE_SHORTCUT" /> </intent-filter> </activity>
2、你的程序如何创建快捷方式,这里就不写了
3、简单说一下OneKeyActivity
在layout下创建一个布局文件:shortcut_onekey.xml
<?xml version="1.0" encoding="UTF-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/main" android:layout_width="fill_parent" android:layout_height="fill_parent" > <FrameLayout android:id="@+id/anim_layout" android:layout_width="60.0dip" android:layout_height="60.0dip" android:background="@drawable/shortcut_onekey_bg" android:visibility="invisible" > <ImageView android:id="@+id/anim_image" android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="@drawable/shortcut_onekey_rotate" android:visibility="invisible" /> <ImageView android:id="@+id/cover_image" android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="@drawable/shortcut_onekey_cover" android:visibility="visible" /> </FrameLayout> </RelativeLayout>
其实这个布局文件就是堆放了几个图片而已
然后动画效果,需要在anim目录下创建shortcut_onekey.xml
<?xml version="1.0" encoding="UTF-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android" > <rotate android:duration="1200" android:fromDegrees="0.0" android:pivotX="50.0%" android:pivotY="50.0%" android:toDegrees="1440.0" /> </set>
下面是OneKeyActivity的主要代码:
@Override public void onCreate(Bundle bundle) { super.onCreate(bundle); Intent intent = getIntent(); setContentView(R.layout.shortcut_onekey); bg = (FrameLayout)findViewById(R.id.anim_layout); Rect rect = intent.getSourceBounds(); if(rect != null) { //int i = getResources().getDimensionPixelSize(0x7f0b001d); int i=20; int j = rect.left + rect.width() / 2; int k = i + rect.top; android.widget.RelativeLayout.LayoutParams layoutparams = (android.widget.RelativeLayout.LayoutParams)bg.getLayoutParams(); layoutparams.leftMargin = j - layoutparams.width / 2; layoutparams.topMargin = k - layoutparams.height / 2; bg.setLayoutParams(layoutparams); } play(this); mHandler.sendEmptyMessageDelayed(1, 1000); } public static void play(OneKeyActivity onekeyactivity) { onekeyactivity.bg.setVisibility(0); ImageView imageview = (ImageView)onekeyactivity.findViewById(R.id.anim_image); imageview.setVisibility(0); imageview.startAnimation(AnimationUtils.loadAnimation(onekeyactivity, R.anim.shortcut_onekey)); } private Handler mHandler = new Handler() { public void handleMessage(Message msg) { Toast.makeText(getApplicationContext(), "杀掉N多个进程", Toast.LENGTH_SHORT).show(); if (1 == msg.what) finish(); // 动画播放结束,结束我们的Activity界面 } };
整体而言,是比较简单的;但是这种效果的设计,我觉得不是程序员和美工能想出来的,应该是产品经理这种比较贴近于用户使用角度,提出类似的使用需求来;看来干啥都不容易,特别是做APP不赚钱,还要想方设法改善用户体验,得到用户的使用认可,也只有大公司有这个资源,有闲工夫养着一批人这么玩。
据外媒The Verge报道,迪士尼在当地时间周四宣布,将在2021年3月5日《寻龙传说》( Raya and the Last Dragon)于院线上映的当天,以Premier Access的形式发...
近日,人气急升的TV动画《咒术回战》即将于2月5日播出最新第17话《京都姉妹校交流会―団体战4》,今天官方公开了2名预定登场的新角色,一起来了解下。 ·《咒术回战》是一部以咒...
时间过得真快,一转眼《布鲁可战队》上映两个月,相信小朋友、大朋友对葡乐镇的故事已经不陌生了,与葡萄的距离也越走越近。是怎样的团队打造出了这部又能认识车辆,又塑造小朋友性格的动画呢?这次专访,带领大家认...
第93届奥斯卡最佳动画长片奖入围大名单出炉,一共27部,大热门动画均在列,包括《心灵奇旅》《狼行者》,日本现象级动画...
“倚剑江湖踏歌行”少年歌行漫影联动发布会12 月10 日在北京吉里星空间盛大召开。本次发布会由优酷、晨星盛世、中影年年共同举办,优酷剧集中心总经理谢颖、优酷动漫中心总经理孙旻、晨星盛世董事长周涛、中影...
在原型设计中,我们也经常需要做一些简朴的动画结果。如何才气够完成呢?本文将从三个方面举办梳理,但愿对你有辅佐。 事情中发明,在原型设计傍边,偶然需要做一些简朴的动画结果。究竟动态相较于静态,往往越发...