启动新 Intent 时 Android 应用程序崩溃

Posted

技术标签:

【中文标题】启动新 Intent 时 Android 应用程序崩溃【英文标题】:Android app crashes when starting a new Intent 【发布时间】:2020-08-08 19:31:13 【问题描述】:

我正在编写一个程序,单击此按钮后将启动另一个程序。

但是,当我单击相应的按钮时,程序强制关闭。

这是代码。

package com.example.pc.multi_functionapp;

import androidx.appcompat.app.AppCompatActivity;

import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;

public class MainActivity extends AppCompatActivity 

    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Button button1 = (Button)findViewById(R.id.button_1);
        Button button2 = (Button)findViewById(R.id.button_2);

        button1.setOnClickListener(new View.OnClickListener() 
            @Override
            public void onClick(View v) 
                Intent int1 = new Intent(MainActivity.this, Accelerometer.class);
                startActivity(int1);
            
        );
        button2.setOnClickListener(new View.OnClickListener() 
            @Override
            public void onClick(View v) 
                Intent int2 = new Intent(MainActivity.this, Locator.class);
                startActivity(int2);
            
        );
    

这是 XML 代码

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout

    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_
    android:layout_
    android:orientation="vertical"
    android:padding="16dp"
    android:layout_gravity="center_horizontal"

    tools:context=".MainActivity">

    <Button
        android:layout_
        android:layout_
        android:layout_gravity="center_horizontal"
        android:id="@+id/button_1"
        android:text="Android Accelerometer"
        />
    <Button
        android:layout_
        android:layout_
        android:layout_gravity="center_horizontal"
        android:id="@+id/button_2"
        android:text="Android Current Location"
        />
    </LinearLayout>

这是 android 清单代码

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

    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".Locator"></activity>
        <activity android:name=".Accelerometer" />
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

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

</man

对于程序本身,如果我一个一个运行,Accelerometer 和 Locator 可以正常工作。

我是故意创建这个程序的,这两个程序可以在一个应用程序中运行,无需在不同的应用程序中打开它。

我希望在单击第一个按钮后,加速度计程序将启动,当我单击第二个按钮时,Locator 程序将启动。

发生的事情是,当我单击它时,程序会强制关闭。

请帮助我,以便按钮在单击时正常工作。

编辑: 加速度计代码

package com.example.pc.multi_functionapp;

import android.content.Context;
import android.hardware.Sensor;
import android.hardware.SensorEvent;
import android.hardware.SensorEventListener;
import android.hardware.SensorManager;
import android.os.Bundle;
import android.util.Log;
import android.widget.TextView;

import androidx.appcompat.app.AppCompatActivity;

public class Accelerometer extends AppCompatActivity implements SensorEventListener 
    private static final String TAG = "MainActivity";
    private SensorManager sensorManager;
    Sensor accelerometer;

    TextView xValue, yValue, zValue;

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

        xValue = (TextView) findViewById(R.id.xValue);
        yValue = (TextView) findViewById(R.id.yValue);
        zValue = (TextView) findViewById(R.id.zValue);
        Log.d(TAG, "onCreate: initializing Sensor Services");
        sensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE);

        accelerometer = sensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
        sensorManager.registerListener(Accelerometer.this, accelerometer, SensorManager.SENSOR_DELAY_NORMAL);
        Log.d(TAG, "onCreate: Registered accelerometer listener");
    

    @Override
    public void onAccuracyChanged(Sensor sensor, int accuracy) 

    

    @Override
    public void onSensorChanged(SensorEvent sensorEvent) 
        Log.d(TAG, "onSensorChanged: X: " + sensorEvent.values[0] + "Y: " + sensorEvent.values[1] + "Z: " + sensorEvent.values[2]);

        xValue.setText("xValue: " + sensorEvent.values[0]);
        yValue.setText("yValue: " + sensorEvent.values[1]);
        zValue.setText("xValue: " + sensorEvent.values[2]);
    

定位码

package com.example.pc.multi_functionapp;

import android.Manifest;
import android.content.pm.PackageManager;
import android.location.Address;
import android.location.Geocoder;
import android.location.Location;
import android.os.Bundle;
import android.text.html;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;

