百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分析 > 正文

「有内鬼,终止交易」风靡朋友圈的壁纸,实现代码竟如此简单 | 原力计划

liebian365 2025-02-15 00:01 9 浏览 0 评论

作者 | sanmianti

来源 | CSDN博客

出品 | CSDN(ID:CSDNnews)

前几天刷抖音时,看到一款壁纸,显示的是诺基亚时代的键盘机样式,昏黄的屏幕显示着【有内鬼,终止交易】的消息内容。感觉很有创意,记忆一下飘到十年前,那时候手机没有微信,没有QQ,没有抖音~蛮荒时代,大家都是通过短信聊天儿,一条信息一毛钱,偶尔通过移动梦网上网充个浪,一不小心用掉3、5M流量然后电话就欠费停机了, 哈哈哈哈。

既然那么有时代感,那么能引起我们共同的追忆,想着如果能做一款应用,它不仅仅是一款壁纸,而且可以点击按键,甚至可以收发短信,拨打电话,岂不是很酷。光说不练假把式,说干就干,接下来就看我们如何实现它!

实现思路

先给大家看一下效果图:

看似复杂,实际上整个应用就由一个主activity架起,activity布局上半部分是Android原生的两个ImageView(MyNokia 图标及模拟屏幕效果),布局下半部分即键盘处是一个WebView内嵌一个本地页面,键盘效果由本地HTML网页渲染得到,通话及短信都是调用的系统界面。

该应用的难点在于如何准确的在一张图片上的各个部位绑定监听事件,例如数字键、星号键、确认键等等。网上有各种实现思路,但尝试后发现都不太理想,要么过于复杂、要么在不同设备上适配性不佳,监听点击位置不准确。

后来转变思路,尝试将该图片切割为不同的小模块,然后为每一个模块View绑定监听事件,最后将各个子模块合并在一起,从视觉效果上就像一张完整的图片。

比较幸运的是之前有一定的PS使用经验,在PS里面有一个非常好用的工具可以帮助我们快速完成上述切割步骤。该工具叫【切片工具】,使用切片工具将目标图片划分为一个一个小模块后,然后选择【文件】→【导出】→【存储为web格式】,PS自动会将图片切割为一个一个的小模块(item)然后组合在一起生成一个HTML文件,该HTML打开后渲染出切割前的完整图片样式。切割完成后我们在应用中直接嵌入该HTML,同时为HTML中的每一个item绑定监听事件,并将点击事件透传给原生activity进行处理即可。

详细代码

Github 源码
:https://github.com/sanmianti/MyNokia

layout布局文件

两个ImageView分别显示NOKIA Logo和屏幕效果,三个TextView分别对应着【销毁】按钮和【退出】按钮以及屏幕中央正文显示,一个Web用于加载本地HTML渲染出键盘效果。

 1
2
3
4
5 6
7 ......
8
9 android:layout_width="match_parent"
10
11 android:layout_height="match_parent">
12
13
14
15 16
17 ......
18
19 android:id="@+id/imageView"
20
21 android:layout_width="match_parent"
22
23 android:layout_height="wrap_content"/>
24
25
26
27 28
29 ......
30
31 android:id="@+id/imageView2"
32
33 android:layout_width="match_parent"
34
35 android:layout_height="0dp"
36
37 android:src="@drawable/screen"/>
38
39
40
41 42
43 ......
44
45 android:id="@+id/input"
46
47 android:layout_width="wrap_content"
48
49 android:layout_height="wrap_content"
50
51 android:text="讯息:\n\n有内鬼,终止交易!"/>
52
53
54
55 56
57 ......
58
59 android:layout_width="wrap_content"
60
61 android:layout_height="wrap_content"
62
63 android:text="销毁"/>
64
65
66
67 68
69 ......
70
71 android:layout_width="wrap_content"
72
73 android:layout_height="wrap_content"
74
75 android:padding="24dp"
76
77 android:text="退出"/>
78
79
80
81 82
83 ......
84
85 android:id="@+id/webview_keyboard"
86
87 android:layout_width="0dp"
88
89 android:layout_height="0dp"/>
90
91
92
93

拨打电话

 1private void callPhone(String number) {
2
3 if (TextUtils.isEmpty(number)) {
4
5 showToastMessage("请输入手机号");
6
7 }else {
8
9 Intent intent = new Intent;
10
11 intent.setAction(Intent.ACTION_CALL);
12
13 Uri data = Uri.parse("tel:" + number);
14
15 intent.setData(data);
16
17 startActivity(intent);
18
19 }
20
21}

跳转至短信列表

 1private void toSMSList{
2
3 try{
4
5 Intent intent4 = new Intent;
6
7 intent4.setClassName("com.android.mms","com.android.mms.ui.ConversationList");
8
9 startActivity(intent4);
10
11 }catch (Exception e){
12
13 showToastMessage("打开短信失败");
14
15 }
16
17
18
19}

