Submit Code

This commit is contained in:
daidai2 2023-05-16 14:46:06 +08:00
parent 5b83090613
commit b830e36689
1395 changed files with 115020 additions and 0 deletions

2
.gitattributes vendored Normal file
View File

@ -0,0 +1,2 @@
Security/Code/Phishing[[:space:]]Hijacking/PIPMoveStack/app/src/main/res/raw/live.mp4 filter=lfs diff=lfs merge=lfs -text
Security/Code/Phishing[[:space:]]Hijacking/PIPPishing/app/src/main/res/raw/live.mp4 filter=lfs diff=lfs merge=lfs -text

View File

@ -0,0 +1,233 @@
import time
import uiautomator2 as u2
import weditor #方便快速识别手机上的元素,方便写代码
from appium import webdriver
#adb路径C:\Users\zlllllau\android-sdks\platform-tools
#元素定位工具C:\Users\zlllllau\android-sdks\tools
#USB链接选项选择”传输文件“否则abd不能连接
from tornado.gen import Wait
from win32api import Sleep
class Screen_record:
device_name = "1a4587ef" #oppo机
app_name = "腾讯会议"
device = None
def connect(self,device_name = "1a4587ef"):
self.device_name = device_name
self.device=u2.connect(self.device_name)
print("链接成功")
#打开对应的app
def open_app(self, app_name):
self.app_name = app_name
self.device.app_start(app_name, stop=True)
#开启腾讯会议app的录屏功能
def start_app_screenRecord(self):
try:
self.device(textContains='快速会议').click()
except Exception:
print("无按钮1")
try:
self.device(textContains='进入会议').click()
except Exception:
print("无按钮2")
try:
self.device(textContains='更多').click()
except Exception:
print("无按钮3")
try:
self.device(textContains='云录制').click()
except Exception:
print("无按钮4")
# if self.device(textContains='进入会议').exists:
# self.device(textContains='进入会议').click()
#开启手机自身的录屏功能
def start_syst_screenRecord(self,video_name="test"):
try:
#打开通知栏
self.device.open_notification()
time.sleep(2)
self.device.swipe(550, 590, 550, 2000)
self.device(description='屏幕录制').click()
#Android已禁用self.device.screenrecord("{}.mp4".format(video_name))
self.device(resourceId="com.coloros.screenrecorder:id/iv_play_status").click()
except Exception:
print("没有找到屏幕录制按钮")
#安装应用
def install_app(self, load_url=""):
pass
#打开其他待测app
def start_another(self,app_pkgname="QQ"):
#self.device.app_start(app_pkgname, stop=True) 找不到该包名?
if app_pkgname == "飞书":
self.device(text="飞书").click()
self.device(resourceId="com.ss.android.lark:id/textItem", text="更多").click()
self.device(text="视频会议").click()
self.device(text="发起会议").click()
self.device(text="开始会议").click()
#如果不等待一定时间,会没有小窗出现
time.sleep(3)
self.device.press("home")
if app_pkgname == "QQ":
self.device(text="QQ").click()
self.device(resourceId="com.android.systemui:id/recent_apps").click()
self.device.xpath('//*[@content-desc="QQ"]/android.view.ViewGroup[1]/android.widget.ImageButton[1]').click()
self.device(resourceId="com.oppo.launcher:id/text", text="浮窗").click()
self.device.click(584, 1382)
time.sleep(3)
self.device.click(319, 707)
self.device.click(393, 1776)
#self.device(text="输入QQ密码").set_text("1111")
if app_pkgname == "微信":
self.device(text="微信").click()
self.device(resourceId="com.tencent.mm:id/g5z").click()
self.device(resourceId="com.tencent.mm:id/knx", text="用密码登录").click()
self.device(resourceId="com.android.systemui:id/recent_apps").click()
self.device.xpath('//*[@content-desc="微信"]/android.view.ViewGroup[1]/android.widget.ImageButton[1]').click()
self.device(resourceId="com.oppo.launcher:id/text", text="浮窗").click()
self.device.click(542, 1493)
time.sleep(2)
self.device.click(393, 1776)
if app_pkgname == "腾讯视频":
self.device(text="腾讯视频").click()
time.sleep(12)
self.device.click(963, 2182)
try:
self.device.xpath('//*[@resource-id="android:id/content"]/android.widget.FrameLayout[1]/android.widget.FrameLayout[1]/android.widget.FrameLayout[1]/android.widget.ImageView[1]').click()
except Exception:
pass
#self.device.click(276,295)
#self.device.xpath('//*[@resource-id="android:id/content"]/android.widget.FrameLayout[2]/android.widget.FrameLayout[1]/android.widget.FrameLayout[1]/android.view.ViewGroup[1]/android.widget.FrameLayout[1]/android.view.ViewGroup[1]/android.view.ViewGroup[4]').click()
self.device.xpath('//*[@resource-id="android:id/content"]/android.widget.FrameLayout[2]/android.widget.FrameLayout[1]/android.widget.FrameLayout[1]/android.view.ViewGroup[1]/android.widget.FrameLayout[1]/android.view.ViewGroup[1]/android.view.ViewGroup[2]').click()
self.device.xpath('//android.widget.CheckBox').click()
#开启小窗
self.device(resourceId="com.android.systemui:id/recent_apps").click()
self.device.xpath('//*[@content-desc="腾讯视频"]/android.view.ViewGroup[1]/android.widget.ImageButton[1]').click()
self.device.xpath('//*[@resource-id="com.oppo.launcher:id/drag_layer"]/android.widget.LinearLayout[2]').click()
self.device.click(450, 1515)
self.device.click(584, 1382)
time.sleep(3)
self.device.click(319, 707)
self.device.click(393, 1776)
if app_pkgname == "淘宝":
self.device(text="淘宝").click()
self.device.xpath('//*[@content-desc="我的淘宝"]/android.widget.ImageView[1]').click()
self.device.click(111, 2099)
self.device.click(612, 1023)
self.device.click(606, 839)
time.sleep(3)
# 进入小窗
self.device(resourceId="com.android.systemui:id/recent_apps").click()
self.device.xpath('//*[@content-desc="淘宝"]/android.view.ViewGroup[1]/android.widget.ImageButton[1]').click()
self.device(resourceId="com.oppo.launcher:id/text", text="浮窗").click()
self.device.click(644, 1502)
self.device.click(134, 1865)
if app_pkgname == "创高体育":
self.device(text="创高体育").click()
time.sleep(3)
#进入小窗
self.device(resourceId="com.android.systemui:id/recent_apps").click()
time.sleep(2)
self.device.xpath('//*[@content-desc="创高体育"]/android.view.ViewGroup[1]/android.widget.ImageButton[1]').click()
self.device(resourceId="com.oppo.launcher:id/text", text="浮窗").click()
self.device(resourceId="net.crigh.cgsport:id/btn_login").click()
self.device.click(535, 1736)
self.device.click(579, 1674)
if app_pkgname == "YouTube":
self.device(text="YouTube").click()
self.device(resourceId="com.google.android.youtube:id/image", description="帐号").click()
self.device(resourceId="com.google.android.youtube:id/button").click()
self.device(resourceId="com.google.android.youtube:id/add_account").click()
time.sleep(5)
self.device.click(381, 789)
#进入小窗---失败
if app_pkgname == "TikTok":
self.device(text="TikTok").click()
self.device.xpath('//*[@resource-id="com.zhiliaoapp.musically:id/egn"]/android.widget.ImageView[1]').click()
self.device(resourceId="com.zhiliaoapp.musically:id/agd").click()
#self.device.click(814, 2189)
#self.device.xpath('//*[@resource-id="com.zhiliaoapp.musically:id/anz"]/android.view.ViewGroup[1]').click()
#进入小窗
self.device(resourceId="com.android.systemui:id/recent_apps").click()
self.device.xpath('//*[@content-desc="TikTok"]/android.view.ViewGroup[1]/android.widget.ImageButton[1]').click()
self.device(resourceId="com.oppo.launcher:id/text", text="浮窗").click()
self.device.click(727, 2097)
self.device.click(574, 1532)
time.sleep(2)
self.device.click(283, 1670)
if app_pkgname == "Twitter":
self.device(text="Twitter").click()
time.sleep(3)
self.device.click(408, 2165)
time.sleep(2)
#进入小窗
self.device(resourceId="com.android.systemui:id/recent_apps").click()
self.device.xpath('//*[@content-desc="Twitter"]/android.view.ViewGroup[1]/android.widget.ImageButton[1]').click()
self.device(resourceId="com.oppo.launcher:id/text", text="浮窗").click()
#输入信息
self.device.click(339, 1463)
self.device.click(332, 1892)
if app_pkgname == "Teams":
self.device(text="Teams").click()
time.sleep(5)
#进入小窗
self.device(resourceId="com.android.systemui:id/recent_apps").click()
self.device.xpath('//*[@content-desc="Teams"]/android.view.ViewGroup[1]/android.widget.ImageButton[1]').click()
self.device(resourceId="com.oppo.launcher:id/text", text="浮窗").click()
self.device.click(456, 1644)
time.sleep(2)
self.device.click(72, 1673)
self.device(resourceId="com.microsoft.teams:id/sign_in_button").click()
if app_pkgname == "Netflix":
self.device(text="Netflix").click()
time.sleep(3)
# 进入小窗
self.device(resourceId="com.android.systemui:id/recent_apps").click()
self.device.xpath('//*[@content-desc="Netflix"]/android.view.ViewGroup[1]/android.widget.ImageButton[1]').click()
self.device(resourceId="com.oppo.launcher:id/text", text="浮窗").click()
self.device.click(782, 1087)
self.device.click(669, 752)
self.device.click(86, 1605)
self.device.click(464, 778)
self.device.click(86, 1605)
if app_pkgname == "Zoom":
self.device(text="Zoom").click()
time.sleep(3)
# 进入小窗
self.device(resourceId="com.android.systemui:id/recent_apps").click()
self.device.xpath('//*[@content-desc="Zoom"]/android.view.ViewGroup[1]/android.widget.ImageButton[1]').click()
self.device(resourceId="com.oppo.launcher:id/text", text="浮窗").click()
self.device.click(604, 2021)
self.device.click(592, 1349)
self.device.click(89, 1614)
def test_process(self,device_name = "1a4587ef",app_test_name="QQ",app_name="com.tencent.wemeet.app"):
self.connect(device_name)
#打开腾讯会议录屏
#self.open_app(app_name)
#self.start_app_screenRecord()
app_name_list = ["飞书", "QQ", "微信", "腾讯视频", "淘宝", "创高体育", "YouTube", "TikTok","Twitter",
"Teams", "Netflix", "Zoom"]
#打开手机系统录屏
self.start_syst_screenRecord()
#打开另一个待测APP
app_test_name = app_name_list[11]
self.start_another(app_test_name)
#结束手机录屏
time.sleep(5)
self.device.click(126, 1622)
self.device.click(137, 1625)
#获取包名
#adb shell pm list package 无需要root
if __name__ == '__main__':
test = Screen_record()
test.test_process()