import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;

import com.google.android.gms.location.FusedLocationProviderClient;
import com.google.android.gms.location.LocationServices;
import com.google.android.gms.tasks.OnCompleteListener;
import com.google.android.gms.tasks.Task;

import java.io.IOException;
import java.util.List;
import java.util.Locale;

public class Locator extends AppCompatActivity 
    TextView textView1, textView2, textView3, textView4, textView5;
    FusedLocationProviderClient fusedLocationProviderClient;
    Button btLocation;
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        btLocation = findViewById(R.id.bt_location);
        textView1 = findViewById(R.id.text_view1);
        textView2 = findViewById(R.id.text_view2);
        textView3 = findViewById(R.id.text_view3);
        textView4 = findViewById(R.id.text_view4);
        textView5 = findViewById(R.id.text_view5);

        fusedLocationProviderClient = LocationServices.getFusedLocationProviderClient(this);

        btLocation.setOnClickListener(new View.OnClickListener() 
            @Override
            public void onClick(View v) 
                if (ActivityCompat.checkSelfPermission(Locator.this
                        , Manifest.permission.ACCESS_FINE_LOCATION) == PackageManager.PERMISSION_GRANTED)
                    getLocation();
                
                else 
                    ActivityCompat.requestPermissions(Locator.this
                            , new String[]Manifest.permission.ACCESS_FINE_LOCATION, 44);
                
            
        );
    
    private void getLocation() 
        fusedLocationProviderClient.getLastLocation().addOnCompleteListener(new OnCompleteListener<Location>() 
            @Override
            public void onComplete(@NonNull Task<Location> task) 
                Location location = task.getResult();
                if (location != null)
                    try 
                        Geocoder geocoder = new Geocoder(Locator.this, Locale.getDefault());
                        List<Address> addresses = geocoder.getFromLocation(location.getLatitude(), location.getLongitude(), 1 );
                        textView1.setText(Html.fromHtml("<font color='#6200EE'><B>Latitude :</b><br></font>" + addresses.get(0).getLatitude()));
                        textView2.setText(Html.fromHtml("<font color='#6200EE'><B>Longitude :</b><br></font>" + addresses.get(0).getLongitude()));
                        textView3.setText(Html.fromHtml("<font color='#6200EE'><B>Country Name :</b><br></font>" + addresses.get(0).getCountryName()));
                        textView4.setText(Html.fromHtml("<font color='#6200EE'><B>Locality :</b><br></font>" + addresses.get(0).getLocality()));
                        textView5.setText(Html.fromHtml("<font color='#6200EE'><B>Address :</b><br></font>" + addresses.get(0).getAddressLine(0)));
                     catch (IOException e) 
                        e.printStackTrace();
                    
                
            
        );
    

Before CLicked

After Clicked

【问题讨论】:

在您启动 Intent 时从 Android Studio 发布 RUN 选项卡的屏幕截图。有什么错误吗? @Dharmaraj 我在那里发布了编辑,抱歉我的代表不到 10,所以我还不能发布图片。相反,我发布了链接 【参考方案1】:

哦,你的错误很简单。

我认为您已经复制了活动,而您忘记更改所有活动的setContentView() 中的布局。它们都是R.layout.activity_main,因此应用程序正在启动activity_main.xml,但视图正在从它们的真实资源中获取findViewById()

【讨论】:

太棒了,现在可以使用了,谢谢。我没注意到。呵呵。【参考方案2】:

崩溃可能是由于两个原因。 确保所有活动都有单独的布局。 确保您的活动已添加到 AndroidManifest.xml 文件中。

【讨论】:

以上是关于启动新 Intent 时 Android 应用程序崩溃的主要内容,如果未能解决你的问题,请参考以下文章

用于在Android中启动新活动的多个Intent标志

Android-----Intent中通过startActivity(Intent intent )显式启动新的Activity

Android(Intent 学习)

Android开发- Intent和Broadcast Receiver

android 通用 Intent

Android12.2 利用Intent启动和关闭Activity