Compare commits

...

18 Commits
master ... oppo

Author SHA1 Message Date
zhl
da724adfff update version code of oppo 2021-11-09 19:34:22 +08:00
zhl
e611a5b4f4 添加apk层面供js调用的显示隐私政策和用户协议的方法 2021-10-28 10:32:47 +08:00
zhl
9e534c5184 update sdk of oppo 2021-10-21 16:19:23 +08:00
zhl
e8189a5a50 update version code of oppo 2021-02-25 13:35:54 +08:00
zhl
cbf94cb747 更新oppo的版本和icon 2021-01-19 10:08:42 +08:00
zhl
1ca516b7e1 更新oppo版本 2021-01-18 16:55:58 +08:00
zhl
d0c31fda51 更新oppo的版本号 2021-01-18 12:43:20 +08:00
zhl
098cc65123 修正热更无法正常运行的bug 2020-12-23 20:07:21 +08:00
zhl
b1726e94ce 修改版本号 2020-11-27 16:28:11 +08:00
zhl
fe6c516a8f 更新oppo的sdk 2020-11-27 10:23:36 +08:00
zhl
63a15b11eb 修改oppo打包的key, 修改oppo混淆规则 2020-11-23 16:43:22 +08:00
zhl
2059939f80 移除oppo代码中的todo 2020-11-23 13:52:12 +08:00
zhl
a8a1e954f3 接入oppo的支付 2020-11-23 13:51:01 +08:00
zhl
fc1aafadbf 更新oppo的channelid 2020-11-19 20:10:36 +08:00
zhl
7101599a6b 修改退出流程 2020-11-19 17:51:49 +08:00
zhl
0078dfec2c 增加oppo登陆和支付的代码 2020-11-19 16:48:41 +08:00
zhl
ffa2eff144 Merge branch 'master' into oppo 2020-11-19 16:12:28 +08:00
zhl
e11f2b0c1b 修改oppo的applicationid 2020-11-19 16:02:05 +08:00
17 changed files with 222 additions and 52 deletions

View File