View File

@ -0,0 +1,84 @@
#打开视频软件并进入小窗模式
def start_video(self, v_app):
self.device(text=v_app).click()
time.sleep(7)
if v_app == "爱奇艺":
self.device.xpath('//androidx.recyclerview.widget.RecyclerView/android.widget.RelativeLayout[1]/android.widget.RelativeLayout[1]/android.widget.ImageView[1]').click()
time.sleep(120) #广告
#开启画中画模式
self.device(resourceId="com.android.systemui:id/center_group").click()
if v_app == "人人视频":
#该APP无画中画模式
self.device.xpath('//*[@resource-id="com.example.pptv:id/rv_content"]/android.view.ViewGroup[1]/androidx.recyclerview.widget.RecyclerView[1]/android.view.ViewGroup[1]/android.widget.ImageView[1]').click()
time.sleep(20) #广告
if v_app == "Plex":
self.device.xpath('//*[@resource-id="com.plexapp.android:id/content_container"]/android.view.ViewGroup[1]/android.view.View[1]/android.view.View[1]/android.view.View[2]/android.view.View[1]').click()
self.device(resourceId="com.plexapp.android:id/play").click()
time.sleep(20)
#开启画中画模式(只有Plex在画中画时会顺利开启。)
self.device.click(200,200)
self.device(resourceId="com.android.systemui:id/center_group").click()
if v_app == "咪咕视频":
self.device.xpath('//*[@resource-id="com.cmcc.cmvideo:id/fragment_container"]/android.widget.FrameLayout[1]/androidx.recyclerview.widget.RecyclerView[1]/android.view.ViewGroup[4]/android.widget.FrameLayout[1]').click()
self.device.click(200, 200)
time.sleep(61)
#小窗的设计:需要点击小窗按钮。
self.device.click(200, 200)
self.device.xpath('//*[@resource-id="com.cmcc.cmvideo:id/playViewContainer"]/android.view.ViewGroup[1]/android.view.ViewGroup[1]/android.view.ViewGroup[3]/android.view.ViewGroup[1]/android.view.ViewGroup[2]/android.view.ViewGroup[1]/android.view.ViewGroup[2]').click()
self.device(resourceId="com.android.systemui:id/center_group").click()
if v_app == "腾讯视频":
self.device.xpath('//androidx.viewpager.widget.ViewPager/android.widget.RelativeLayout[1]/android.view.ViewGroup[1]/android.widget.FrameLayout[1]/android.view.ViewGroup[1]/androidx.recyclerview.widget.RecyclerView[1]/android.widget.RelativeLayout[1]/android.widget.RelativeLayout[1]').click()
time.sleep(80) #广告时长
self.device.click(200, 200)
self.device.xpath('//android.widget.FrameLayout[1]/android.widget.LinearLayout[1]/android.widget.FrameLayout[1]/android.widget.FrameLayout[2]/android.view.ViewGroup[1]/android.view.ViewGroup[1]/android.widget.FrameLayout[1]/android.widget.FrameLayout[1]/android.widget.FrameLayout[1]/android.widget.FrameLayout[1]/android.view.ViewGroup[1]/android.view.ViewGroup[4]/android.widget.ImageView[1]').click()
if v_app == "优酷视频":
self.device(resourceId="com.youku.phone:id/light_widget_gif_view_id").click()
time.sleep(90)
self.device.click(200, 200)
self.device(resourceId="com.youku.phone:id/lottie_small_pip_btn").click()
self.device(resourceId="com.android.systemui:id/center_group").click()
if v_app == "哔哩哔哩":
self.device(description="热门,6之3,标签").click()
self.device.xpath('//*[@resource-id="tv.danmaku.bili:id/recycler_view"]/android.widget.LinearLayout[1]/android.view.ViewGroup[1]/android.widget.ImageView[1]').click()
time.sleep(2)
self.device.click(200,200)
self.device(resourceId="tv.danmaku.bili:id/float_window").click()
self.device(resourceId="com.android.systemui:id/center_group").click()
if v_app == "搜狐视频":
self.device(resourceId="com.sohu.sohuvideo:id/tv_normal", text="首页").click()
self.device.xpath('//*[@resource-id="com.sohu.sohuvideo:id/rl_refresh_layout"]/androidx.recyclerview.widget.RecyclerView[1]/android.widget.LinearLayout[4]/android.widget.FrameLayout[1]/android.widget.ImageView[1]').click()
#广告
time.sleep(50)
self.device(resourceId="com.android.systemui:id/center_group").click()
if v_app == "乐视视频":
self.device.xpath('//*[@resource-id="com.letv.android.client:id/pull_list"]/android.widget.LinearLayout[3]/android.widget.RelativeLayout[1]/android.widget.FrameLayout[1]').click()
time.sleep(70)
self.device.click(200,200)
self.device.click(1005, 405)
self.device(resourceId="com.android.systemui:id/center_group").click()
if v_app == "芒果TV":
self.device.xpath('//*[@resource-id="com.hunantv.imgo.activity:id/viewPager"]/android.view.ViewGroup[1]').click()
#Uiautomator2 弹窗处理
self.device.watcher.when('com.hunantv.imgo.activity:id/btnClose').click()
self.device.watcher.when('知道了').click()
# 广告
time.sleep(65)
self.device.click(200, 200)
self.device(resourceId="com.hunantv.imgo.activity:id/tv_float_window_play").click()
def test_process_VideoCOnflict(self, device_name = "1a4587ef"):
self.connect(device_name)
v_name_list = ["爱奇艺", "人人视频", "Plex", "咪咕视频", "腾讯视频", "优酷视频", "哔哩哔哩", "搜狐视频", "乐视视频", "芒果TV"]
#打开视频软件
# for v_name in v_name_list:
self.start_video(v_name_list[9])
#获取包名
#adb shell pm list package 无需要root
if __name__ == '__main__':
test = Screen_record()
#test.test_process_RecordConflict()
test.test_process_VideoCOnflict()

16
Exception/Code/audio.py Normal file
View File

@ -0,0 +1,16 @@
'''
#完成语音条录制的自动化脚本
author:wpj
date:2022.2
'''
import touch as touch
import uiautomator2 as u2
import time
#连接手机(adb序列号方式)或者直接用wifi也可以
device=u2.connect('6HJDU19B04004216')
#切换到录制语音功能
device(description="切换到按住说话").click()
#通过长按按钮完成语音录入
device(description="按住说话").long_click(duration=5,timeout=10)

View File

@ -0,0 +1,19 @@
'''
#完成穿透问题的自动化脚本
author:wpj
date:2022.2
'''
import touch as touch
import uiautomator2 as u2
#连接手机(adb序列号方式)或者直接用wifi也可以
device=u2.connect('6HJDU19B04004216')
print(device.device_info)
#主屏打开APP1
device(text='QQ').click()
# 用侧边栏形式打开APP2
device.touch.down(1035,585).move(500,585).move(501,585).move(501,586).move(502,586).move(502,587).move(503,587).move(503,588).up(503,588)
#打开被测试的APP
device(text='微信').up(clickable='true').click()
#完成持续点击观察是否穿透
device(clickable='false').click_gone(interval=1.0)

View File

@ -0,0 +1,40 @@
'''
#完成加入会议的自动化脚本(以飞书会议、腾讯会议为例)
author:wpj
date:2022.2
'''
import touch as touch
import uiautomator2 as u2
#连接手机(adb序列号方式)或者直接用wifi也可以
from uiautomator2 import UiObject
device=u2.connect('6HJDU19B04004216')
'''
#飞书
device(text='飞书').click()
#等待元素出现(开屏缓慢)
device(textContains='更多').wait(timeout=10.0)
#由于飞书的”更多选项上没有给text所以只能通过xpath绝对定位的方式“
device.xpath('//*[@resource-id="com.ss.android.lark:id/main_tab"]/android.view.ViewGroup[6]').click()
device(text='视频会议').click()
device(text='加入会议').click()
#根据对方提供的会议号加入会议
device.send_keys('647676676')
device(textContains='加入').click()
#打开摄像头的麦克风,
device(resourceId="com.ss.android.lark:id/audio_container").click()
device(resourceId="com.ss.android.lark:id/camera_container").click()
'''
#腾讯会议
device(text='腾讯会议').click()
#等待元素出现(开屏缓慢)
device(textContains='加入会议').wait(timeout=10.0)
device(text='加入会议').click()
#根据对方提供的会议号加入会议
device.send_keys('799649026')
device(resourceId="com.tencent.wemeet.app:id/atp").click()
#打开摄像头的麦克风,
device.xpath('//*[@resource-id="com.tencent.wemeet.app:id/a58"]/android.widget.FrameLayout[1]').click()
device(resourceId="com.tencent.wemeet.app:id/b4_").click()

View File

@ -0,0 +1,31 @@
'''
#完成开启会议的自动化脚本(以飞书会议、腾讯会议为例)
author:wpj
date:2022.2
'''
import touch as touch
import uiautomator2 as u2
#连接手机(adb序列号方式)或者直接用wifi也可以
device=u2.connect('6HJDU19B04004216')
#腾讯会议
device(text='腾讯会议').click()
#等待元素出现(开屏缓慢)
device(textContains='快速会议').wait(timeout=10.0)
device(text='快速会议').click()
device(text='进入会议').click()
device.xpath('//*[@resource-id="com.tencent.wemeet.app:id/a58"]/android.widget.FrameLayout[1]').click()
'''
#飞书
device(text='飞书').click()
#等待元素出现(开屏缓慢)
device(textContains='更多').wait(timeout=10.0)
#由于飞书的”更多选项上没有给text所以只能通过xpath绝对定位的方式“
device.xpath('//*[@resource-id="com.ss.android.lark:id/main_tab"]/android.view.ViewGroup[6]').click()
device(text='视频会议').click()
device(textContains='新会议').click()
device(textContains='开始').click()
#打开摄像头的麦克风,
device(resourceId="com.ss.android.lark:id/audio_container").click()
device(resourceId="com.ss.android.lark:id/camera_container").click()
'''

31
Exception/Code/demo.py Normal file
View File

@ -0,0 +1,31 @@
'''
#完成点击弹出键盘的自动化脚本(以交通银行、建设银行为例)
author:wpj
date:2022.2
'''
import uiautomator2 as u2
#连接手机(adb序列号方式)或者直接用wifi也可以
device=u2.connect('6HJDU19B04004216')
#打开被测试的APP测试密码输入等对安全性有要求的软件以中国建设银行和交通银行为例
#单击直到元素消失超时时间10点击间隔1
#device(text='中国建设银行').click_gone(maxretry=10,interval=1.0)
device(text='交通银行').click_gone(maxretry=10,interval=1.0)
#等待元素出现(开屏广告)
device(textContains='转账').wait(timeout=10.0)
#点击进入转账汇款界面(需要密码输入)
if device(textContains='转账').exists:
device(textContains='转账').click()
device(textContains='输入').wait(timeout=3.0)
#打开输入密码的信息,有“请输入登录密码”的提示语
if device(textContains='输入').exists:
device(textContains='输入').click()
#如果没有“请输入登录密码”的提示语则用两种class的情况分别尝试点击弹出键盘
else:
if device(className="android.widget.ScrollView").exists:
device(className="android.widget.ScrollView").click()
else:
if device(className="android.widget.EditText").exists:
device(className="android.widget.EditText").click()

42
Exception/Code/demo2.py Normal file
View File

@ -0,0 +1,42 @@
'''
#完成同时打开两个APP并弹出键盘的自动化脚本一个主屏打开一个侧边栏打开
author:wpj
date:2022.2
'''
import uiautomator2 as u2
import time
#连接手机(adb序列号方式)或者直接用wifi也可以
device=u2.connect('6HJDU19B04004216')
#打开被测试的APP测试密码输入等对安全性有要求的软件以中国建设银行和交通银行为例
#单击直到元素消失超时时间10点击间隔1
#device(text='中国建设银行').click_gone(maxretry=10,interval=1.0)
device(text='交通银行').click_gone(maxretry=10,interval=1.0)
#等待元素出现(开屏广告)
device(textContains='转账').wait(timeout=10.0)
#点击进入转账汇款界面(需要密码输入)
if device(textContains='转账').exists:
device(textContains='转账').click()
device(textContains='登录密码').wait(timeout=3.0)
#打开输入密码的信息,有“请输入登录密码”的提示语
if device(textContains='登录密码').exists:
device(textContains='登录密码').click()
#如果没有“请输入登录密码”的提示语则用两种class的情况分别尝试点击弹出键盘
else:
if device(className="android.widget.ScrollView").exists:
device(className="android.widget.ScrollView").click()
else:
if device(className="android.widget.EditText").exists:
device(className="android.widget.EditText").click()
#等待十秒这中间是通过侧边栏打开第二个APP
time.sleep (5)
#点击进入某聊天程序
device.click(0.5,0.5)
if device(className="android.widget.ScrollView").exists:
device(className="android.widget.ScrollView").click()
else:
if device(className="android.widget.EditText").exists:
device(className="android.widget.EditText").click()

14
Exception/Code/open.py Normal file
View File

@ -0,0 +1,14 @@
'''
#完成侧边栏以FF模式打开某APP的自动化脚本
author:wpj
date:2022.2
'''
import touch as touch
import uiautomator2 as u2
#连接手机(adb序列号方式)或者直接用wifi也可以
device=u2.connect('6HJDU19B04004216')
# 用侧边栏形式打开APP
device.touch.down(1035,585).move(500,585).move(501,585).move(501,586).move(502,586).move(502,587).move(503,587).move(503,588).up(503,588)
#打开被测试的APP
device(text='交通银行').up(clickable='true').click()

27
Exception/Code/pip.py Normal file
View File

@ -0,0 +1,27 @@
'''
#完成进入PIP模式的自动化脚本两种方法分别以飞书和腾讯会议为例
author:wpj
date:2022.2
'''
import touch as touch
import uiautomator2 as u2
import time
#连接手机(adb序列号方式)或者直接用wifi也可以
device=u2.connect('6HJDU19B04004216')
'''
# 第一种PIP方式直接上滑退出
x,y = device.window_size()
x1 = x / 2
y1 = y * 0.99
y2 = y * 0.5
device.swipe(x1,y1,x1,y2)
'''
#第二种PIP方式点击专门的小窗模式功能后再退出到主屏
device(resourceId="com.tencent.wemeet.app:id/bw6").click()
#实操中这里常常慢一些,所以等待一下
time.sleep (2)
x,y = device.window_size()
x1 = x / 2
y1 = y * 0.99
y2 = y * 0.5
device.swipe(x1,y1,x1,y2)

19
Exception/Code/record.py Normal file
View File

@ -0,0 +1,19 @@
'''
#完成通过系统截屏的自动化脚本
author:wpj
date:2022.2
'''
import touch as touch
import uiautomator2 as u2
#连接手机(adb序列号方式)或者直接用wifi也可以
device=u2.connect('6HJDU19B04004216')
#下拉打开手机顶部菜单工具栏
device.swipe(800,0,800,500)
#展开快捷菜单栏
device(description="展开快捷设置").click()
#点击截屏按键
device(description='截屏').click()
device(text='截屏').down(clickable='true').click()

17
Exception/Code/video_1.py Normal file
View File

@ -0,0 +1,17 @@
'''
#完成拨出视频电话的自动化脚本
author:wpj
date:2022.2
'''
import touch as touch
import uiautomator2 as u2
import time
#连接手机(adb序列号方式)或者直接用wifi也可以
device=u2.connect('6HJDU19B04004216')
#先点击更多功能按钮
device(description="更多功能按钮,已折叠").click()
#在更多功能的菜单中打开视频通话功能
device(text='视频通话').click()
#开始
device(text='视频通话').click()

13
Exception/Code/video_2.py Normal file
View File

@ -0,0 +1,13 @@
'''
#完成接通视频通话的自动化脚本(以飞书会议、腾讯会议为例)
author:wpj
date:2022.2
'''
import touch as touch
import uiautomator2 as u2
import time
#连接手机(adb序列号方式)或者直接用wifi也可以
device=u2.connect('6HJDU19B04004216')
#直接点击接听即可
device(description="接听").click()

View File

