1

私の仕事は、縦向きの場合は「通常の」計算機を、横向きの場合は「技術的な」計算機を作成することです。そのため、最初は両方の向きのインターフェイスを作成し、エミュレーターでテストして動作することを確認しました。

横向きの場合、「res」に「layout-land」フォルダーを作成し、縦向きに使用する同じ名前のxmlファイルを配置しました。私の活動はただ一つ。

縦方向のボタン用に書いたコードは、横方向の同じ ID を持つボタンでも機能するはずですか?

次に、「通常の」電卓用のコードをいくつか書きましたが、正常に動作しますが、向きを変更しようとするとアプリケーションが停止し、LogCat は次のように言います。

横向きの場合、「res」に「layout-land」フォルダーを作成し、縦向きに使用する同じ名前のxmlファイルを配置しました。私の活動はただ一つ。

縦方向のボタン用に書いたコードは、横方向の同じ ID を持つボタンでも機能するはずですか?

ロフキャットは次のように述べています。

09-20 10:10:37.544: D/AndroidRuntime(450): Shutting down VM
09-20 10:10:37.555: W/dalvikvm(450): threadid=1: thread exiting with uncaught exception (group=0x40014760)
09-20 10:10:37.564: E/AndroidRuntime(450): FATAL EXCEPTION: main
09-20 10:10:37.564: E/AndroidRuntime(450): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.calculatorapp/com.example.calculatorapp.MainActivity}: java.lang.NullPointerException
09-20 10:10:37.564: E/AndroidRuntime(450):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1815)
09-20 10:10:37.564: E/AndroidRuntime(450):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1831)
09-20 10:10:37.564: E/AndroidRuntime(450):  at android.app.ActivityThread.access$500(ActivityThread.java:122)
09-20 10:10:37.564: E/AndroidRuntime(450):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1024)
09-20 10:10:37.564: E/AndroidRuntime(450):  at android.os.Handler.dispatchMessage(Handler.java:99)
09-20 10:10:37.564: E/AndroidRuntime(450):  at android.os.Looper.loop(Looper.java:132)
09-20 10:10:37.564: E/AndroidRuntime(450):  at android.app.ActivityThread.main(ActivityThread.java:4123)
09-20 10:10:37.564: E/AndroidRuntime(450):  at java.lang.reflect.Method.invokeNative(Native Method)
09-20 10:10:37.564: E/AndroidRuntime(450):  at java.lang.reflect.Method.invoke(Method.java:491)
09-20 10:10:37.564: E/AndroidRuntime(450):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
09-20 10:10:37.564: E/AndroidRuntime(450):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
09-20 10:10:37.564: E/AndroidRuntime(450):  at dalvik.system.NativeStart.main(Native Method)
09-20 10:10:37.564: E/AndroidRuntime(450): Caused by: java.lang.NullPointerException
09-20 10:10:37.564: E/AndroidRuntime(450):  at com.example.calculatorapp.MainActivity.onCreate(MainActivity.java:127)
09-20 10:10:37.564: E/AndroidRuntime(450):  at android.app.Activity.performCreate(Activity.java:4397)
09-20 10:10:37.564: E/AndroidRuntime(450):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1048)
09-20 10:10:37.564: E/AndroidRuntime(450):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1779)
09-20 10:10:37.564: E/AndroidRuntime(450):  ... 11 more
09-20 10:10:42.074: I/Process(450): Sending signal. PID: 450 SIG: 9

私のアクティビティコードは次のようなものです:

public class MainActivity extends Activity {

    Button btn0, btn1, btn2, btn3, btn4, btn5, btn6, btn7, btn8, btn9, btnDot, btnDel, btnCE, btnC, 
    btnPlus, btnMinus, btnMult, btnDiv, btnEqual, btn1divX, btnPercent, btnSqrt, btnSign, btnMC, btnMR, btnMS, btnMplus, btnMminus;   

    TextView currentView;

    StringBuilder numberStringBuilder;

    double memory;
    boolean memoryIsFull;


    char sign;
    double leftOperand, rightOperand;
    boolean signWasPressedOnce;
    boolean equalsignWasPressedOnce;

    boolean leftOperandIsReady;
    boolean rightOperandIsReady;

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

        numberStringBuilder = new StringBuilder();

        btn0 = (Button)findViewById(R.id.btn0);
        btn1 = (Button)findViewById(R.id.btn1);
......... //other buttons
                btnMS.setEnabled(false);

        currentView = (TextView)findViewById(R.id.display);

        leftOperand = rightOperand = 0;

        signWasPressedOnce = true;
        equalsignWasPressedOnce = true;
        leftOperandIsReady = false;
        rightOperandIsReady = false;
        memoryIsFull = false;

        OnClickListener onClickNumber = new OnClickListener() {

            @Override
            public void onClick(View v) {
                switch(v.getId()) {
                case R.id.btn0:
                    numberStringBuilder.append("0");
                    break;
..............//some other buttons
                btn0.setOnClickListener(onClickNumber);
        btn1.setOnClickListener(onClickNumber);
..............//some other setOnClick opeartions
                OnClickListener onClickOperation = new OnClickListener() {

            @Override
            public void onClick(View v) {
                double valueFromDisplay;
                String currentViewFromDisplay;
                switch(v.getId()) {
                case R.id.btnPlus:
                    if(signWasPressedOnce) 
                        actAsSignWasPressedOnce('+');
                    else 
                        actAsSignWasPressedMoreThanOnce('+');
                    break;
..............//some other buttons
                btnPlus.setOnClickListener(onClickOperation);
        btnMinus.setOnClickListener(onClickOperation);
................// and some methods
4

1 に答える 1

2

考えられる理由は、layout フォルダーの xml ファイルでのみ使用でき、layout-land フォルダーの xml ファイルでは使用できない EditText や TextView などの要素を使用している可能性があります。

そのため、向きを変更すると、レイアウト ファイルにその要素がなく、向きが変わるたびに onCreate が再度呼び出されるため、その ID が見つからず、null ポインター例外がスローされます。

両方のレイアウト xml ファイルを確認してください。それらのいずれかでいくつかの要素が欠落しており、それを MainActivity.java で参照していると思います

あなたのlogcatは明確にそれを言っています、エラーはどこですか-

Caused by: java.lang.NullPointerException 09-20 10:10:37.564: at
android.app.Instrumentation.callActivityOnCreate

それが役立つことを願っています。

于 2013-09-20T10:13:22.327 に答える