打开通讯录

 1private void toAddressList{
2
3 try{
4
5 Intent intent = new Intent(Intent.ACTION_VIEW, ContactsContract.Contacts.CONTENT_URI);
6
7 startActivityForResult(intent, 0);
8
9 }catch (Exception e){
10
11 showToastMessage("打开通讯录失败");
12
13 }
14
15}

加载键盘布局及监听JS点击事件

1binding.webviewKeyboard.loadUrl("file:///android_asset/15694580471773267.html");
3binding.webviewKeyboard.addJavascriptInterface(new MainActivityJS, "jsObj");

说那么多,看的可能云里雾里,不妨结合源码看一下,跑一下demo,主代码拢共不到300行。很简单,聪明的你肯定一看就懂。如遇到任何问题,欢迎留言反馈。

源码及下载

Github MyNokia 源码:

https://github.com/sanmianti/MyNokia

点我下载安装包:
https://download.csdn.net/download/u012719153/12196860

原文链接:

https://blog.csdn.net/u012719153/article/details/104548331

相关推荐

4万多吨豪华游轮遇险 竟是因为这个原因……

(观察者网讯)4.7万吨豪华游轮搁浅,竟是因为油量太低?据观察者网此前报道,挪威游轮“维京天空”号上周六(23日)在挪威近海发生引擎故障搁浅。船上载有1300多人,其中28人受伤住院。经过数天的调...

“菜鸟黑客”必用兵器之“渗透测试篇二”

"菜鸟黑客"必用兵器之"渗透测试篇二"上篇文章主要针对伙伴们对"渗透测试"应该如何学习?"渗透测试"的基本流程?本篇文章继续上次的分享,接着介绍一下黑客们常用的渗透测试工具有哪些?以及用实验环境让大家...

科幻春晚丨《震动羽翼说“Hello”》两万年星间飞行,探测器对地球的最终告白

作者|藤井太洋译者|祝力新【编者按】2021年科幻春晚的最后一篇小说,来自大家喜爱的日本科幻作家藤井太洋。小说将视角放在一颗太空探测器上,延续了他一贯的浪漫风格。...

麦子陪你做作业(二):KEGG通路数据库的正确打开姿势

作者:麦子KEGG是通路数据库中最庞大的,涵盖基因组网络信息,主要注释基因的功能和调控关系。当我们选到了合适的候选分子,单变量研究也已做完,接着研究机制的时便可使用到它。你需要了解你的分子目前已有哪些...

知存科技王绍迪:突破存储墙瓶颈,详解存算一体架构优势

智东西(公众号:zhidxcom)编辑|韦世玮智东西6月5日消息,近日,在落幕不久的GTIC2021嵌入式AI创新峰会上,知存科技CEO王绍迪博士以《存算一体AI芯片:AIoT设备的算力新选择》...

每日新闻播报(September 14)_每日新闻播报英文

AnOscarstatuestandscoveredwithplasticduringpreparationsleadinguptothe87thAcademyAward...

香港新巴城巴开放实时到站数据 供科技界研发使用

中新网3月22日电据香港《明报》报道,香港特区政府致力推动智慧城市,鼓励公私营机构开放数据,以便科技界研发使用。香港运输署21日与新巴及城巴(两巴)公司签署谅解备忘录,两巴将于2019年第3季度,开...

5款不容错过的APP: Red Bull Alert,Flipagram,WifiMapper

本周有不少非常出色的app推出,鸵鸟电台做了一个小合集。亮相本周榜单的有WifiMapper's安卓版的app,其中包含了RedBull的一款新型闹钟,还有一款可爱的怪物主题益智游戏。一起来看看我...

Qt动画效果展示_qt显示图片

今天在这篇博文中,主要实践Qt动画,做一个实例来讲解Qt动画使用,其界面如下图所示(由于没有录制为gif动画图片,所以请各位下载查看效果):该程序使用应用程序单窗口,主窗口继承于QMainWindow...

如何从0到1设计实现一门自己的脚本语言

作者:dong...

三年级语文上册 仿写句子 需要的直接下载打印吧

描写秋天的好句好段1.秋天来了,山野变成了美丽的图画。苹果露出红红的脸庞,梨树挂起金黄的灯笼,高粱举起了燃烧的火把。大雁在天空一会儿写“人”字,一会儿写“一”字。2.花园里,菊花争奇斗艳,红的似火,粉...

C++|那些一看就很简洁、优雅、经典的小代码段

目录0等概率随机洗牌:1大小写转换2字符串复制...

二年级上册语文必考句子仿写,家长打印,孩子照着练

二年级上册语文必考句子仿写,家长打印,孩子照着练。具体如下:...

一年级语文上 句子专项练习(可打印)

...

亲自上阵!C++ 大佬深度“剧透”:C++26 将如何在代码生成上对抗 Rust?

...

取消回复欢迎 发表评论: