Как я могу заставить это базовое приложение для примера сервиса Android работать?

#android #android-studio #android-service

#Android #android-studio #android-сервис

Вопрос:

Я новичок в разработке приложений для Android и изучаю сервисы Android. Итак, я создал это базовое приложение, которое демонстрирует сервис, и я просто не могу понять, что не так. Logcat показывает, что он не может найти файл класса MyService. Приложение останавливается, когда я нажимаю кнопку «Пуск». Вот моя программа.

MainActivity.java

 
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 {

    private Button start,stop;

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

        start = findViewById(R.id.start);
        stop = findViewById(R.id.stop);

        start.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                startActivity(new Intent(MainActivity.this, MyService.class));
            }
        });

        stop.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                stopService(new Intent(MainActivity.this, MyService.class));
            }
        });
    }
} 
 

MyService.java

 
import android.app.Service;
import android.content.Intent;
import android.media.MediaPlayer;
import android.os.IBinder;
import android.provider.Settings;

import androidx.annotation.Nullable;

public class MyService extends Service {
    private MediaPlayer player;

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        player = MediaPlayer.create(this, Settings.System.DEFAULT_ALARM_ALERT_URI);
        player.setLooping(true);
        player.start();
        return START_STICKY;
    }

    @Override
    public void onDestroy() {
        super.onDestroy();
        player.stop();
    }

    @Nullable
    @Override
    public IBinder onBind(Intent intent) {
        return null;
    }
}
 

AndroidManifest.xml

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

    <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/Theme.Service_Test">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

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

</manifest>
 

Это logcat:
введите описание изображения здесь

Комментарии:

1. Почему вы запускаете службу с помощью вызова startActivity() . Используйте startService() вместо этого и посмотрите на другие ответы.

Ответ №1:

Вы должны зарегистрировать свою службу в манифесте:

 <service android:enabled="true" android:name="com.my.packagename.MyService" />
 

и запустите службу через:

 startService(new Intent(this, MyService.class));
 

Комментарии:

1. Я уже это сделал. Вы можете проверить файл манифеста.

2. вы запускаете Службу, похожую на действие. startService не startActivity

Ответ №2:

Попробуйте заменить:

 startActivity(new Intent(MainActivity.this, MyService.class));
 

Автор::

 if (Build.VERSION.SDK_INT >= 26) {
    startForegroundService( new Intent(this, MyService.class));
} else {
    startService(new Intent(this, MyService.class));
}
 

Также добавьте в манифест:

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

Службы переднего плана продолжают работать в фоновом режиме, когда экран выключен.

Комментарии:

1. Вы можете использовать ContextCompat.startForegroundService(контекст, намерение). Оно уже обрабатывает, когда вызывать startService и когда вызывать startForegroundService.