@ -0,0 +1,15 @@
*.iml
.gradle
/local.properties
/.idea/caches
/.idea/libraries
/.idea/modules.xml
/.idea/workspace.xml
/.idea/navEditor.xml
/.idea/assetWizardSettings.xml
.DS_Store
/build
/captures
.externalNativeBuild
.cxx
local.properties

View File

@ -0,0 +1,3 @@
# Default ignored files
/shelf/
/workspace.xml

View File

@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="CompilerConfiguration">
<bytecodeTargetLevel target="11" />
</component>
</project>

View File

@ -0,0 +1,19 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="GradleMigrationSettings" migrationVersion="1" />
<component name="GradleSettings">
<option name="linkedExternalProjectsSettings">
<GradleProjectSettings>
<option name="testRunner" value="GRADLE" />
<option name="distributionType" value="DEFAULT_WRAPPED" />
<option name="externalProjectPath" value="$PROJECT_DIR$" />
<option name="modules">
<set>
<option value="$PROJECT_DIR$" />
<option value="$PROJECT_DIR$/app" />
</set>
</option>
</GradleProjectSettings>
</option>
</component>
</project>

View File

@ -0,0 +1,10 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ExternalStorageConfigurationManager" enabled="true" />
<component name="ProjectRootManager" version="2" languageLevel="JDK_11" default="true" project-jdk-name="Android Studio default JDK" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/build/classes" />
</component>
<component name="ProjectType">
<option name="id" value="Android" />
</component>
</project>

View File

@ -0,0 +1 @@
/build

View File

@ -0,0 +1,39 @@
plugins {
id 'com.android.application'
}
android {
namespace 'com.example.adobfuscation'
compileSdk 33
defaultConfig {
applicationId "com.example.adobfuscation"
minSdk 24
targetSdk 33
versionCode 1
versionName "1.0"
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
}
dependencies {
implementation 'androidx.appcompat:appcompat:1.4.1'
implementation 'com.google.android.material:material:1.5.0'
implementation 'androidx.constraintlayout:constraintlayout:2.1.3'
testImplementation 'junit:junit:4.13.2'
androidTestImplementation 'androidx.test.ext:junit:1.1.3'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.4.0'
}

View File

@ -0,0 +1,21 @@
# Add project specific ProGuard rules here.
# You can control the set of applied configuration files using the
# proguardFiles setting in build.gradle.
#
# For more details, see
# http://developer.android.com/guide/developing/tools/proguard.html
# If your project uses WebView with JS, uncomment the following
# and specify the fully qualified class name to the JavaScript interface
# class:
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
# public *;
#}
# Uncomment this to preserve the line number information for
# debugging stack traces.
#-keepattributes SourceFile,LineNumberTable
# If you keep the line number information, uncomment this to
# hide the original source file name.
#-renamesourcefileattribute SourceFile

View File

@ -0,0 +1,26 @@
package com.example.adobfuscation;
import android.content.Context;
import androidx.test.platform.app.InstrumentationRegistry;
import androidx.test.ext.junit.runners.AndroidJUnit4;
import org.junit.Test;
import org.junit.runner.RunWith;
import static org.junit.Assert.*;
/**
* Instrumented test, which will execute on an Android device.
*
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
*/
@RunWith(AndroidJUnit4.class)
public class ExampleInstrumentedTest {
@Test
public void useAppContext() {
// Context of the app under test.
Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext();
assertEquals("com.example.adobfuscation", appContext.getPackageName());
}
}

View File

@ -0,0 +1,30 @@
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools">
<uses-permission
android:name="android.permission.PACKAGE_USAGE_STATS"
tools:ignore="ProtectedPermissions" />
<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />
<application
android:allowBackup="true"
android:dataExtractionRules="@xml/data_extraction_rules"
android:fullBackupContent="@xml/backup_rules"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/Theme.AdObfuscation"
tools:targetApi="31">
<activity
android:name=".MainActivity"
android:exported="true">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>

View File

@ -0,0 +1,184 @@
package com.example.adobfuscation;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import android.Manifest;
import android.app.Activity;
import android.app.AppOpsManager;
import android.app.usage.UsageEvents;
import android.app.usage.UsageStatsManager;
import android.content.Context;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.graphics.PixelFormat;
import android.net.Uri;
import android.os.Build;
import android.os.Bundle;
import android.os.Handler;
import android.provider.Settings;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.WindowManager;
import android.widget.Button;
import android.widget.Toast;
import java.util.Calendar;
public class MainActivity extends AppCompatActivity {
private static final String TAG = "AdObfuscation";
private Handler mHandler = null; //监听后的处理
private static final int POSTDELAYED_COUNTS = 5000; //监听时间间隔
//悬浮窗相关的变量
private WindowManager wm;
private WindowManager.LayoutParams layoutParams;
private View displayView;
Activity thi = this;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
requestOverlayPermission();//申请悬浮窗权限
if(canUsageStats(getApplicationContext())) {
mHandler = new Handler();
mHandler.post(new Runnable() {
@Override
public void run() {
//分析进程
String fore = getForegroundPackageName(getApplicationContext());
if("com.sina.weibo".equals(fore)){ //监听微博打开
showFloatingView();
}
mHandler.postDelayed(this, POSTDELAYED_COUNTS);
}
});
}else{
//申请权限
startActivityForResult(new Intent(Settings.ACTION_USAGE_ACCESS_SETTINGS),809);
}
}
//能否使用UsageStat权限
public static boolean canUsageStats(Context context) {
AppOpsManager appOps = (AppOpsManager) context.getSystemService(Context.APP_OPS_SERVICE);
int mode = 0;
if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.Q) {
mode = appOps.unsafeCheckOpNoThrow(AppOpsManager.OPSTR_GET_USAGE_STATS, android.os.Process.myUid(), context.getPackageName());
} else {
mode = appOps.checkOpNoThrow(AppOpsManager.OPSTR_GET_USAGE_STATS, android.os.Process.myUid(), context.getPackageName());
}
if (mode == AppOpsManager.MODE_DEFAULT) {
return (context.checkCallingOrSelfPermission(Manifest.permission.PACKAGE_USAGE_STATS) == PackageManager.PERMISSION_GRANTED);
} else {
return (mode == AppOpsManager.MODE_ALLOWED);
}
}
//申请SYSTEM_ALRET_WINDOW权限
public void requestOverlayPermission() {
if (!Settings.canDrawOverlays(this)) {
Intent intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION, Uri.parse("package:" + getPackageName()));
startActivityForResult(intent, 0);
}
}
//制作悬浮窗广告
private void showFloatingView() {
if (Settings.canDrawOverlays(this)) {
// 获取WindowManager服务
wm = (WindowManager) getSystemService(WINDOW_SERVICE);
// 设置LayoutParam
layoutParams = new WindowManager.LayoutParams();
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
layoutParams.type = WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY;
} else {
layoutParams.type = WindowManager.LayoutParams.TYPE_PHONE;
}
layoutParams.format = PixelFormat.RGBA_8888;
layoutParams.width = 800;
layoutParams.height = 1300;
layoutParams.x = 10;
layoutParams.y = 5;
//加入注释面板
LayoutInflater layoutInflater = LayoutInflater.from(this);
displayView = layoutInflater.inflate(R.layout.advertisement_view, null);
//给注释面板加上按钮触发器
displayView.setOnTouchListener(new FloatingOnTouchListener());
// 将注释面板添加到WindowManager
wm.addView(displayView, layoutParams);
}
}
//监听前台运行的软件
public static String getForegroundPackageName(Context context) {
//Get the app record in the last month
Calendar calendar = Calendar.getInstance();
final long end = calendar.getTimeInMillis();
calendar.add(Calendar.MONTH, -1);
final long start = calendar.getTimeInMillis();
UsageStatsManager usageStatsManager = (UsageStatsManager) context.getSystemService(Context.USAGE_STATS_SERVICE);
UsageEvents usageEvents = usageStatsManager.queryEvents(start, end);
UsageEvents.Event event = new UsageEvents.Event();
String packageName = null;
while (usageEvents.hasNextEvent()) {
usageEvents.getNextEvent(event);
if (event.getEventType() == UsageEvents.Event.ACTIVITY_RESUMED) {
packageName = event.getPackageName();
}
}
return packageName;
}
private class FloatingOnTouchListener implements View.OnTouchListener {
@Override
public boolean onTouch(View view, MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
int x = (int) event.getRawX();
int y = (int) event.getRawY();
if(x >= 800 && x <= 900 && y >= 680 && y <= 780){
//关闭视图
wm.removeView(displayView);
}else if(x >= 200 && x <= 920 && y >= 500 && y <= 1900){
// finish(); //主栈开启的关键
wm.removeView(displayView); //关闭视图
//打开浏览器跳转至网址
String xunLei_Website = "https://pan.xunlei.com/"; //迅雷云盘网址
jumpUriToBrowser(thi, xunLei_Website);
}
break;
default:
break;
}
return false;
}
}
//通过URL跳到浏览器
public static void jumpUriToBrowser(Context context, String url) {
Intent intent = new Intent();
// 设置意图动作为打开浏览器
intent.setAction(Intent.ACTION_VIEW);
// 声明一个Uri
Uri uri = Uri.parse(url);
intent.setData(uri);
intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
context.startActivity(intent);
}
}

