繁体   English   中英

在屏幕方向更改时显示Logcat消息

[英]Showing Logcat message on screen orientation change

我想知道何时使用Logcat在我的设备上更改方向,但没有显示任何输出(我正在使用Android Studio)。 我已经将screenSize属性添加到我的AndroidManifest.xml但这不能解决问题。 以下是我的清单文件:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.danishrehman.orientationchangenotification" >

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity

            android:name=".MainActivity"
            android:label="@string/app_name"
            android:configChanges="orientation|screenSize"

            >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

这是我的Java代码:

package com.example.danishrehman.orientationchangenotification;

import android.app.Activity;
import android.content.res.Configuration;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.util.Log;


public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

    @Override
    public void onConfigurationChanged(Configuration newConfig) {
        super.onConfigurationChanged(newConfig);
        if(newConfig.orientation==Configuration.ORIENTATION_LANDSCAPE)
        {
            Log.d("LIFECYCLE","Welcome to Landscape Orientation");
        }
        else if (newConfig.orientation==Configuration.ORIENTATION_PORTRAIT)
        {
            Log.d("LIFECYCLE","Welcome to Portrait Orientation");
        }
    }
}

我使用android:configChanges="orientation|screenSize"尝试了您的代码,并且可以在Android Studio Logcat中看到正确的日志记录。 听起来很傻,但是您可以检查在Logcat窗口中选择的日志级别吗? 就像在代码中一样,您使用过Log.d(...) ,只有在Logcat窗口中将Log Level选择为VerboseDebug它才应该可见。

在此处输入图片说明

您可以检查是否已重新创建活动,这是:屏幕方向已更改。

public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        if (savedInstanceState != null) {
            //probably orientation change
            Log.d("LIFECYCLE", "Orientation has changed!");
        }
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM