环信IM即时通讯 什么是Demo?
环信即时通讯 IM 示例开源项目,目前有 Android iOS 和 Web 平台。
环信IM即时通讯 什么是Demo?
环信即时通讯 IM 示例开源项目,目前有 Android iOS 和 Web 平台。
小米开发平台 关于无GPS硬件机型的位置服务适配说明
由于部分WiFi版本的小米平板(例如:小米平板5 WiFi版等)无GPS硬件,即使用户开启位置服务,应用也无法获取到GPS Provider,部分依赖于GPS位置服务的应用可能会提示“未开启位置服务或出现其他问题”,用户体验较差。
针对无GPS硬件的机型,应用可以通过检测Location Proveders中是否包含”gps”来判断是否有GPS硬件。
另外,可以通过检测Network Provider状态来判断用户是否打开位置服务。
参考Demo如下:
LocationManager lm = (LocationManager)getSystemService(Context.LOCATION_SERVICE);
// 无GPS设备通过判断Network Provider来判断位置服务是否打开
// 其他设备仍然通过GPS Provider来判断位置服务是否打开
if (!isGPSExist(lm) && isNetworkLocationAble(lm) || isGpsAble(lm)) {
// 用户已开启位置服务
// 应用自身定位逻辑
} else {
// 提醒用户未开启位置服务,引导用户至位置服务设置页面
openLocationService();
}
// 应用可以通过以下方式判断是否有GPS硬件
public static boolean isGPSExist(LocationManager lm) {
return lm.getAllProviders().contains("gps");
}
private boolean isGpsAble(LocationManager lm){
return lm.isProviderEnabled(LocationManager.GPS_PROVIDER);
}
private boolean isNetworkLocationAble(LocationManager lm){
return lm.isProviderEnabled(LocationManager.NETWORK_PROVIDER);
}
private void openLocationService()(){
Intent intent = new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS);
startActivity(intent);
}
如果应用对GPS有强依赖,建议应用优化新增相关友好提示。
OPPO开放平台消息推送自检工具
OPush Demo提供了一些基本功能的接入示例,开发者可以在接入SDK之前,通过demo方快速体验和了解推送的实际效果。也可以测试一些基本功能例如注册、注销、清除通知、打开通知设置等功能。或者通过修改部分代码,可以快速验证接入功能。
代码参考demo下载:heytapPushDemo.rar(3.0.0版本)
用做网页的技术做APP! 一门提供标准化的jsbridge-mini.js库,您只需要在页面引用并执行JS即可实现各种原生APP、原生PC的功能能力。 ==================APP端================== 【APP端】(安卓版&苹果版)目前提供200+原生功能,2000+JS映射接口,用做网站的技术即可实现各种原生APP能力、APP demo地址https://www.yimenapp.com/doc/demo.cshtml下载教程: ♦ JS-SDK 引用方式: ♦ 普通网页 script 方式加载:下载最新版,请在页面上调用 jsBridge 接口之前引用 jsbridge-mini.js 库; ♦ js module 方式引用:npm install ym-jsbridge 具体请参考 npm package |
核心代码示例,详情参阅demo
jsBridge.pns.getLoginToken({
titleText : "绑定手机号码",
sloganText: "使用本机号码一键绑定",
loginButtonText: "一键绑定",
showLogo: true,
privacyHideCheckbox: true,
privacyPrefixText : "绑定手机号即表示已阅读并同意"
}, function(succ, data) {
if (succ) {
//jsBridge.setClipboardText(data.token);
alert("授权成功 token:\n" + data.token);
} else {
alert("授权失败:\n" + data.errorMessage)
}
});
A标签执行JS示例代码
<a href="javascript:void(0)" onclick="zhixing()">执行</a>
<!-- 写入一个A标签href值为"javascript:void(0)",定义点击事件onclick;-->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- 在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接;-->
<script type="text/javascript">
function zhixing() {
<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.pns.getLoginToken({
titleText : "绑定手机号码",
sloganText: "使用本机号码一键绑定",
loginButtonText: "一键绑定",
showLogo: true,
privacyHideCheckbox: true,
privacyPrefixText : "绑定手机号即表示已阅读并同意"
}, function(succ, data) {
if (succ) {
//jsBridge.setClipboardText(data.token);
alert("授权成功 token:\n" + data.token);
} else {
alert("授权失败:\n" + data.errorMessage)
}
});
}
</script>
<!--执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可;-->
按钮执行JS示例代码
<button onclick="zhixing()" >执行</button>
<!-- //写一个按钮,定义点击执行事件; -->
<script src="您的服务器URL/jsbridge-mini.js"></script>
<!-- //在您的服务器引入一门JS地址,请下载jsbridge-mini.js上传您自己的服务器获取链接; -->
<script type="text/javascript">
function zhixing() {
<!--这里可以直接复制JS核心代码到此{}括号内-->
jsBridge.pns.getLoginToken({
titleText : "绑定手机号码",
sloganText: "使用本机号码一键绑定",
loginButtonText: "一键绑定",
showLogo: true,
privacyHideCheckbox: true,
privacyPrefixText : "绑定手机号即表示已阅读并同意"
}, function(succ, data) {
if (succ) {
//jsBridge.setClipboardText(data.token);
alert("授权成功 token:\n" + data.token);
} else {
alert("授权失败:\n" + data.errorMessage)
}
});
}
</script>
<!-- //执行核心代码;
//如果需要进入页面就执行,去掉点击事件即可; -->