当前位置: 首页 > news >正文

做网站背景图的科技图片专业建设的主要内容

做网站背景图的科技图片,专业建设的主要内容,昌吉州住房和城乡建设局网站,汽车之家网站Android 辅助服务(AccessibilityService)旨在帮助具有视觉、身体或年龄相关限制的用户更轻松地使用 Android 设备和应用。通过辅助服务,可以将一些人工操作自动化,从而解放用户的双手。 因此我们可以使用它来实现一些自动化任务&a…

Android 辅助服务(AccessibilityService)旨在帮助具有视觉、身体或年龄相关限制的用户更轻松地使用 Android 设备和应用。通过辅助服务,可以将一些人工操作自动化,从而解放用户的双手。
因此我们可以使用它来实现一些自动化任务,比如抢红包,测试,自动玩游戏(外挂?)。author: https://blog.csdn.net/keeng2008

  1. 编写辅助服务MyAccessibilityService,继承AccessibilityService
class MyAccessibilityService : AccessibilityService() {override fun onServiceConnected() {super.onServiceConnected()Log.i(TAG, "onServiceConnected")}override fun onAccessibilityEvent(event: AccessibilityEvent) {Log.i(TAG, "onAccessibilityEvent: $event")val packageName = event.packageName/* 处理界面变动事件 */}override fun onInterrupt() {Log.i(TAG, "onInterrupt")}
}

当辅助服务开启后,Service会开始运行,界面上的元素变动,窗口变动会回调onAccessibilityEvent。在其中可以实现模拟点击。

  • 这个服务不能主动开启,需要用户在设置-无障碍中手动开启。
  1. 把MyAccessibilityService添加到Manifest
    <serviceandroid:name=".accessbi.MyAccessibilityService"android:exported="true"android:label="控制辅助服务Demo"android:permission="android.permission.BIND_ACCESSIBILITY_SERVICE"><intent-filter><action android:name="android.accessibilityservice.AccessibilityService" /></intent-filter><meta-dataandroid:name="android.accessibilityservice"android:resource="@xml/my_accessibility" /></service>

在res/xml中添加文件 my_accessibility.xml

<?xml version="1.0" encoding="utf-8"?>
<accessibility-service xmlns:android="http://schemas.android.com/apk/res/android"android:accessibilityEventTypes="typeAllMask"android:accessibilityFeedbackType="feedbackSpoken"android:accessibilityFlags="flagReportViewIds"android:canRetrieveWindowContent="true"android:canPerformGestures="true"android:notificationTimeout="100"/>

这样就已经注册好辅助服务,但是需要用户手动到“设置”中的“无障碍”,去启动无障碍功能。

  1. 引导用户直接跳转到无障碍中启动
  • 3.1 判断当前是否已经启动
    fun isAccessibilitySettingsOn(context: Context): Boolean {val accessibilityEnabled = Settings.Secure.getInt(context.contentResolver,Settings.Secure.ACCESSIBILITY_ENABLED)if (accessibilityEnabled != 1) return falseval value = Settings.Secure.getString(context.contentResolver,Settings.Secure.ENABLED_ACCESSIBILITY_SERVICES) ?: return falsereturn value.contains(context.packageName) &&value.contains(MyAccessibilityService::class.java.simpleName)}
  • 3.2 跳转到无障碍设置界面
    发现未开启服务后,引导用户跳转到设置界面,手动打开。
    fun openAccessibilitySetting(context: Context) {val intent = Intent(Settings.ACTION_ACCESSIBILITY_SETTINGS)context.startActivity(intent)}
  • 3.3 开启后能否保持状态
    经测试,如果进程被主动杀死重启,那么开关就被关闭了。
    其它情况下即使关机重启,更新APP,它的状态能保持-
  1. AccessibilityService常用方法
  • 获取当前的APP: val packageName = event.packageName
  • 获取当前的Activity:
    fun getActivityName(context: Context, event: AccessibilityEvent): String {val componentName = ComponentName(event.packageName.toString(), event.className.toString())try {var activityName = context.packageManager.getActivityInfo(componentName, 0).toString()activityName =activityName.substring(activityName.indexOf(" "), activityName.indexOf("}"))return activityName} catch (e: Exception) {}return ""}

不是每个event都能获取到Activity的,比如一些Toast,Dialog的事件,拿不到Activity; 所以可以把最后的Activity保存起来,随时读取。

  • 通过文本获取当前界面的View