View File

@ -0,0 +1,30 @@
<vector xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:aapt="http://schemas.android.com/aapt"
android:width="108dp"
android:height="108dp"
android:viewportWidth="108"
android:viewportHeight="108">
<path android:pathData="M31,63.928c0,0 6.4,-11 12.1,-13.1c7.2,-2.6 26,-1.4 26,-1.4l38.1,38.1L107,108.928l-32,-1L31,63.928z">
<aapt:attr name="android:fillColor">
<gradient
android:endX="85.84757"
android:endY="92.4963"
android:startX="42.9492"
android:startY="49.59793"
android:type="linear">
<item
android:color="#44000000"
android:offset="0.0" />
<item
android:color="#00000000"
android:offset="1.0" />
</gradient>
</aapt:attr>
</path>
<path
android:fillColor="#FFFFFF"
android:fillType="nonZero"
android:pathData="M65.3,45.828l3.8,-6.6c0.2,-0.4 0.1,-0.9 -0.3,-1.1c-0.4,-0.2 -0.9,-0.1 -1.1,0.3l-3.9,6.7c-6.3,-2.8 -13.4,-2.8 -19.7,0l-3.9,-6.7c-0.2,-0.4 -0.7,-0.5 -1.1,-0.3C38.8,38.328 38.7,38.828 38.9,39.228l3.8,6.6C36.2,49.428 31.7,56.028 31,63.928h46C76.3,56.028 71.8,49.428 65.3,45.828zM43.4,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2c-0.3,-0.7 -0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C45.3,56.528 44.5,57.328 43.4,57.328L43.4,57.328zM64.6,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2s-0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C66.5,56.528 65.6,57.328 64.6,57.328L64.6,57.328z"
android:strokeWidth="1"
android:strokeColor="#00000000" />
</vector>

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.2 MiB

View File

@ -0,0 +1,170 @@
<?xml version="1.0" encoding="utf-8"?>
<vector xmlns:android="http://schemas.android.com/apk/res/android"
android:width="108dp"
android:height="108dp"
android:viewportWidth="108"
android:viewportHeight="108">
<path
android:fillColor="#3DDC84"
android:pathData="M0,0h108v108h-108z" />
<path
android:fillColor="#00000000"
android:pathData="M9,0L9,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,0L19,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M29,0L29,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M39,0L39,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M49,0L49,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M59,0L59,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M69,0L69,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M79,0L79,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M89,0L89,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M99,0L99,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,9L108,9"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,19L108,19"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,29L108,29"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,39L108,39"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,49L108,49"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,59L108,59"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,69L108,69"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,79L108,79"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,89L108,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,99L108,99"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,29L89,29"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,39L89,39"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,49L89,49"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,59L89,59"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,69L89,69"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,79L89,79"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M29,19L29,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M39,19L39,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M49,19L49,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M59,19L59,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M69,19L69,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M79,19L79,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
</vector>

View File

@ -0,0 +1,26 @@
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/main_text"
android:textSize="50sp"
android:textColor="@color/black"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</LinearLayout>
</androidx.constraintlayout.widget.ConstraintLayout>

View File

@ -0,0 +1,27 @@
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".TestActivity">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/main_text"
android:textSize="30sp"
android:textColor="@color/black"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</LinearLayout>
</androidx.constraintlayout.widget.ConstraintLayout>

View File

@ -0,0 +1,17 @@
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:id="@+id/advertisement"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:src="@drawable/advertisement">
</ImageView>
</LinearLayout>
</androidx.constraintlayout.widget.ConstraintLayout>

View File

@ -0,0 +1,5 @@
<?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
<background android:drawable="@drawable/ic_launcher_background" />
<foreground android:drawable="@drawable/ic_launcher_foreground" />
</adaptive-icon>

View File

@ -0,0 +1,5 @@
<?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
<background android:drawable="@drawable/ic_launcher_background" />
<foreground android:drawable="@drawable/ic_launcher_foreground" />
</adaptive-icon>

View File

@ -0,0 +1,6 @@
<?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
<background android:drawable="@drawable/ic_launcher_background" />
<foreground android:drawable="@drawable/ic_launcher_foreground" />
<monochrome android:drawable="@drawable/ic_launcher_foreground" />
</adaptive-icon>

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 982 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.6 KiB

View File

@ -0,0 +1,16 @@
<resources xmlns:tools="http://schemas.android.com/tools">
<!-- Base application theme. -->
<style name="Theme.AdObfuscation" parent="Theme.MaterialComponents.DayNight.DarkActionBar">
<!-- Primary brand color. -->
<item name="colorPrimary">@color/purple_200</item>
<item name="colorPrimaryVariant">@color/purple_700</item>
<item name="colorOnPrimary">@color/black</item>
<!-- Secondary brand color. -->
<item name="colorSecondary">@color/teal_200</item>
<item name="colorSecondaryVariant">@color/teal_200</item>
<item name="colorOnSecondary">@color/black</item>
<!-- Status bar color. -->
<item name="android:statusBarColor">?attr/colorPrimaryVariant</item>
<!-- Customize your theme here. -->
</style>
</resources>

View File

@ -0,0 +1,10 @@
<?xml version="1.0" encoding="utf-8"?>
<resources>
<color name="purple_200">#FFBB86FC</color>
<color name="purple_500">#FF6200EE</color>
<color name="purple_700">#FF3700B3</color>
<color name="teal_200">#FF03DAC5</color>
<color name="teal_700">#FF018786</color>
<color name="black">#FF000000</color>
<color name="white">#FFFFFFFF</color>
</resources>

View File

@ -0,0 +1,6 @@
<resources>
<string name="app_name">AdObfuscation</string>
<string name="main_text">广告混淆</string>
<string name="XunLei_Website">www.pan.xunlei.com</string>
<string name="test">测试</string>
</resources>

View File

@ -0,0 +1,16 @@
<resources xmlns:tools="http://schemas.android.com/tools">
<!-- Base application theme. -->
<style name="Theme.AdObfuscation" parent="Theme.MaterialComponents.DayNight.DarkActionBar">
<!-- Primary brand color. -->
<item name="colorPrimary">@color/purple_500</item>
<item name="colorPrimaryVariant">@color/purple_700</item>
<item name="colorOnPrimary">@color/white</item>
<!-- Secondary brand color. -->
<item name="colorSecondary">@color/teal_200</item>
<item name="colorSecondaryVariant">@color/teal_700</item>
<item name="colorOnSecondary">@color/black</item>
<!-- Status bar color. -->
<item name="android:statusBarColor">?attr/colorPrimaryVariant</item>
<!-- Customize your theme here. -->
</style>
</resources>

View File

@ -0,0 +1,13 @@
<?xml version="1.0" encoding="utf-8"?><!--
Sample backup rules file; uncomment and customize as necessary.
See https://developer.android.com/guide/topics/data/autobackup
for details.
Note: This file is ignored for devices older that API 31
See https://developer.android.com/about/versions/12/backup-restore
-->
<full-backup-content>
<!--
<include domain="sharedpref" path="."/>
<exclude domain="sharedpref" path="device.xml"/>
-->
</full-backup-content>

View File

@ -0,0 +1,19 @@
<?xml version="1.0" encoding="utf-8"?><!--
Sample data extraction rules file; uncomment and customize as necessary.
See https://developer.android.com/about/versions/12/backup-restore#xml-changes
for details.
-->
<data-extraction-rules>
<cloud-backup>
<!-- TODO: Use <include> and <exclude> to control what is backed up.
<include .../>
<exclude .../>
-->
</cloud-backup>
<!--
<device-transfer>
<include .../>
<exclude .../>
</device-transfer>
-->
</data-extraction-rules>

View File

@ -0,0 +1,17 @@
package com.example.adobfuscation;
import org.junit.Test;
import static org.junit.Assert.*;
/**
* Example local unit test, which will execute on the development machine (host).
*
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
*/
public class ExampleUnitTest {
@Test
public void addition_isCorrect() {
assertEquals(4, 2 + 2);
}
}

View File

@ -0,0 +1,5 @@
// Top-level build file where you can add configuration options common to all sub-projects/modules.
plugins {
id 'com.android.application' version '7.4.1' apply false
id 'com.android.library' version '7.4.1' apply false
}

View File

@ -0,0 +1,21 @@
# Project-wide Gradle settings.
# IDE (e.g. Android Studio) users:
# Gradle settings configured through the IDE *will override*
# any settings specified in this file.
# For more details on how to configure your build environment visit
# http://www.gradle.org/docs/current/userguide/build_environment.html
# Specifies the JVM arguments used for the daemon process.
# The setting is particularly useful for tweaking memory settings.
org.gradle.jvmargs=-Xmx2048m -Dfile.encoding=UTF-8
# When configured, Gradle will run in incubating parallel mode.
# This option should only be used with decoupled projects. More details, visit
# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
# org.gradle.parallel=true
# AndroidX package structure to make it clearer which packages are bundled with the
# Android operating system, and which are packaged with your app's APK
# https://developer.android.com/topic/libraries/support-library/androidx-rn
android.useAndroidX=true
# Enables namespacing of each library's R class so that its R class includes only the
# resources declared in the library itself and none from the library's dependencies,
# thereby reducing the size of the R class for that library
android.nonTransitiveRClass=true

