autojs应用锁

2024-01-14 13:32
文章标签 应用 autojs

本文主要是介绍autojs应用锁,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

牙叔教程 简单易懂

效果展示

在这里插入图片描述

功能

屏蔽指定app界面的触摸事件, 让别人无法操控你的手机

原理

添加一个定时器, 检查是不是指定的app, 是的话就用悬浮窗遮挡, 不是就不遮挡

环境

Autojs版本: 9.0.5

Android版本: 10.0.0

MIUI版本: 12.5.1

你将学到以下知识点

  • 停止非自身的其他脚本
  • 自定义勾选框
  • UI界面配置的自动保存
  • 打开脚本时还原上次配置
  • 获取手机上app列表
  • 判断app是否存在
  • 悬浮窗权限的申请和判断
  • 查看使用情况权限的申请和判断
  • 允许后台弹出界面的申请
  • 关闭电池优化的申请和判断
  • 允许自启动的申请
  • 桌面图标的隐藏和显示
  • 最近任务隐藏和显示

权限分类

  • 隐藏类
    • 隐藏桌面图标
    • 从最近任务隐藏
  • 非隐藏类
    • 悬浮窗权限
    • 查看使用情况权限
    • 允许后台弹出界面
    • 关闭电池优化
    • 允许自启动
  • 非隐藏类又分两种, 安卓系统是否提供了, 判断用户是否授予权限的api
    • 可以判断: 悬浮窗权限, 查看使用情况权限, 关闭电池优化
    • 不可以判断: 允许后台弹出界面, 允许自启动

权限功能

  • 悬浮窗权限: 用于屏蔽用户的触摸事件

  • 查看使用情况权限: 比如查看当前时那个app, 某个app用了多久之类的

  • 允许后台弹出界面: 不给这个权限, 那么app处于后台, 就什么都干不了

  • 关闭电池优化: 电量低的时候, 大概率不会第一个被系统杀死

  • 允许自启动: 用于定时启动之类的, 或者开机自启动

  • 隐藏桌面图标

  • 从最近任务隐藏: 最近任务中, 看不到app的身影

代码讲解

1. 悬浮窗权限
悬浮窗权限: {apply: function () {app.startActivity({packageName: "com.android.settings",className: "com.android.settings.Settings$AppDrawOverlaySettingsActivity",data: "package:" + context.packageName.toString(),});},check: function () {return floaty.checkPermission();},
},
2. 自定义控件
(function () {util.extend(CustomView, ui.Widget);function CustomView() {ui.Widget.call(this);let scope = this;let paint = new Paint(Paint.ANTI_ALIAS_FLAG);let rect = new android.graphics.RectF();paint.setAntiAlias(true);paint.setAlpha(255); //透明度0-255  0完全透明 255完全不透明paint.setStyle(android.graphics.Paint.Style.FILL);let deviation = 12;let checkedColor = "#27ae60";let unCheckedColor = "#bdc3c7";this.checked = false;this.defineAttr("checked", (view, attr, value, defineSetter) => {if (value === "false") {this.checked = false;} else if (value === "true") {this.checked = true;}this.updateColor();});this.defineAttr("checkedColor", (view, attr, value, defineSetter) => {checkedColor = value;});this.defineAttr("unCheckedColor", (view, attr, value, defineSetter) => {unCheckedColor = value;});this.setChecked = function (value) {this.checked = value;this.updateColor();};this.getChecked = function () {return this.checked;};this.updateColor = function () {if (this.checked) {setBackground(scope.view, checkedColor);} else {setBackground(scope.view, unCheckedColor);}};this.onFinishInflation = function (view) {view.post(function () {scope.updateColor();});};}...CustomView.prototype.render = function () {return <View w="30dp" h="30dp" margin="6 6 6 6"></View>;};ui.registerWidget("custom-checkbox", CustomView);return CustomView;
})();
3. 获取app列表
function getAppList() {let appList = $app.getInstalledApps({get: ["meta_data"],match: ["factory_only"],});return appList;
}
4. 判断app是否存在
function appExists(appName, appList) {var len = appList.length;for (var i = 0; i < len; i++) {let item = appList[i];if (item.label === appName) {return true;}}
}
5. UI界面
ui.layout(<scroll><vertical padding="16dp"><text text="应用锁" margin="0 0 0 10" textColor="#d9000000" textSize="35sp" w="*" gravity="center"></text><texttext="--牙叔教程 简单易懂"margin="0 0 0 10"textColor="#80000000"textSize="25sp"w="*"gravity="center"></text><card cardCornerRadius="5dp" w="match_parent" h="wrap_content"><list id="list" padding="10" bg="#7a57d1"><horizontal w="match_parent" margin="0 0 0 6"><View w="10dp" h="match_parent" bg="{{this.guideColor}}"></View><vertical layout_weight="1" marginLeft="10"><text id="permissionName" textSize="24sp" textColor="#d9ffffff" text="{{this.permissionName}}"></text><textid="permissionDescription"textSize="16sp"textColor="#80ffffff"text="{{this.permissionDescription}}"></text></vertical><custom-checkboxid="permissionStatus"checkedColor="#30e6db"unCheckedColor="#F5F7FA"checked="{{this.permissionStatus}}"></custom-checkbox></horizontal></list></card><horizontal margin="0 10 0 0"><text id="label" text="要锁定的app名字: " textSize="24sp" textColor="#d9000000"></text><input id="appName" w="*" singleLine="true"></input></horizontal><button id="lock" bg="#7a57d1" textColor="#d9ffffff" textSize="24sp" text="锁定"></button><text id="desc" textSize="18sp" textColor="#80000000"></text></vertical></scroll>
);
6. 软键盘呈现的方式: 布局高度不变,上移动,腾出足够空间给软键盘
activity.window.setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_ADJUST_PAN);
7. 随时保存界面配置
ui.emitter.on("pause", () => {// 记录那些不能正常判断权限的勾选框状态var len = items.length;for (var i = 0; i < len; i++) {let item = items[i];if (!~unHiddenPermission.indexOf(item.permissionName)) {storage.put(item.permissionName, item.permissionStatus);} else {if (!~canCheckPermission.indexOf(item.permissionName)) {storage.put(item.permissionName, item.permissionStatus);}}}storage.put("appName", ui.appName.text());
});
8. 悬浮窗界面
window = floaty.rawWindow(<frame gravity="center" bg="#00ff0000"><text id="content" textColor="#0076ff03" textSize="66sp" w="*" h="*" gravity="center"></text></frame>
);
window.content.setText("应用锁\n牙叔教程");
window.setSize(-1, -1);
window.setTouchable(true);
9. 定时器锁定指定app
setInterval(function () {var currentPackageName = currentPackage();if (packageName === currentPackageName) {window.setPosition(0, 0);} else {window.setPosition(6000, 6000);}
}, 200);