@ -6,4 +6,6 @@ key/publish_key
key store pass: 7654321Kingsome_
key alias: release
key pass: 7654321Kingsome_
oppo使用alias: oppo
```

View File

@ -3,11 +3,11 @@ apply plugin: 'com.android.application'
android {
compileSdkVersion 28
defaultConfig {
applicationId "com.hnjc.wjtx.mi"
minSdkVersion 18
applicationId 'com.hnjc.wjtx.nearme.gamecenter'
minSdkVersion 19
targetSdkVersion 28
versionCode 1
versionName "1.0.0"
versionCode 9
versionName "1.0.9"
ndk {
abiFilters 'armeabi-v7a'
}

BIN
app/libs/gamesdk-20210810.aar Executable file

Binary file not shown.

Binary file not shown.

View File

@ -83,9 +83,11 @@
-dontwarn android.support.**
-keep class **.R$styleable{*;}
-keep class com.hnjc.wjtx.mi.** { *; }
-dontwarn com.hnjc.wjtx.mi.**
-keep class com.hnjc.wjtx.** { *; }
-dontwarn com.hnjc.wjtx.**
-keep class org.egret.** { *; }
-dontwarn org.egret.**
-dontwarn org.egret.**
-keep class com.nearme.** { *; }

View File

@ -5,14 +5,13 @@
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.VIBRATE" />
<application
android:allowBackup="false"
android:icon="@mipmap/ic_launcher"
android:icon="@drawable/icon"
android:name=".JCApplication"
android:label="@string/app_name"
android:usesCleartextTraffic="true"
@ -38,19 +37,12 @@
android:theme="@android:style/Theme.NoTitleBar.Fullscreen">
</activity>
<!-- <activity android:name=".MainActivity"-->
<!-- android:launchMode="singleTask"-->
<!-- android:screenOrientation="portrait"-->
<!-- android:windowSoftInputMode="adjustPan|stateAlwaysVisible"-->
<!-- android:configChanges="orientation|keyboardHidden|screenSize|screenLayout"-->
<!-- android:theme="@android:style/Theme.NoTitleBar.Fullscreen">-->
<!-- <intent-filter>-->
<!-- <action android:name="android.intent.action.MAIN" />-->
<!-- <category android:name="android.intent.category.LAUNCHER" />-->
<!-- </intent-filter>-->
<!-- </activity>-->
<!-- nearme game sdk config goes here -->
<uses-library android:name="org.apache.http.legacy" android:required="false" />
<!-- <meta-data android:name="app_type" android:value="1" /> &lt;!&ndash;app_type:1 表示应用应用必须设为1&ndash;&gt;-->
<meta-data android:name="debug_mode" android:value="false" /> <!-- 日志开关发布时候设置为false -->
<meta-data android:name="is_offline_game" android:value="false" /> <!-- true:单机游戏 false:网游 。应用设置true-->
<meta-data android:name="app_key" android:value="c8d0bd98ecda441993df181cdf23663a" /> <!-- appKey -->
</application>

View File

@ -3,10 +3,14 @@ package com.hnjc.wjtx;
import android.app.Application;
import android.util.Log;
import com.nearme.game.sdk.GameCenterSDK;
public class JCApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
Log.i("JCApplication", "JCApplication onCreate");
String appSecret = "4225d8b8b9fa49ed8686c9e325a05d7b";
GameCenterSDK.init(appSecret, this);
}
}

View File

@ -93,6 +93,7 @@ public class LaunchActivity extends Activity {
int check = checkSelfPermission(permissions[0]);
if (check != PackageManager.PERMISSION_GRANTED) {
requestPermissions(permissions, 111);
return;
}
}
compareVersions();
@ -128,7 +129,7 @@ public class LaunchActivity extends Activity {
*/
private void getLocalVersionInfo() {
String fileName = gameUrl.replace("index.html", "version.json");
String realPath = getFileDirByUrl(fileName);
String realPath = preloadPath + "/" + getFileDirByUrl(fileName) + "version.json" ;
File versionFile = new File(realPath);
if (versionFile.exists()) {
JSONObject data = AssetsUtil.readJsonFromFile(this, realPath);
@ -198,7 +199,7 @@ public class LaunchActivity extends Activity {
});
}
private void preloadGame() {
String dir = preloadPath + getFileDirByUrl(gameUrl);
String dir = preloadPath + "/" + getFileDirByUrl(gameUrl);
File dirFile = new File(dir);
if (!dirFile.exists()) {
dirFile.mkdirs();
@ -278,4 +279,14 @@ public class LaunchActivity extends Activity {
overridePendingTransition(0, 0);
}
@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions,
int[] grantResults) {
switch (requestCode) {
case 111:
compareVersions();
break;
}
}
}

View File

@ -12,6 +12,10 @@ import android.os.VibrationEffect;
import android.os.Vibrator;
import android.util.Log;
import android.view.KeyEvent;
import android.view.Window;
import android.view.WindowManager;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.FrameLayout;
import android.widget.ImageView;
import android.widget.Toast;
@ -19,6 +23,13 @@ import android.widget.Toast;
import com.hnjc.wjtx.util.AssetsUtil;
import com.hnjc.wjtx.util.StorageUtil;
import com.hnjc.wjtx.util.StringUtil;
import com.nearme.game.sdk.GameCenterSDK;
import com.nearme.game.sdk.callback.ApiCallback;
import com.nearme.game.sdk.callback.GameExitCallback;
import com.nearme.game.sdk.callback.SinglePayCallback;
import com.nearme.game.sdk.common.model.biz.PayInfo;
import com.nearme.game.sdk.common.util.AppUtil;
import com.nearme.platform.opensdk.pay.PayResponse;
import org.egret.egretnativeandroid.EgretNativeAndroid;
import org.json.JSONException;
@ -32,11 +43,15 @@ public class MainActivity extends Activity {
private ImageView launchScreenImageView = null;
private FrameLayout rootLayout = null;
private Vibrator vibrator;
private boolean alterShowed;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
WindowManager.LayoutParams.FLAG_FULLSCREEN);
String preloadPath = AssetsUtil.getDiskFileDir(this, this.getString(R.string.preload_path));
String gameUrl = this.getString(R.string.game_url);
@ -58,7 +73,7 @@ public class MainActivity extends Activity {
nativeAndroid.config.preloadPath = preloadPath;
setExternalInterfaces();
if (!nativeAndroid.initialize(gameUrl)) {
Toast.makeText(this, "Initialize native failed.",
Toast.LENGTH_LONG).show();
@ -86,21 +101,30 @@ public class MainActivity extends Activity {
public boolean onKeyDown(final int keyCode, final KeyEvent keyEvent) {
if (keyCode == KeyEvent.KEYCODE_BACK) {
//声明并初始化弹出对象
AlertDialog.Builder builder=new AlertDialog.Builder(this);
builder.setTitle("提示:");
builder.setMessage("是否退出");
//设置确认按钮
builder.setNegativeButton("确定", (dialog, which) -> {
nativeAndroid.exitGame();
finish();//退出程序
// AlertDialog.Builder builder = new AlertDialog.Builder(this);
// builder.setTitle("提示:");
// builder.setMessage("是否退出");
// //设置确认按钮
// builder.setNegativeButton("确定", (dialog, which) -> {
// nativeAndroid.exitGame();
// finish();//退出程序
// });
// //设置取消按钮
// builder.setPositiveButton("取消", null);
// //显示弹框
// builder.show();
GameCenterSDK.getInstance().onExit(this, new GameExitCallback() {
public void exitGame() {
AppUtil.exitGameProcess(MainActivity.this);
nativeAndroid.exitGame();
finish();
}
});
//设置取消按钮
builder.setPositiveButton("取消",null);
//显示弹框
builder.show();
return true;
} else {
return super.onKeyDown(keyCode, keyEvent);
}
return super.onKeyDown(keyCode, keyEvent);
}
private void setExternalInterfaces() {
@ -114,14 +138,13 @@ public class MainActivity extends Activity {
});
nativeAndroid.setExternalInterface("setLocalStorage", message -> {
Log.d(TAG, "setLocalStorage: " + message);
try{
try {
JSONObject jsonObject = new JSONObject(message);
String key = jsonObject.getString("key");
String val = jsonObject.getString("val");
SharedPreferences sharedPref = getPreferences(Context.MODE_PRIVATE);
StorageUtil.writeString(sharedPref, key, val);
}
catch (JSONException e) {
} catch (JSONException e) {
Log.e(TAG, " onState message failed to analyze");
}
@ -159,17 +182,34 @@ public class MainActivity extends Activity {
Log.d(TAG, "showToast: " + message);
Toast.makeText(MainActivity.this, message, Toast.LENGTH_LONG).show();
});
nativeAndroid.setExternalInterface("showPrivacy", message -> {
Log.d(TAG, "showPrivacy: " + message);
runOnUiThread(this::showPrivacy);
});
nativeAndroid.setExternalInterface("showAgreement", message -> {
Log.d(TAG, "showAgreement: " + message);
runOnUiThread(this::showAgreement);
});
nativeAndroid.setExternalInterface("getUid", message -> {
//TODO: 平台的登陆
GameCenterSDK.getInstance().doLogin(this, new ApiCallback() {
@Override
public void onSuccess(String arg0) {
doGetTokenAndSsoid();
}
@Override
public void onFailure(String arg0, int arg1) {
nativeAndroid.callExternalInterface("loginCancel", "");
}
});
});
nativeAndroid.setExternalInterface("@onState", message -> {
Log.e(TAG, "Get @onState: " + message);
try{
try {
JSONObject jsonObject = new JSONObject(message);
String state = jsonObject.getString("state");
handleStateEvent(state);
}
catch (JSONException e) {
} catch (JSONException e) {
Log.e(TAG, " onState message failed to analyze");
}
@ -180,13 +220,64 @@ public class MainActivity extends Activity {
try {
JSONObject jsonObject = new JSONObject(message);
String cpOrderId = jsonObject.getString("orderId");
String productCode = jsonObject.getString("productCode");
int count = jsonObject.getInt("count");
//TODO: 平台的支付
String cpOrderId = jsonObject.getString("order");
String attach = jsonObject.getString("attach");
int money = jsonObject.getInt("amount"); // 未传
String notifyUrl = jsonObject.getString("notifyUrl"); // 未传
String productName = jsonObject.getString("productName"); // 未传
String productDesc = jsonObject.getString("productDesc"); //未传
// String sign = jsonObject.getString("sign"); // 未传
PayInfo payInfo = new PayInfo(cpOrderId, attach, money );
payInfo.setProductDesc(productDesc);
payInfo.setProductName(productName);
payInfo.setAmount(money);
// payInfo.setType(PayInfo.TYPE_AUTO_ORDER_WXPAY);
payInfo.setUseCachedChannel(false);
// 支付结果服务器回调地址不通过服务端回调发货的应用可以不用填写~
payInfo.setCallbackUrl(notifyUrl);
JSONObject obj = new JSONObject();
GameCenterSDK.getInstance().doPay(this, payInfo,
new SinglePayCallback() {
@Override
public void onSuccess(String resultMsg) {
// add OPPO 支付成功处理逻辑~
try {
obj.put("errcode", 0);
obj.put("errmsg", "");
nativeAndroid.callExternalInterface("payResult", obj.toString());
} catch (JSONException e) {
e.printStackTrace();
}
}
@Override
public void onFailure(String resultMsg, int resultCode) {
// add OPPO 支付失败处理逻辑~
try {
if (PayResponse.CODE_CANCEL != resultCode) {
obj.put("errmsg", "支付失败");
} else {
// 取消支付处理
obj.put("errmsg", "支付取消");
}
obj.put("errcode", resultCode);
nativeAndroid.callExternalInterface("payResult", obj.toString());
} catch (JSONException e) {
e.printStackTrace();
}
}
@Override
public void onCallCarrierPay(PayInfo payInfo, boolean bySelectSMSPay) {
// Toast.makeText(this, "运营商支付", Toast.LENGTH_SHORT).show();
Log.i(TAG, "运营商支付");
}
});
} catch (JSONException e) {
e.printStackTrace();
} catch ( Exception e ) {
} catch (Exception e) {
e.printStackTrace();
}
});
@ -210,6 +301,31 @@ public class MainActivity extends Activity {
});
}
public void doGetTokenAndSsoid() {
GameCenterSDK.getInstance().doGetTokenAndSsoid(new ApiCallback() {
@Override
public void onSuccess(String resultMsg) {
try {
JSONObject json = new JSONObject(resultMsg);
String token = json.getString("token");
String ssoid = json.getString("ssoid");
JSONObject obj = new JSONObject();
obj.put("openid", ssoid);
obj.put("token", token);
nativeAndroid.callExternalInterface("sendUidToJS", obj.toString());
} catch (JSONException e) {
e.printStackTrace();
}
}
@Override
public void onFailure(String content, int resultCode) {
nativeAndroid.callExternalInterface("loginCancel", "");
}
});
}
@Override
protected void onDestroy() {
super.onDestroy();
@ -226,6 +342,7 @@ public class MainActivity extends Activity {
FrameLayout.LayoutParams.MATCH_PARENT);
rootLayout.addView(launchScreenImageView, params);
}
private void handleStateEvent(String state) {
switch (state) {
case "running":
@ -235,6 +352,7 @@ public class MainActivity extends Activity {
Log.i(TAG, state);
}
}
private void hideLoadingView() {
rootLayout.removeView(launchScreenImageView);
Drawable drawable = launchScreenImageView.getDrawable();
@ -242,5 +360,41 @@ public class MainActivity extends Activity {
drawable.setCallback(null);
launchScreenImageView = null;
}
private void showPrivacy() {
String url = "https://privacy3.kingsome.cn/";
alertWebview(url);
}
private void showAgreement() {
String url = "https://privacy2.kingsome.cn/user_agreement.html";
alertWebview(url);
}
private void alertWebview(String url) {
AlertDialog.Builder builder = new AlertDialog.Builder(this);
WebView mwebView = new WebView(this);
this.alterShowed = false;
mwebView.loadUrl(url);
mwebView.setWebViewClient( new WebViewClient() {
//设置结束加载函数
@Override
public void onPageFinished(WebView view, String url) {
if (!alterShowed) {
alterShowed = true;
builder.show();
}
}
}
);
builder.setPositiveButton( "取消", null );
builder.setView( mwebView );
builder.setPositiveButton("确定", (dialog, which) -> {
dialog.dismiss();
});
// builder.setNegativeButton("拒绝", (dialog, which) -> {
// //用户不同意隐私协议不通过Demo在此处退出游戏接入方可按自己要求处理但不能调用MiCommplatform.getInstance().onUserAgreed(this);
// dialog.dismiss();
// android.os.Process.killProcess(android.os.Process.myPid());
// });
}
}

View File

@ -14,7 +14,7 @@ public class WebApi {
public void getVersionInfo(BaseInterface iFace) {
this.mInterface = iFace;
// String versionUrl = "http://10.0.1.3:7021/game/zip/version.json";
// String versionUrl = "https://test.kingsome.cn/wjtx/config/version_native.json";
String versionUrl = "https://h5games-al.kingsome.cn/wjtx/config/version_native.json";
AppRequestUtil.getInstance().getRequest(context, versionUrl, new RequestListener() {

View File

@ -12,6 +12,7 @@ import org.json.JSONObject;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
@ -187,12 +188,15 @@ public class AssetsUtil {
*/
public static String readFromFile(Context context, String path) {
try {
InputStreamReader inputReader = new InputStreamReader(context.openFileInput(path));
FileInputStream fileInputStream = new FileInputStream(new File(path));
InputStreamReader inputReader = new InputStreamReader(fileInputStream);
BufferedReader bufReader = new BufferedReader(inputReader);
String line="";
StringBuilder result= new StringBuilder();
while((line = bufReader.readLine()) != null)
result.append(line);
fileInputStream.close();
inputReader.close();
bufReader.close();
return result.toString();

Binary file not shown.

Before

Width:  |  Height:  |  Size: 145 KiB

After

Width:  |  Height:  |  Size: 195 KiB

View File

@ -3,10 +3,11 @@
<string name="load_game">下载游戏资源</string>
<string name="start_game">进入游戏</string>
<string name="preload_path">preload</string>
<string name="game_url">http://local/index.html?channel=7013</string>
<string name="game_url">http://local/index.html?channel=7105</string>
<string name="local_version">1.0.0</string>
<string name="load_back">load_back</string>
<string name="launch_version">获取游戏版本</string>
<string name="launch_download">正在更新游戏资源</string>
<string name="launch_unzip">正在解压游戏资源</string>
<string name="app_id">30414659</string>
</resources>

BIN
assets/nearme.apk Executable file

Binary file not shown.

Binary file not shown.

BIN
assets/opay_version Executable file

Binary file not shown.

Binary file not shown.