View File

@ -0,0 +1,6 @@
#Sun Mar 05 23:20:09 CST 2023
distributionBase=GRADLE_USER_HOME
distributionUrl=https\://services.gradle.org/distributions/gradle-7.5-bin.zip
distributionPath=wrapper/dists
zipStorePath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME

View File

@ -0,0 +1,185 @@
#!/usr/bin/env sh
#
# Copyright 2015 the original author or authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
##############################################################################
##
## Gradle start up script for UN*X
##
##############################################################################
# Attempt to set APP_HOME
# Resolve links: $0 may be a link
PRG="$0"
# Need this for relative symlinks.
while [ -h "$PRG" ] ; do
ls=`ls -ld "$PRG"`
link=`expr "$ls" : '.*-> \(.*\)$'`
if expr "$link" : '/.*' > /dev/null; then
PRG="$link"
else
PRG=`dirname "$PRG"`"/$link"
fi
done
SAVED="`pwd`"
cd "`dirname \"$PRG\"`/" >/dev/null
APP_HOME="`pwd -P`"
cd "$SAVED" >/dev/null
APP_NAME="Gradle"
APP_BASE_NAME=`basename "$0"`
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
# Use the maximum available, or set MAX_FD != -1 to use that value.
MAX_FD="maximum"
warn () {
echo "$*"
}
die () {
echo
echo "$*"
echo
exit 1
}
# OS specific support (must be 'true' or 'false').
cygwin=false
msys=false
darwin=false
nonstop=false
case "`uname`" in
CYGWIN* )
cygwin=true
;;
Darwin* )
darwin=true
;;
MINGW* )
msys=true
;;
NONSTOP* )
nonstop=true
;;
esac
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar
# Determine the Java command to use to start the JVM.
if [ -n "$JAVA_HOME" ] ; then
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then
# IBM's JDK on AIX uses strange locations for the executables
JAVACMD="$JAVA_HOME/jre/sh/java"
else
JAVACMD="$JAVA_HOME/bin/java"
fi
if [ ! -x "$JAVACMD" ] ; then
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME
Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
fi
else
JAVACMD="java"
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
fi
# Increase the maximum file descriptors if we can.
if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then
MAX_FD_LIMIT=`ulimit -H -n`
if [ $? -eq 0 ] ; then
if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then
MAX_FD="$MAX_FD_LIMIT"
fi
ulimit -n $MAX_FD
if [ $? -ne 0 ] ; then
warn "Could not set maximum file descriptor limit: $MAX_FD"
fi
else
warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT"
fi
fi
# For Darwin, add options to specify how the application appears in the dock
if $darwin; then
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\""
fi
# For Cygwin or MSYS, switch paths to Windows format before running java
if [ "$cygwin" = "true" -o "$msys" = "true" ] ; then
APP_HOME=`cygpath --path --mixed "$APP_HOME"`
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"`
JAVACMD=`cygpath --unix "$JAVACMD"`
# We build the pattern for arguments to be converted via cygpath
ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null`
SEP=""
for dir in $ROOTDIRSRAW ; do
ROOTDIRS="$ROOTDIRS$SEP$dir"
SEP="|"
done
OURCYGPATTERN="(^($ROOTDIRS))"
# Add a user-defined pattern to the cygpath arguments
if [ "$GRADLE_CYGPATTERN" != "" ] ; then
OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)"
fi
# Now convert the arguments - kludge to limit ourselves to /bin/sh
i=0
for arg in "$@" ; do
CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -`
CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option
if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition
eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"`
else
eval `echo args$i`="\"$arg\""
fi
i=`expr $i + 1`
done
case $i in
0) set -- ;;
1) set -- "$args0" ;;
2) set -- "$args0" "$args1" ;;
3) set -- "$args0" "$args1" "$args2" ;;
4) set -- "$args0" "$args1" "$args2" "$args3" ;;
5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;;
6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;;
7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;;
8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;;
9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;;
esac
fi
# Escape application args
save () {
for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done
echo " "
}
APP_ARGS=`save "$@"`
# Collect all arguments for the java command, following the shell quoting and substitution rules
eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS"
exec "$JAVACMD" "$@"

View File

@ -0,0 +1,89 @@
@rem
@rem Copyright 2015 the original author or authors.
@rem
@rem Licensed under the Apache License, Version 2.0 (the "License");
@rem you may not use this file except in compliance with the License.
@rem You may obtain a copy of the License at
@rem
@rem https://www.apache.org/licenses/LICENSE-2.0
@rem
@rem Unless required by applicable law or agreed to in writing, software
@rem distributed under the License is distributed on an "AS IS" BASIS,
@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
@rem See the License for the specific language governing permissions and
@rem limitations under the License.
@rem
@if "%DEBUG%" == "" @echo off
@rem ##########################################################################
@rem
@rem Gradle startup script for Windows
@rem
@rem ##########################################################################
@rem Set local scope for the variables with windows NT shell
if "%OS%"=="Windows_NT" setlocal
set DIRNAME=%~dp0
if "%DIRNAME%" == "" set DIRNAME=.
set APP_BASE_NAME=%~n0
set APP_HOME=%DIRNAME%
@rem Resolve any "." and ".." in APP_HOME to make it shorter.
for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m"
@rem Find java.exe
if defined JAVA_HOME goto findJavaFromJavaHome
set JAVA_EXE=java.exe
%JAVA_EXE% -version >NUL 2>&1
if "%ERRORLEVEL%" == "0" goto execute
echo.
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
echo.
echo Please set the JAVA_HOME variable in your environment to match the
echo location of your Java installation.
goto fail
:findJavaFromJavaHome
set JAVA_HOME=%JAVA_HOME:"=%
set JAVA_EXE=%JAVA_HOME%/bin/java.exe
if exist "%JAVA_EXE%" goto execute
echo.
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
echo.
echo Please set the JAVA_HOME variable in your environment to match the
echo location of your Java installation.
goto fail
:execute
@rem Setup the command line
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
@rem Execute Gradle
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %*
:end
@rem End local scope for the variables with windows NT shell
if "%ERRORLEVEL%"=="0" goto mainEnd
:fail
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
rem the _cmd.exe /c_ return code!
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
exit /b 1
:mainEnd
if "%OS%"=="Windows_NT" endlocal
:omega

View File

@ -0,0 +1,16 @@
pluginManagement {
repositories {
google()
mavenCentral()
gradlePluginPortal()
}
}
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
google()
mavenCentral()
}
}
rootProject.name = "AdObfuscation"
include ':app'

View File

@ -0,0 +1,15 @@
*.iml
.gradle
/local.properties
/.idea/caches
/.idea/libraries
/.idea/modules.xml
/.idea/workspace.xml
/.idea/navEditor.xml
/.idea/assetWizardSettings.xml
.DS_Store
/build
/captures
.externalNativeBuild
.cxx
local.properties

View File

@ -0,0 +1,3 @@
# Default ignored files
/shelf/
/workspace.xml

View File

@ -0,0 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="CompilerConfiguration">
<bytecodeTargetLevel target="11" />
</component>
</project>

View File

@ -0,0 +1,19 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="GradleMigrationSettings" migrationVersion="1" />
<component name="GradleSettings">
<option name="linkedExternalProjectsSettings">
<GradleProjectSettings>
<option name="testRunner" value="GRADLE" />
<option name="distributionType" value="DEFAULT_WRAPPED" />
<option name="externalProjectPath" value="$PROJECT_DIR$" />
<option name="modules">
<set>
<option value="$PROJECT_DIR$" />
<option value="$PROJECT_DIR$/app" />
</set>
</option>
</GradleProjectSettings>
</option>
</component>
</project>

View File

@ -0,0 +1,10 @@
<?xml version="1.0" encoding="UTF-8"?>
<project version="4">
<component name="ExternalStorageConfigurationManager" enabled="true" />
<component name="ProjectRootManager" version="2" languageLevel="JDK_11" default="true" project-jdk-name="Android Studio default JDK" project-jdk-type="JavaSDK">
<output url="file://$PROJECT_DIR$/build/classes" />
</component>
<component name="ProjectType">
<option name="id" value="Android" />
</component>
</project>

View File

@ -0,0 +1 @@
/build

View File