fun findViewByText(svr: AccessibilityAble, text: String): AccessibilityNodeInfo? {val nodes = svr.getRootNode()?.findAccessibilityNodeInfosByText(text)if (nodes != null) {for (node in nodes) {if (node.text == text) {return node}}}return nodes?.firstOrNull()
}

AccessibilityAble: 主是要封装了对 getService().rootInActiveWindow 的引用, 这样可以从当前的全局根结点开始寻找。

  • 通过viewId获取当前界面的View
    格式示例 :“APP包名:id/operator_normal_iv”
fun findViewById(svr: AccessibilityAble, viewId: String): AccessibilityNodeInfo? {val nodes = svr.getRootNode()?.findAccessibilityNodeInfosByViewId(viewId)return nodes?.firstOrNull()
}
  • 模拟View点击
val btn: AccessibilityNodeInfo? = AccessibilityUtils.findViewByText(svr, "下次再说")
if (btn != null && btn.isClickable && btn.isVisibleToUser) {btn.performAction(AccessibilityNodeInfo.ACTION_CLICK)
}
  • 通过手势长按指定坐标
fun performLongPress(svr: AccessibilityAble, point: PointF, durationMill: Long) {// 创建手势描述val gestureBuilder = GestureDescription.Builder()// 移动到指定坐标val path = Path().apply {moveTo(point.x, point.y)}val duration: Long = durationMill // 持续时间 毫秒val strokeDescription = GestureDescription.StrokeDescription(path, 0, duration)// 添加手势到描述gestureBuilder.addStroke(strokeDescription)val gesture = gestureBuilder.build()// 执行手势val cb = object : AccessibilityService.GestureResultCallback() {override fun onCompleted(gestureDescription: GestureDescription?) {Log.i(TAG, "onCompleted, $gestureDescription")}override fun onCancelled(gestureDescription: GestureDescription?) {Log.i(TAG, "onCancelled, $gestureDescription")}}val res = svr.getService().dispatchGesture(gesture, cb, null)Log.i(TAG, "dispatchGesture, res: $res")
}
  • 点击Node所在位置:主要是有些文本不可点击,直接模拟点击该位置
fun performClick(svr: AccessibilityAble, node: AccessibilityNodeInfo) {val rect = Rect()node.getBoundsInScreen(rect)val centerP = PointF(rect.exactCenterX(), rect.exactCenterY())Log.i(TAG, "Start Simple Click at $centerP")performLongPress(svr,centerP,100L)
}

author: https://blog.csdn.net/keeng2008 有了这神器,能实现些什么新奇玩法呢?抢红包,自动打卡,继续探索中。

http://www.yayakq.cn/news/651769/

相关文章:

  • 专注专业网站建设软件app研发
  • 网站建设策划 流程图360游戏
  • 上海公司沪牌价格百度搜索引擎优化案例
  • 宜昌做网站公司做网站如何变现
  • 建下载网站软件商店电脑版下载
  • 网站开发文档有哪些百度经验网站建设
  • 闵行交大附近网站建设山东省建设监理网站
  • 腾讯云怎么做网站白酒企业网站源码
  • 百度做网站多少钱一年网站建设初期的工作计划
  • 哪个网站可以代做软件个人博客seo
  • 韩国美食做视频网站炒股网站开发
  • 容易被百度收录的网站网站建设那些公司比较好
  • 学校网站建设及使用娱乐网站开发
  • 做电影网站要很大的主机空间吗玉溪市建设厅官方网站
  • 建设一个下载资料的网站多种五屏网站建设
  • 设计师必备的国际设计网站电商网站 设计
  • 网盘 商业网站建设案例课程 下载诸暨做网站广告的电话
  • wordpress not found如何建设和优化一个网站步骤
  • 交通局网站模板太原网站建设王道下拉惠
  • 网站前台建设用到哪些工具河南建筑业城乡建设网站查询
  • 国外毕业设计网站网络优化大师app
  • 怀化二医院网站网站开发技术的现状
  • 简要描述创建商务站点的商务做企业网站需要准备什么
  • 类似稿定设计的网站旅游 网站建设目标
  • 淘客类网站如何做排名网站的建设方式
  • 网站怎么做来流量广告联盟怎么做
  • 体育直播网站建设电商网站会员体制怎么做
  • 网站的注册页面怎么做宣传片拍摄注意事项
  • 网站里怎样做物流跟踪功能免费可商用网站
  • 厦门外贸网站建设报价表郑州做网站