
const permission = {
state: {
WRITE_EXTERNAL_STORAGE: false,
ACCESS_FINE_LOCATION: false,
CALL_PHONE: false,
CAMERA: false,
RECORD_AUDIO: false,
READ_CONTACTS: false,
WRITE_CONTACTS: false,
isIos: plus.os.name == "iOS",
mapping: {
'WRITE_EXTERNAL_STORAGE': {
title: "存储空间/照片权限申请说明",
content: "****需要获取相册权限,以便识别图片、上传图片或视频。",
methods: 'SET_WRITE_EXTERNAL_STORAGE'
},
'ACCESS_FINE_LOCATION': {
title: "地理位置权限申请说明",
content: "****需要获取当前位置,以便进行定位签到或设置活动地址。",
methods: 'SET_ACCESS_FINE_LOCATION'
},
'CALL_PHONE': {
title: "拨打/管理电话权限申请说明",
content: "****需要获取电话权限,以便拨打电话。",
methods: 'SET_CALL_PHONE'
},
'CAMERA': {
title: '相机权限使用说明',
content: '****需要获取相机权限,以便扫描二维码、拍摄以及录制视频。',
methods: 'SET_CAMERA'
},
'RECORD_AUDIO': {
title: '录音权限申请说明',
content: '****需要获取麦克风权限,以便进行录音。',
methods: 'SET_RECORD_AUDIO'
},
'READ_CONTACTS': {
title: '通讯录权限申请说明',
content: '****需要访问联系人,以便添加联系人到通讯录。',
methods: 'SET_READ_CONTACTS'
},
'WRITE_CONTACTS': {
title: '通讯录权限申请说明',
content: '****需要访问联系人,以便添加联系人到通讯录。',
methods: 'SET_WRITE_CONTACTS'
}
}
},
mutations: {
SET_WRITE_EXTERNAL_STORAGE(state, val) {
state.WRITE_EXTERNAL_STORAGE = val
},
SET_CALL_PHONE(state, val) {
state.CALL_PHONE = val
},
SET_ACCESS_FINE_LOCATION(state, val) {
state.ACCESS_FINE_LOCATION = val
},
SET_CAMERA(state, val) {
state.CAMERA = val
},
SET_RECORD_AUDIO(state, val) {
state.RECORD_AUDIO = val
},
SET_READ_CONTACTS(state, val) {
state.READ_CONTACTS = val
},
SET_WRITE_CONTACTS(state, val) {
state.WRITE_CONTACTS = val
}
},
actions: {
async requestPermissions({state,dispatch,commit}, permissionID) {
try {
if (!state[permissionID] && !state.isIos) {
var viewObj = await dispatch('nativeObjView', permissionID);
viewObj.show();
}
console.log('android.permission.' + permissionID, '当前手机权限');
return new Promise(async function (resolve, reject) {
if (state.isIos) {
resolve(1);
return
}
function requestAndroidPermission(permissionID_) {
return new Promise(function (resolve, reject) {
plus.android.requestPermissions(
[permissionID_],
function(resultObj) {
var result = 0;
for (var i = 0; i < resultObj.granted.length; i++) {
result = 1
}
for (var i = 0; i < resultObj.deniedPresent.length; i++) {
result = 0
}
for (var i = 0; i < resultObj.deniedAlways.length; i++) {
result = -1
}
resolve(result);
},
function(error) {
console.log('申请权限错误:' + error.code + " = " + error
.message);
resolve({
code: error.code,
message: error.message
});
}
);
});
}
const result = await requestAndroidPermission(
'android.permission.' + permissionID
);
if (result === 1) {
commit(state.mapping[permissionID].methods, true)
} else if (result === 0) {
commit(state.mapping[permissionID].methods, false)
} else {
commit(state.mapping[permissionID].methods, true)
console.log('操作权限已被拒绝,请手动前往设置')
}
if (viewObj) viewObj.close()
resolve(result);
});
} catch (error) {
console.log(error);
}
},
nativeObjView({state}, permissionID) {
const systemInfo = uni.getSystemInfoSync();
const statusBarHeight = systemInfo.statusBarHeight;
const navigationBarHeight = systemInfo.platform === 'android' ? 48 :
44;
const totalHeight = statusBarHeight + navigationBarHeight;
let view = new plus.nativeObj.View(permissionID, {
top: '0px',
left: '0px',
width: '100%',
backgroundColor: '#444',
})
view.drawRect({
color: '#fff',
radius: '5px'
}, {
top: totalHeight + 'px',
left: '5%',
width: '90%',
height: "100px",
})
view.drawText('权限使用说明', {
top: totalHeight + 5 + 'px',
left: "8%",
height: "30px"
}, {
align: "left",
color: "#000",
}, {
onClick: function(e) {
console.log(e);
}
})
view.drawText(state.mapping[permissionID].content, {
top: totalHeight + 35 + 'px',
height: "60px",
left: "8%",
width: "84%"
}, {
whiteSpace: 'normal',
size: "14px",
align: "left",
color: "#656563"
})
function show() {
view = plus.nativeObj.View.getViewById(permissionID);
view.show()
view = null
}
function close() {
view = plus.nativeObj.View.getViewById(permissionID);
view.close();
view = null
}
return {
show,
close
}
},
gotoAppPermissionSetting({state}) {
if (state.isIos) {
var UIApplication = plus.ios.import("UIApplication");
var application2 = UIApplication.sharedApplication();
var NSURL2 = plus.ios.import("NSURL");
var setting2 = NSURL2.URLWithString("app-settings:");
application2.openURL(setting2);
plus.ios.deleteObject(setting2);
plus.ios.deleteObject(NSURL2);
plus.ios.deleteObject(application2);
} else {
var Intent = plus.android.importClass("android.content.Intent");
var Settings = plus.android.importClass("android.provider.Settings");
var Uri = plus.android.importClass("android.net.Uri");
var mainActivity = plus.android.runtimeMainActivity();
var intent = new Intent();
intent.setAction(Settings.ACTION_APPLICATION_DETAILS_SETTINGS);
var uri = Uri.fromParts("package", mainActivity.getPackageName(), null);
intent.setData(uri);
mainActivity.startActivity(intent);
}
}
}
}
export default permission
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人