@ -0,0 +1,39 @@
plugins {
id 'com.android.application'
}
android {
namespace 'com.example.extractprivilege'
compileSdk 33
defaultConfig {
applicationId "com.example.extractprivilege"
minSdk 24
targetSdk 33
versionCode 1
versionName "1.0"
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
}
dependencies {
implementation 'androidx.appcompat:appcompat:1.4.1'
implementation 'com.google.android.material:material:1.5.0'
implementation 'androidx.constraintlayout:constraintlayout:2.1.3'
testImplementation 'junit:junit:4.13.2'
androidTestImplementation 'androidx.test.ext:junit:1.1.3'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.4.0'
}

View File

@ -0,0 +1,21 @@
# Add project specific ProGuard rules here.
# You can control the set of applied configuration files using the
# proguardFiles setting in build.gradle.
#
# For more details, see
# http://developer.android.com/guide/developing/tools/proguard.html
# If your project uses WebView with JS, uncomment the following
# and specify the fully qualified class name to the JavaScript interface
# class:
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
# public *;
#}
# Uncomment this to preserve the line number information for
# debugging stack traces.
#-keepattributes SourceFile,LineNumberTable
# If you keep the line number information, uncomment this to
# hide the original source file name.
#-renamesourcefileattribute SourceFile

View File

@ -0,0 +1,26 @@
package com.example.extractprivilege;
import android.content.Context;
import androidx.test.platform.app.InstrumentationRegistry;
import androidx.test.ext.junit.runners.AndroidJUnit4;
import org.junit.Test;
import org.junit.runner.RunWith;
import static org.junit.Assert.*;
/**
* Instrumented test, which will execute on an Android device.
*
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
*/
@RunWith(AndroidJUnit4.class)
public class ExampleInstrumentedTest {
@Test
public void useAppContext() {
// Context of the app under test.
Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext();
assertEquals("com.example.extractprivilege", appContext.getPackageName());
}
}

View File

@ -0,0 +1,32 @@
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools">
<uses-permission android:name="android.permission.PACKAGE_USAGE_STATS"
tools:ignore="ProtectedPermissions" />
<uses-permission android:name="android.permission.CAMERA"/>
<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />
<uses-feature android:name="android.hardware.camera.autofocus" android:required="false" />
<application
android:allowBackup="true"
android:dataExtractionRules="@xml/data_extraction_rules"
android:fullBackupContent="@xml/backup_rules"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/Theme.ExtractPrivilege"
tools:targetApi="31">
<activity
android:name=".MainActivity"
android:exported="true"
android:supportsPictureInPicture="true">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>

View File

@ -0,0 +1,190 @@
package com.example.extractprivilege;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import android.Manifest;
import android.app.Activity;
import android.app.AppOpsManager;
import android.app.usage.UsageEvents;
import android.app.usage.UsageStatsManager;
import android.content.Context;
import android.content.Intent;
import android.content.pm.PackageManager;
import android.graphics.PixelFormat;
import android.net.Uri;
import android.os.Build;
import android.os.Bundle;
import android.os.Handler;
import android.provider.Settings;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.WindowManager;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.MediaController;
import android.widget.Toast;
import android.widget.VideoView;
import java.util.Calendar;
public class MainActivity extends AppCompatActivity {
private VideoView video; //视频播放器
private Button test;
private Handler mHandler = null; //监听后的处理
private static final int POSTDELAYED_COUNTS = 5000; //监听时间间隔
//悬浮窗相关的变量
WindowManager wm;
WindowManager.LayoutParams layoutParams;
View displayView;
Activity thi = this;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
requestOverlayPermission();//申请悬浮窗权限
video = findViewById(R.id.video);
test = findViewById(R.id.test_button);
String path = "android.resource://"+getPackageName() +"/"+R.raw.live;//获取视频路径
Uri uri = Uri.parse(path);//将路径转换成uri
video.setVideoURI(uri);//为视频播放器设置视频路径
video.setMediaController(new MediaController(MainActivity.this));//显示控制栏
video.setFocusable(true); //让VideoView获得焦点
video.start(); //开始播放视频
if(canUsageStats(getApplicationContext())) {
mHandler = new Handler();
mHandler.post(new Runnable() {
@Override
public void run() {
//分析进程
String fore = getForegroundPackageName(getApplicationContext());
if("com.android.camera".equals(fore)){ //监听相机
showFloatingView();
}
mHandler.postDelayed(this, POSTDELAYED_COUNTS);
}
});
}else{
//申请权限
startActivityForResult(new Intent(Settings.ACTION_USAGE_ACCESS_SETTINGS),809);
}
//测试按钮
test.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
showFloatingView();
}
});
}
//能否使用UsageStat权限
public static boolean canUsageStats(Context context) {
AppOpsManager appOps = (AppOpsManager) context.getSystemService(Context.APP_OPS_SERVICE);
int mode = 0;
if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.Q) {
mode = appOps.unsafeCheckOpNoThrow(AppOpsManager.OPSTR_GET_USAGE_STATS, android.os.Process.myUid(), context.getPackageName());
} else {
mode = appOps.checkOpNoThrow(AppOpsManager.OPSTR_GET_USAGE_STATS, android.os.Process.myUid(), context.getPackageName());
}
if (mode == AppOpsManager.MODE_DEFAULT) {
return (context.checkCallingOrSelfPermission(Manifest.permission.PACKAGE_USAGE_STATS) == PackageManager.PERMISSION_GRANTED);
} else {
return (mode == AppOpsManager.MODE_ALLOWED);
}
}
//申请SYSTEM_ALRET_WINDOW权限
public void requestOverlayPermission() {
if (!Settings.canDrawOverlays(this)) {
Intent intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION, Uri.parse("package:" + getPackageName()));
startActivityForResult(intent, 0);
}
}
private void showFloatingView() {
if (Settings.canDrawOverlays(this)) {
// 获取WindowManager服务
wm = (WindowManager) getSystemService(WINDOW_SERVICE);
// 设置LayoutParam
layoutParams = new WindowManager.LayoutParams();
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
layoutParams.type = WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY;
} else {
layoutParams.type = WindowManager.LayoutParams.TYPE_PHONE;
}
layoutParams.format = PixelFormat.RGBA_8888;
layoutParams.width = 800;
layoutParams.height = 580;
layoutParams.x = 10;
layoutParams.y = 10;
//加入注释面板
LayoutInflater layoutInflater = LayoutInflater.from(this);
displayView = layoutInflater.inflate(R.layout.permissions_description_panel, null);
//给注释面板加上按钮触发器
displayView.setOnTouchListener(new FloatingOnTouchListener());
// 将注释面板添加到WindowManager
wm.addView(displayView, layoutParams);
}
}
//监听前台运行的软件
public static String getForegroundPackageName(Context context) {
//Get the app record in the last month
Calendar calendar = Calendar.getInstance();
final long end = calendar.getTimeInMillis();
calendar.add(Calendar.MONTH, -1);
final long start = calendar.getTimeInMillis();
UsageStatsManager usageStatsManager = (UsageStatsManager) context.getSystemService(Context.USAGE_STATS_SERVICE);
UsageEvents usageEvents = usageStatsManager.queryEvents(start, end);
UsageEvents.Event event = new UsageEvents.Event();
String packageName = null;
while (usageEvents.hasNextEvent()) {
usageEvents.getNextEvent(event);
if (event.getEventType() == UsageEvents.Event.ACTIVITY_RESUMED) {
packageName = event.getPackageName();
}
}
return packageName;
}
private class FloatingOnTouchListener implements View.OnTouchListener {
@Override
public boolean onTouch(View view, MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
int x = (int) event.getRawX();
int y = (int) event.getRawY();
if(x >= 200 && x <= 500 && y >= 1400 && y <= 1550 ){
//点击取消按钮
wm.removeView(displayView);
}
if(x >= 600 && x <= 900 && y >= 1400 && y <= 1550 ){
//点击确认按钮
wm.removeView(displayView);
ActivityCompat.requestPermissions(thi,
new String[]{Manifest.permission.CAMERA}, 1);
}
break;
default:
break;
}
return false;
}
}
}

View File

@ -0,0 +1,30 @@
<vector xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:aapt="http://schemas.android.com/aapt"
android:width="108dp"
android:height="108dp"
android:viewportWidth="108"
android:viewportHeight="108">
<path android:pathData="M31,63.928c0,0 6.4,-11 12.1,-13.1c7.2,-2.6 26,-1.4 26,-1.4l38.1,38.1L107,108.928l-32,-1L31,63.928z">
<aapt:attr name="android:fillColor">
<gradient
android:endX="85.84757"
android:endY="92.4963"
android:startX="42.9492"
android:startY="49.59793"
android:type="linear">
<item
android:color="#44000000"
android:offset="0.0" />
<item
android:color="#00000000"
android:offset="1.0" />
</gradient>
</aapt:attr>
</path>
<path
android:fillColor="#FFFFFF"
android:fillType="nonZero"
android:pathData="M65.3,45.828l3.8,-6.6c0.2,-0.4 0.1,-0.9 -0.3,-1.1c-0.4,-0.2 -0.9,-0.1 -1.1,0.3l-3.9,6.7c-6.3,-2.8 -13.4,-2.8 -19.7,0l-3.9,-6.7c-0.2,-0.4 -0.7,-0.5 -1.1,-0.3C38.8,38.328 38.7,38.828 38.9,39.228l3.8,6.6C36.2,49.428 31.7,56.028 31,63.928h46C76.3,56.028 71.8,49.428 65.3,45.828zM43.4,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2c-0.3,-0.7 -0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C45.3,56.528 44.5,57.328 43.4,57.328L43.4,57.328zM64.6,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2s-0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C66.5,56.528 65.6,57.328 64.6,57.328L64.6,57.328z"
android:strokeWidth="1"
android:strokeColor="#00000000" />
</vector>

