From f21ed5989be4b3bfe4707c87b92d03236916d30d Mon Sep 17 00:00:00 2001 From: hch <305670599@qq.com> Date: 星期三, 27 十二月 2023 11:18:30 +0800 Subject: [PATCH] 0312 测试 --- SdkProject/library/src/main/java/com/secondworld/sdk/GameActivity.java | 78 +++++++++++++++++++++++++++++++++++++- 1 files changed, 75 insertions(+), 3 deletions(-) diff --git a/SdkProject/library/src/main/java/com/secondworld/sdk/GameActivity.java b/SdkProject/library/src/main/java/com/secondworld/sdk/GameActivity.java index 1bc106d..c3fc094 100644 --- a/SdkProject/library/src/main/java/com/secondworld/sdk/GameActivity.java +++ b/SdkProject/library/src/main/java/com/secondworld/sdk/GameActivity.java @@ -1,15 +1,25 @@ package com.secondworld.sdk; +import android.content.Intent; import android.os.Bundle; -import android.support.annotation.NonNull; +import android.view.KeyEvent; +import android.widget.FrameLayout; +import android.widget.RelativeLayout; + +import androidx.annotation.NonNull; import com.secondworld.sdk.utils.LogUtil; +import com.secondworld.sdk.utils.WebViewUtil; +import com.juefeng.sdk.juefengsdk.JFSDK; public class GameActivity extends UnityPlayerActivity { private static Class<? extends GameActivityProxy> proxyClass; - GameActivityProxy proxy; + private GameActivityProxy proxy; + + private RelativeLayout webContainer; + private FrameLayout unityContainer; //娉ㄥ唽浠g悊绫� public static void registerProxy(Class<? extends GameActivityProxy> proxyClass) { @@ -19,7 +29,13 @@ @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); - LogUtil.d("GameActivity","鍚姩鐨勬槸GameActivity锛�"); + LogUtil.d("GameActivity", "鍚姩鐨勬槸GameActivity锛�"); + setContentView(R.layout.activity_main); + webContainer = findViewById(R.id.webContainer); + unityContainer = findViewById(R.id.unityContainer); + unityContainer.addView(mUnityPlayer); + WebViewUtil.I.init(this, webContainer); + //鍒濆鍖栨笭閬撲唬鐞嗙被 try { if (proxyClass != null) { proxy = proxyClass.newInstance(); @@ -37,6 +53,15 @@ super.onStart(); if (proxy != null) proxy.onStart(); + } + + @Override + protected void onRestart() { + super.onRestart(); + if (proxy != null) + proxy.onRestart(); + + JFSDK.getInstance().onRestart(GTGameMain.I.activity); } @Override @@ -68,10 +93,57 @@ } @Override + protected void onNewIntent(Intent intent) { + super.onNewIntent(intent); + if (proxy != null) + proxy.onNewIntent(intent); + JFSDK.getInstance().onNewIntent(GTGameMain.I.activity, intent); + } + + @Override + protected void onActivityResult(int requestCode, int resultCode, Intent data) { + super.onActivityResult(requestCode, resultCode, data); + if (proxy != null) + proxy.onActivityResult(requestCode, resultCode, data); + } + + @Override public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { super.onRequestPermissionsResult(requestCode, permissions, grantResults); if (proxy != null) proxy.onRequestPermissionsResult(requestCode, permissions, grantResults); } + @Override + public boolean onKeyDown(int keyCode, KeyEvent event) { + if (proxy == null) + return super.onKeyDown(keyCode, event); + boolean b = proxy.onKeyDown(keyCode, event); + return b ? b : super.onKeyDown(keyCode, event); + } + + @Override + public boolean dispatchKeyEvent(KeyEvent event) { + if(event.getKeyCode() == KeyEvent.KEYCODE_BACK) { + if(event.getAction() == KeyEvent.ACTION_DOWN&&event.getRepeatCount() == 0) { + JFSDK.getInstance().exitLogin(GTGameMain.I.activity); + return true; + } + } + return super.dispatchKeyEvent(event); + } + + @Override + public void onWindowFocusChanged(boolean hasFocus) + { + super.onWindowFocusChanged(hasFocus); + JFSDK.getInstance().onWindowFocusChanged(hasFocus); + } + + @Override + public void onBackPressed() + { + super.onBackPressed(); + JFSDK.getInstance().onBackPressed(GTGameMain.I.activity); + } } \ No newline at end of file -- Gitblit v1.8.0