Мне нужно вызвать собственный экран реагирования, когда я получаю тихое уведомление. В настоящее время я экспериментирую с состоянием телефона. Я делаю это с помощью класса PhoneStateListenr, который запускает второе действие с именем MyActivity, которое запускает внутри него код React Native.
Когда запускается класс MyActivity, я получил следующую ошибку: сообщение о том, что текущая активность имеет неправильный класс:
java.lang.IllegalStateException: Current Activity is of incorrect class, expected AppCompatActivity, received MyActivity
MyActivity срабатывает в зависимости от состояния телефона,
package com.apartmentapp;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
public class PhoneStateListener extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
try {
final Context ctx;
ctx = context;
final Intent intnt = new Intent(context, MyActivity.class);
intnt.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
intnt.addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP);
intnt.putExtra("phone_no", "9876543210");
intnt.putExtra("contact_name", "Test User");
intnt.putExtra("id", "1234");
ctx.startActivity(intnt);
} catch (Exception e) {
e.printStackTrace();
}
}
}
Ниже приведен MyActivityClass
package com.apartmentapp;
import android.app.Activity;
import android.os.Bundle;
import android.view.Window;
import android.view.WindowManager;
import android.widget.FrameLayout;
import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;
import androidx.fragment.app.Fragment;
import com.facebook.hermes.reactexecutor.HermesExecutorFactory;
import com.facebook.react.BuildConfig;
import com.facebook.react.PackageList;
import com.facebook.react.ReactInstanceManager;
import com.facebook.react.ReactPackage;
import com.facebook.react.ReactRootView;
import com.facebook.react.common.LifecycleState;
import com.facebook.react.modules.core.DefaultHardwareBackBtnHandler;
import com.facebook.soloader.SoLoader;
import java.util.List;
public class MyActivity extends Activity implements DefaultHardwareBackBtnHandler {
private Window wind;
private ReactRootView mReactRootView;
private ReactInstanceManager mReactInstanceManager;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
requestWindowFeature(Window.FEATURE_NO_TITLE);
this.setFinishOnTouchOutside(true);
super.onCreate(savedInstanceState);
SoLoader.init(this, false);
mReactRootView = new ReactRootView(this);
List<ReactPackage> packages = new PackageList(getApplication()).getPackages();
mReactInstanceManager = ReactInstanceManager.builder()
.setApplication(getApplication())
.setCurrentActivity(this)
.setBundleAssetName("index.android.bundle")
.setJSMainModulePath("index")
.addPackages(packages)
.setUseDeveloperSupport(BuildConfig.DEBUG)
.setInitialLifecycleState(LifecycleState.RESUMED)
.setJavaScriptExecutorFactory(new HermesExecutorFactory())
.build();
mReactRootView.startReactApplication(mReactInstanceManager, "AlertPopupFragment", null);
setContentView(mReactRootView);
setContentView(R.layout.dialog);
FrameLayout alertPopUpFragment = findViewById(R.id.alertPopUpFragment);
alertPopUpFragment.addView(mReactRootView);
}
private Bundle getLaunchOptions(String message) {
Bundle initialProperties = new Bundle();
initialProperties.putString("message", message);
return initialProperties;
}
@Override
protected void onResume() {
// TODO Auto-generated method stub
super.onResume();
wind = this.getWindow();
wind.addFlags(WindowManager.LayoutParams.FLAG_DISMISS_KEYGUARD);
wind.addFlags(WindowManager.LayoutParams.FLAG_SHOW_WHEN_LOCKED);
wind.addFlags(WindowManager.LayoutParams.FLAG_TURN_SCREEN_ON);
wind.addFlags(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT);
wind.addFlags(WindowManager.LayoutParams.TYPE_SYSTEM_OVERLAY);
}
@Override
public void invokeDefaultOnBackPressed() {
}
}
Я также пытался решить эту проблему, установив MyActivity как MainActivity,
здесь MyActivity определен в файле манифеста Android
<activity
android:name = ".MyActivity"
android:noHistory = "true"
android:taskAffinity = ".MyActivity"
android:theme = "@style/MyActivity"
android:exported = "true">
<intent-filter>
<action android:name = "android.intent.action.MAIN" />
<category android:name = "android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
Пожалуйста, предоставьте решение
По ошибке вполне понятно, в чем проблема и как ее решить:
Current Activity is of incorrect class, expected AppCompatActivity, received MyActivity
На данный момент ваше определение — MyActivity extends Activity
, но React Native, похоже, требует изменить его на MyActivity extends AppCompatActivity
.
Полное имя класса AppCompatActivity
, скорее всего, будет androidx.appcompat.app.AppCompatActivity. Поэтому вам придется добавить импорт в начало файла Java:
import androidx.appcompat.app.AppCompatActivity;