gpt4 book ai didi

java - 开始新 Activity 时如何修复连续的 logcat 消息?

转载 作者:行者123 更新时间:2023-11-29 22:54:05 25 4
gpt4 key购买 nike

我正在用 java 创建一个 android 应用程序,并观看了 YouTube channel Android Authority 的教程,他在其中用另一个 java 文件替换了开始 Activity 的布局 .xml 文件。此外, Activity 扩展了 Activity 而不是 AppCompactActivity。我做了所有相同的事情,并试图使用 Intent 和 startActivity(intent) 从这个 Activity 开始另一个 Activity 。然而,这样做会导致 logcat 输出连续的文本流,试图创建一个新的 Activity ,但它永远不会成功,并且屏幕停留在第一个 Activity 上。

我已经尝试启动另一个具有 .xml 布局文件的 Activity ,并且成功了。看起来问题出在 .java 布局文件上。我还没有在网上找到任何显示人们遇到同样问题的信息。

开始上课:

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN);
this.requestWindowFeature(Window.FEATURE_NO_TITLE);
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_SENSOR_LANDSCAPE);
setContentView(new MainMenuView(this));
}

主菜单 View 类:

public MainMenuView(Context context){
super(context);
mContext = context;
activity = (Activity) mContext;
intent = new Intent(activity.getBaseContext(), FileSelect.class);

getHolder().addCallback(this);
thread = new MainThread(getHolder(), this);
setFocusable(true);
}

@Override
public void surfaceCreated(SurfaceHolder holder) {
thread.start();
}

public void newActivity(){
if (thingy){ //assigned true when a button is pressed
thingy = false;
mContext.startActivity(intent);
activity.finish();
}
}

第二类:

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN);
this.requestWindowFeature(Window.FEATURE_NO_TITLE);
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_SENSOR_LANDSCAPE);
setContentView(new FileSelectView(this));
}

FileSelectView 类:

public FileSelectView(Context context){
super(context);
mContext = context;
activity = (Activity) mContext;
getHolder().addCallback(this);

thread = new MainThreadTwo(getHolder(), this);
setFocusable(true);
}

@Override
public void surfaceCreated(SurfaceHolder holder) {
thread.start();
}

MainThread 类(MainThread 和 MainThreadTwo 实际上是相同的):

public class MainThread extends Thread {
private SurfaceHolder surfaceHolder;
private MainMenuView mainMenuView;
private boolean running = true;
private static Canvas canvas;

MainThread(SurfaceHolder surfaceHolder, MainMenuView mainMenuView){
super();
this.surfaceHolder = surfaceHolder;
this.mainMenuView = mainMenuView;
}

@Override
public void run() {
long startTime;
long timeBillis;
long waitTime;
int targetFPS = 30;
long targetTime = 1000 / targetFPS;

while (running){
startTime = System.nanoTime();
canvas = null;

try {
canvas = this.surfaceHolder.lockCanvas();
synchronized(surfaceHolder){
if (mainMenuView != null && canvas != null) {
this.mainMenuView.update();
this.mainMenuView.draw(canvas);
}
if (canvas != null){
surfaceHolder.unlockCanvasAndPost(canvas);
}
if (mainMenuView != null){
this.mainMenuView.newActivity();
}
}
}catch(Exception e){
e.printStackTrace();
}

timeBillis = System.nanoTime() - startTime;
waitTime = targetTime - timeBillis;

if (timeBillis < targetTime) {
try {
this.sleep(waitTime);
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
}

当启动具有 .xml 文件布局的类时,调用 startActivity(intent) 后,logcat 将打印以下几条消息,并且屏幕将更新为新 Activity 。在我使用的设置中,在调用 startActivity(intent) 之后,logcat 不断地交替打印出以下内容:

D/ViewRootImpl@ca0f529[FileSelect]: ThreadedRenderer.create() translucent=false
D/InputTransport: Input channel constructed: fd=78
D/ViewRootImpl@ca0f529[FileSelect]: setView = DecorView@1f110ae[FileSelect] touchMode=true

“fd=”数字加一,并且:

D/ViewRootImpl@3ed1b35[MainMenu]: dispatchAttachedToWindow
D/ViewRootImpl@3ed1b35[MainMenu]: Relayout returned: oldFrame=[0,0][0,0] newFrame=[0,0][1280,800] result=0x1 surface={isValid=false 0} surfaceGenerationChanged=false

如果有人能理解这里发生的事情,那真的很有帮助,如果有人不理解问题的某些部分,我会尝试帮助/改写。为什么这些输出消息不断出现,为什么没有出现新的 Activity ?

最佳答案

您需要在您的 while 内(在您的 MainThread 类中)在达到特定条件后将您的变量 running 设置为 false。您的应用程序已进入无限循环,这就是为什么您的日志中有很多消息并且没有显示 Activity 的原因。

关于java - 开始新 Activity 时如何修复连续的 logcat 消息?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57601129/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com