名人名言

思路是最重要的, 其他的百度, bing, stackoverflow, 安卓文档, autojs文档, 最后才是群里问问
— 牙叔教程

声明

部分内容来自网络
本教程仅用于学习, 禁止用于其他用途

bilibili

牙叔教程

微信公众号 牙叔教程

在这里插入图片描述

QQ群

747748653
在这里插入图片描述

完整源码

这篇关于autojs应用锁的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/605322

相关文章

CSS3 布局样式及其应用举例

《CSS3布局样式及其应用举例》CSS3的布局特性为前端开发者提供了无限可能,无论是Flexbox的一维布局还是Grid的二维布局,它们都能够帮助开发者以更清晰、简洁的方式实现复杂的网页布局,本文给... 目录深入探讨 css3 布局样式及其应用引言一、CSS布局的历史与发展1.1 早期布局的局限性1.2

在React聊天应用中实现图片上传功能

《在React聊天应用中实现图片上传功能》在现代聊天应用中,除了文字和表情,图片分享也是一个重要的功能,本文将详细介绍如何在基于React的聊天应用中实现图片上传和预览功能,感兴趣的小伙伴跟着小编一起... 目录技术栈实现步骤1. 消息组件改造2. 图片预览组件3. 聊天输入组件改造功能特点使用说明注意事项

Redis中RedisSearch使用及应用场景

《Redis中RedisSearch使用及应用场景》RedisSearch是一个强大的全文搜索和索引模块,可以为Redis添加高效的搜索功能,下面就来介绍一下RedisSearch使用及应用场景,感兴... 目录1. RedisSearch的基本概念2. RedisSearch的核心功能(1) 创建索引(2

Python datetime 模块概述及应用场景

《Pythondatetime模块概述及应用场景》Python的datetime模块是标准库中用于处理日期和时间的核心模块,本文给大家介绍Pythondatetime模块概述及应用场景,感兴趣的朋... 目录一、python datetime 模块概述二、datetime 模块核心类解析三、日期时间格式化与

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

C语言中位操作的实际应用举例

《C语言中位操作的实际应用举例》:本文主要介绍C语言中位操作的实际应用,总结了位操作的使用场景,并指出了需要注意的问题,如可读性、平台依赖性和溢出风险,文中通过代码介绍的非常详细,需要的朋友可以参... 目录1. 嵌入式系统与硬件寄存器操作2. 网络协议解析3. 图像处理与颜色编码4. 高效处理布尔标志集合

Java中的Lambda表达式及其应用小结

《Java中的Lambda表达式及其应用小结》Java中的Lambda表达式是一项极具创新性的特性,它使得Java代码更加简洁和高效,尤其是在集合操作和并行处理方面,:本文主要介绍Java中的La... 目录前言1. 什么是Lambda表达式?2. Lambda表达式的基本语法例子1:最简单的Lambda表

Python结合PyWebView库打造跨平台桌面应用

《Python结合PyWebView库打造跨平台桌面应用》随着Web技术的发展,将HTML/CSS/JavaScript与Python结合构建桌面应用成为可能,本文将系统讲解如何使用PyWebView... 目录一、技术原理与优势分析1.1 架构原理1.2 核心优势二、开发环境搭建2.1 安装依赖2.2 验

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

SpringShell命令行之交互式Shell应用开发方式

《SpringShell命令行之交互式Shell应用开发方式》本文将深入探讨SpringShell的核心特性、实现方式及应用场景,帮助开发者掌握这一强大工具,具有很好的参考价值,希望对大家有所帮助,如... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定