View File

@ -0,0 +1,170 @@
<?xml version="1.0" encoding="utf-8"?>
<vector xmlns:android="http://schemas.android.com/apk/res/android"
android:width="108dp"
android:height="108dp"
android:viewportWidth="108"
android:viewportHeight="108">
<path
android:fillColor="#3DDC84"
android:pathData="M0,0h108v108h-108z" />
<path
android:fillColor="#00000000"
android:pathData="M9,0L9,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,0L19,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M29,0L29,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M39,0L39,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M49,0L49,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M59,0L59,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M69,0L69,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M79,0L79,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M89,0L89,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M99,0L99,108"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,9L108,9"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,19L108,19"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,29L108,29"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,39L108,39"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,49L108,49"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,59L108,59"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,69L108,69"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,79L108,79"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,89L108,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M0,99L108,99"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,29L89,29"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,39L89,39"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,49L89,49"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,59L89,59"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,69L89,69"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M19,79L89,79"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M29,19L29,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M39,19L39,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M49,19L49,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M59,19L59,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M69,19L69,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
<path
android:fillColor="#00000000"
android:pathData="M79,19L79,89"
android:strokeWidth="0.8"
android:strokeColor="#33FFFFFF" />
</vector>

Binary file not shown.

After

Width:  |  Height:  |  Size: 65 KiB

View File

@ -0,0 +1,8 @@
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">
<!-- 设置圆角半径 -->
<corners android:radius="30dp"/>
<!-- 设置背景颜色 -->
<solid android:color="#FFFFFF"/>
</shape>

View File

@ -0,0 +1,36 @@
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity"
android:orientation="vertical">
<VideoView
android:id="@+id/video"
android:layout_width="match_parent"
android:layout_height="400dp"
android:layout_weight="2"
/>
<TextView
android:id="@+id/textView"
android:layout_width="match_parent"
android:layout_height="200dp"
android:layout_weight="2"
android:text="@string/introduce_text"
android:textSize="20dp"/>
<Button
android:id="@+id/test_button"
android:layout_width="match_parent"
android:layout_height="100dp"
android:layout_weight="1"
android:background="#FFF"
android:gravity="center"
android:text="@string/search_button"
android:textSize="25sp" />
</LinearLayout>

View File

@ -0,0 +1,29 @@
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/white"
>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:background="@drawable/radius_rectangle">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center">
<ImageView
android:id="@+id/permission"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:src="@drawable/permission">
</ImageView>
</LinearLayout>
</LinearLayout>
</androidx.constraintlayout.widget.ConstraintLayout>

View File

@ -0,0 +1,5 @@
<?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
<background android:drawable="@drawable/ic_launcher_background" />
<foreground android:drawable="@drawable/ic_launcher_foreground" />
</adaptive-icon>

View File

@ -0,0 +1,5 @@
<?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
<background android:drawable="@drawable/ic_launcher_background" />
<foreground android:drawable="@drawable/ic_launcher_foreground" />
</adaptive-icon>

View File

@ -0,0 +1,6 @@
<?xml version="1.0" encoding="utf-8"?>
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android">
<background android:drawable="@drawable/ic_launcher_background" />
<foreground android:drawable="@drawable/ic_launcher_foreground" />
<monochrome android:drawable="@drawable/ic_launcher_foreground" />
</adaptive-icon>

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 982 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 7.6 KiB

View File

@ -0,0 +1,16 @@
<resources xmlns:tools="http://schemas.android.com/tools">
<!-- Base application theme. -->
<style name="Theme.ExtractPrivilege" parent="Theme.MaterialComponents.DayNight.DarkActionBar">
<!-- Primary brand color. -->
<item name="colorPrimary">@color/purple_200</item>
<item name="colorPrimaryVariant">@color/purple_700</item>
<item name="colorOnPrimary">@color/black</item>
<!-- Secondary brand color. -->
<item name="colorSecondary">@color/teal_200</item>
<item name="colorSecondaryVariant">@color/teal_200</item>
<item name="colorOnSecondary">@color/black</item>
<!-- Status bar color. -->
<item name="android:statusBarColor">?attr/colorPrimaryVariant</item>
<!-- Customize your theme here. -->
</style>
</resources>

View File

@ -0,0 +1,10 @@
<?xml version="1.0" encoding="utf-8"?>
<resources>
<color name="purple_200">#FFBB86FC</color>
<color name="purple_500">#FF6200EE</color>
<color name="purple_700">#FF3700B3</color>
<color name="teal_200">#FF03DAC5</color>
<color name="teal_700">#FF018786</color>
<color name="black">#FF000000</color>
<color name="white">#FFFFFFFF</color>
</resources>

View File

@ -0,0 +1,9 @@
<resources>
<string name="app_name">ExtractPrivilege</string>
<string name="search_button">找到更多相似MV</string>
<string name="introduce_text">歌手:郭顶\n作词郭顶\n作曲郭顶\n编曲郭顶\n制作人郭顶\n专辑飞行器的执行日期</string>
<string name="permission_title">相机权限使用说明</string>
<string name="permission_content">“相机”检测到应用“Extract Privilege”正在运行为正常使用功能请开启相机使用权限。</string>
<string name="check">确认</string>
<string name="cancel">取消</string>
</resources>

View File

@ -0,0 +1,16 @@
<resources xmlns:tools="http://schemas.android.com/tools">
<!-- Base application theme. -->
<style name="Theme.ExtractPrivilege" parent="Theme.MaterialComponents.DayNight.DarkActionBar">
<!-- Primary brand color. -->
<item name="colorPrimary">@color/purple_500</item>
<item name="colorPrimaryVariant">@color/purple_700</item>
<item name="colorOnPrimary">@color/white</item>
<!-- Secondary brand color. -->
<item name="colorSecondary">@color/teal_200</item>
<item name="colorSecondaryVariant">@color/teal_700</item>
<item name="colorOnSecondary">@color/black</item>
<!-- Status bar color. -->
<item name="android:statusBarColor">?attr/colorPrimaryVariant</item>
<!-- Customize your theme here. -->
</style>
</resources>

View File

@ -0,0 +1,13 @@
<?xml version="1.0" encoding="utf-8"?><!--
Sample backup rules file; uncomment and customize as necessary.
See https://developer.android.com/guide/topics/data/autobackup
for details.
Note: This file is ignored for devices older that API 31
See https://developer.android.com/about/versions/12/backup-restore
-->
<full-backup-content>
<!--
<include domain="sharedpref" path="."/>
<exclude domain="sharedpref" path="device.xml"/>
-->
</full-backup-content>

View File

@ -0,0 +1,19 @@
<?xml version="1.0" encoding="utf-8"?><!--
Sample data extraction rules file; uncomment and customize as necessary.
See https://developer.android.com/about/versions/12/backup-restore#xml-changes
for details.
-->
<data-extraction-rules>
<cloud-backup>
<!-- TODO: Use <include> and <exclude> to control what is backed up.
<include .../>
<exclude .../>
-->
</cloud-backup>
<!--
<device-transfer>
<include .../>
<exclude .../>
</device-transfer>
-->
</data-extraction-rules>

View File

@ -0,0 +1,17 @@
package com.example.extractprivilege;
import org.junit.Test;
import static org.junit.Assert.*;
/**
* Example local unit test, which will execute on the development machine (host).
*
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
*/
public class ExampleUnitTest {
@Test
public void addition_isCorrect() {
assertEquals(4, 2 + 2);
}
}

View File

@ -0,0 +1,5 @@
// Top-level build file where you can add configuration options common to all sub-projects/modules.
plugins {
id 'com.android.application' version '7.4.1' apply false
id 'com.android.library' version '7.4.1' apply false
}

View File

@ -0,0 +1,21 @@
# Project-wide Gradle settings.
# IDE (e.g. Android Studio) users:
# Gradle settings configured through the IDE *will override*
# any settings specified in this file.
# For more details on how to configure your build environment visit
# http://www.gradle.org/docs/current/userguide/build_environment.html
# Specifies the JVM arguments used for the daemon process.
# The setting is particularly useful for tweaking memory settings.
org.gradle.jvmargs=-Xmx2048m -Dfile.encoding=UTF-8
# When configured, Gradle will run in incubating parallel mode.
# This option should only be used with decoupled projects. More details, visit
# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
# org.gradle.parallel=true
# AndroidX package structure to make it clearer which packages are bundled with the
# Android operating system, and which are packaged with your app's APK
# https://developer.android.com/topic/libraries/support-library/androidx-rn
android.useAndroidX=true
# Enables namespacing of each library's R class so that its R class includes only the
# resources declared in the library itself and none from the library's dependencies,
# thereby reducing the size of the R class for that library
android.nonTransitiveRClass=true

View File

@ -0,0 +1,6 @@
#Sat Feb 25 21:56:31 CST 2023
distributionBase=GRADLE_USER_HOME
distributionUrl=https\://services.gradle.org/distributions/gradle-7.5-bin.zip
distributionPath=wrapper/dists
zipStorePath=wrapper/dists
zipStoreBase=GRADLE_USER_HOME

Some files were not shown because too many files have changed in this diff Show More