提交 07c6275e 编写于 作者: lizhongyi_'s avatar lizhongyi_

Merge branch 'dev1' into dev

* dev1:
  uni-usercapturescreen Android 新增禁止截屏API

# Conflicts:
#	pages/index/index.vue
......@@ -6,11 +6,11 @@
</view>
<button @tap="testScreenShotListen">开启截屏监听</button>
<button @tap="testScreenShotOff">关闭截屏监听</button>
<button @tap="testSetUserCaptureScreen">{{setUserCaptureScreenText}}</button>
<button @tap="testGetBatteryInfo">获取电池电量</button>
<button @tap="testonMemoryWarning">开启内存不足告警监听</button>
<button @tap="testoffMemoryWarning">关闭内存不足告警监听</button>
<button @tap="testShowModal">模态弹窗</button>
<button @tap="testShowModalWithTF">模态弹窗带输入框</button>
<button @tap="testStartWifi">初始化wifi模块</button>
<button @tap="testGetWifiList">获取当前wifi列表</button>
......@@ -21,113 +21,87 @@
</template>
<script>
import showModal from '@/uni_modules/uni-showmodal';
export default {
data() {
return {
title: 'Hello',
memListener: null,
memListener:null,
setUserCaptureScreenFlag: true,
setUserCaptureScreenText: '禁止截屏'
}
},
onLoad() {
},
methods: {
onMemoryWarning: function(res) {
onMemoryWarning:function(res){
console.log(res);
},
testShowModal() {
showModal({
title: "温馨提示",
content: "这是一个模态弹窗",
cancelColor: "#ff0000",
confirmColor: "#00ff00",
showCancel: true,
success: function(res) {
console.log(res)
}
})
},
testShowModalWithTF() {
showModal({
title: "提示",
content: "带输入框的弹窗",
showCancel: false,
editable: true,
placeholderText: "请输入内容",
success: function(res) {
console.log(res)
}
})
},
testConnnectWifi() {
testConnnectWifi(){
uni.connectWifi({
maunal: false,
SSID: "Xiaomi_20D0",
password: "BBBB",
complete: (res) => {
maunal:false,
SSID:"Xiaomi_20D0",
password:"BBBB",
complete:(res)=>{
console.log(res);
}
});
},
testGetConnnectWifi() {
testGetConnnectWifi(){
uni.getConnectedWifi({
partialInfo: false,
complete: (res) => {
partialInfo:false,
complete:(res)=>{
console.log(res);
if (res.errCode == 0) {
uni.showToast({
icon: 'none',
title: res.wifi.SSID
icon:'none',
title:res.wifi.SSID
})
} else {
} else{
uni.showToast({
icon: 'none',
title: res.errMsg
icon:'none',
title:res.errMsg
})
}
}
});
},
testStartWifi() {
testStartWifi(){
uni.startWifi({
success: (res) => {
success:(res)=> {
console.log("success: " + JSON.stringify(res));
// wifi 开启成功后,注册wifi链接状态监听和wifi列表获取监听
uni.onGetWifiList(function(res) {
uni.onGetWifiList(function(res){
console.log("onGetWifiList");
console.log(res);
});
uni.onWifiConnected(function(res) {
uni.onWifiConnected(function(res){
console.log("onWifiConnected");
console.log(res);
});
uni.onWifiConnectedWithPartialInfo(function(res) {
uni.onWifiConnectedWithPartialInfo(function(res){
console.log("onWifiConnectedWithPartialInfo");
console.log(res);
});
},
fail: (res) => {
},fail:(res)=>{
console.log("fail: " + JSON.stringify(res));
},
complete: (res) => {
},complete:(res)=>{
console.log("complete: " + JSON.stringify(res));
}
})
},
testStopWifi() {
uni.stopWifi({
success: (res) => {
success:(res)=> {
console.log("success: " + JSON.stringify(res));
},
fail: (res) => {
},fail:(res)=>{
console.log("fail: " + JSON.stringify(res));
},
complete: (res) => {
},complete:(res)=>{
console.log("complete: " + JSON.stringify(res));
}
})
......@@ -135,13 +109,11 @@
},
testGetWifiList() {
uni.getWifiList({
success: (res) => {
success:(res)=> {
console.log("success: " + JSON.stringify(res));
},
fail: (res) => {
},fail:(res)=>{
console.log("fail: " + JSON.stringify(res));
},
complete: (res) => {
},complete:(res)=>{
console.log("complete: " + JSON.stringify(res));
}
})
......@@ -150,15 +122,15 @@
testonMemoryWarning() {
uni.onMemoryWarning(this.onMemoryWarning)
uni.showToast({
icon: 'none',
title: '已监听,注意控制台输出'
icon:'none',
title:'已监听,注意控制台输出'
})
},
testoffMemoryWarning() {
testoffMemoryWarning(){
uni.offMemoryWarning(this.onMemoryWarning)
uni.showToast({
icon: 'none',
title: '监听已移除'
icon:'none',
title:'监听已移除'
})
},
testScreenShotListen() {
......@@ -168,26 +140,26 @@
if (uni.getSystemInfoSync().platform == "android") {
// 除android 之外的平台,不需要判断返回状态码
if (res.errCode == -1) {
if(res.errCode == -1){
// 启动失败
return;
} else if (res.errCode == 0) {
return ;
}else if(res.errCode == 0){
uni.showToast({
icon: "none",
title: '截屏监听已开启'
icon:"none",
title:'截屏监听已开启'
})
} else {
}else {
uni.showToast({
icon: "none",
title: '捕获截屏事件'
icon:"none",
title:'捕获截屏事件'
})
that.screenImage = res.image
}
} else {
}else{
// 除android 之外的平台,不需要判断返回状态码
uni.showToast({
icon: "none",
title: '捕获截屏事件'
icon:"none",
title:'捕获截屏事件'
})
}
......@@ -196,8 +168,8 @@
if (uni.getSystemInfoSync().platform != "android") {
// 除android 之外的平台,直接提示监听已开启
uni.showToast({
icon: "none",
title: '截屏监听已开启'
icon:"none",
title:'截屏监听已开启'
})
}
},
......@@ -207,8 +179,8 @@
});
// 提示已经开始监听,注意观察
uni.showToast({
icon: "none",
title: '截屏监听已关闭'
icon:"none",
title:'截屏监听已关闭'
})
},
testGetBatteryInfo() {
......@@ -222,6 +194,31 @@
}
})
},
testSetUserCaptureScreen() {
let flag = this.setUserCaptureScreenFlag;
uni.setUserCaptureScreen({
open: flag,
success: (res) => {
console.log("setUserCaptureScreen open: " + flag + " success: " + JSON.stringify(res));
},
fail: (res) => {
console.log("setUserCaptureScreen open: " + flag + " fail: " + JSON.stringify(res));
},
complete: (res) => {
console.log("setUserCaptureScreen open: " + flag + " complete: " + JSON.stringify(res));
}
});
uni.showToast({
icon:"none",
title: this.setUserCaptureScreenText
});
this.setUserCaptureScreenFlag = !this.setUserCaptureScreenFlag;
if (this.setUserCaptureScreenFlag) {
this.setUserCaptureScreenText = '禁止截屏';
} else {
this.setUserCaptureScreenText = '允许截屏';
}
},
}
}
</script>
......
......@@ -34,7 +34,8 @@
"uni-ext-api":{
"uni": {
"onUserCaptureScreen": "onUserCaptureScreen",
"offUserCaptureScreen": "offUserCaptureScreen"
"offUserCaptureScreen": "offUserCaptureScreen",
"setUserCaptureScreen": "setUserCaptureScreen"
}
},
"dependencies": [],
......
......@@ -13,7 +13,17 @@ import FileObserver from "android.os.FileObserver";
import File from "java.io.File";
import Environment from "android.os.Environment";
import System from 'java.lang.System';
import WindowManager from 'android.view.WindowManager';
/**
* setUserCaptureScreen 参数定义
*/
type SetUserCaptureScreenOption = {
open: boolean;
success?: (res: UTSJSONObject) => void;
fail?: (res: UTSJSONObject) => void;
complete?: (res: UTSJSONObject) => void;
}
/**
......@@ -145,5 +155,41 @@ export function offUserCaptureScreen(success: (res: any) => void) {
success({});
}
/**
* 设置是否禁止截屏
*/
export function setUserCaptureScreen(option: SetUserCaptureScreenOption) {
const res = {
errCode: 0,
errMsg: "setUserCaptureScreen:ok",
errSubject: "uni-setUserCaptureScreen"
};
UTSAndroid.getUniActivity()?.runOnUiThread(new SetUserCaptureScreenRunnable(option.open));
option.success?.(res);
option.complete?.(res);
}
class SetUserCaptureScreenRunnable extends Runnable {
/**
* true 表示禁止截屏
* false 表示允许截屏
*/
private open: boolean = false;
constructor(open: boolean) {
super();
this.open = open;
}
override run(): void {
if (this.open) {
UTSAndroid.getUniActivity()?.getWindow()?.addFlags(WindowManager.LayoutParams.FLAG_SECURE);
} else {
UTSAndroid.getUniActivity()?.getWindow()?.clearFlags(WindowManager.LayoutParams.FLAG_SECURE);
}
}
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册