Полезные примеры Android

Полезные примеры Android
Android — Услуги «Services «

Служба является компонентом , который работает в фоновом режиме , чтобы выполнять длительные операции без необходимости взаимодействовать с пользователем , и это работает , даже если приложение будет уничтожено. По сути, служба может принимать два состояния —

Sr.No. Состояние и описание
1

Начал

Служба запускается, когда компонент приложения, например действие, запускает ее, вызывая startService () . После запуска служба может работать в фоновом режиме неограниченное время, даже если компонент, запустивший ее, будет уничтожен.

2

Связаны

Служба привязывается, когда компонент приложения связывается с ней с помощью вызова bindService () . Привязанная служба предлагает интерфейс клиент-сервер, который позволяет компонентам взаимодействовать со службой, отправлять запросы, получать результаты и даже делать это между процессами с межпроцессным взаимодействием (IPC).

У службы есть методы обратного вызова жизненного цикла, которые вы можете реализовать для отслеживания изменений в состоянии службы, и вы можете выполнять работу на соответствующем этапе. Следующая диаграмма слева показывает жизненный цикл, когда служба создается с помощью startService (), а диаграмма справа показывает жизненный цикл, когда служба создается с помощью bindService (): (изображение любезно предоставлено: android.com)

Жизненный цикл службы Android

Чтобы создать службу, вы создаете класс Java, который расширяет базовый класс службы или один из его существующих подклассов. Сервис базовый класс определяет различные методы обратного вызова и наиболее важные из них приведены ниже. Вам не нужно реализовывать все методы обратного вызова. Однако важно понимать каждый из них и реализовывать те, которые гарантируют, что ваше приложение ведет себя так, как ожидают пользователи.

Sr.No. Обратный звонок и описание
1

onStartCommand ()

Система вызывает этот метод, когда другой компонент, например действие, запрашивает запуск службы, вызывая startService () . Если вы реализуете этот метод, вы обязаны остановить службу, когда ее работа будет завершена, путем вызова методов stopSelf () или stopService () .

2

отвязать ()

Система вызывает этот метод, когда другой компонент хочет выполнить привязку к службе, вызвав bindService () . Если вы реализуете этот метод, вы должны предоставить интерфейс, который клиенты используют для связи со службой, путем возврата объекта IBinder . Вы всегда должны реализовывать этот метод, но если вы не хотите разрешать привязку, вы должны вернуть null .

3

onUnbind ()

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

4

onRebind ()

Система вызывает этот метод, когда новые клиенты подключились к службе, после того, как она ранее была уведомлена о том, что все отключились в ее onUnbind (Intent) .

5

onCreate ()

Система вызывает этот метод при первом создании службы с помощью onStartCommand () или onBind () . Этот вызов требуется для выполнения одноразовой настройки.

6

onDestroy ()

Система вызывает этот метод, когда служба больше не используется и уничтожается. Ваш сервис должен реализовать это для очистки любых ресурсов, таких как потоки, зарегистрированные слушатели, приемники и т. Д.

Следующий каркасный сервис демонстрирует каждый из методов жизненного цикла —

package com.tutorialspoint;
import android.app.Service;
import android.os.IBinder;
import android.content.Intent;
import android.os.Bundle;
public class HelloService extends Service {
/** indicates how to behave if the service is killed */
int mStartMode;
/** interface for clients that bind */
IBinder mBinder;     
/** indicates whether onRebind should be used */
boolean mAllowRebind;
/** Called when the service is being created. */
@Override
public void onCreate() {
}
/** The service is starting, due to a call to startService() */
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
return mStartMode;
}
/** A client is binding to the service with bindService() */
@Override
public IBinder onBind(Intent intent) {
return mBinder;
}
/** Called when all clients have unbound with unbindService() */
@Override
public boolean onUnbind(Intent intent) {
return mAllowRebind;
}
/** Called when a client is binding to the service with bindService()*/
@Override
public void onRebind(Intent intent) {
}
/** Called when The service is no longer used and is being destroyed */
@Override
public void onDestroy() {
}
}

пример

Этот пример проведет вас через простые шаги, чтобы показать, как создать свою собственную службу Android. Выполните следующие шаги, чтобы изменить приложение Android, которое мы создали в главе « Пример Hello World» :

Шаг Описание
1 Вы будете использовать Android StudioIDE для создания Android-приложения и назовете его My Application в пакете com.example.tutorialspoint7.myapplication, как описано в главе « Пример Hello World» .
2 Измените файл основного действия MainActivity.java, добавив методы startService () и stopService () .
3 Создайте новый java-файл MyService.java в пакете com.example.My Application . В этом файле будут реализованы методы, связанные с сервисом Android.
4 Определите свою службу в файле AndroidManifest.xml с помощью тега <service … />. Приложение может иметь одну или несколько служб без каких-либо ограничений.
5 Измените содержимое файла res / layout / activity_main.xml по умолчанию, чтобы включить две кнопки в линейный макет.
6 Нет необходимости изменять какие-либо константы в файле res / values ​​/ strings.xml . Студия Android позаботится о строковых значениях
7 Запустите приложение, чтобы запустить эмулятор Android и проверить результат изменений, внесенных в приложение.

Ниже приводится содержимое измененного файла основного действия MainActivity.java . Этот файл может включать каждый из основных методов жизненного цикла. Мы добавили методы startService () и stopService () для запуска и остановки службы.

package com.example.tutorialspoint7.myapplication;
import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.os.Bundle;
import android.app.Activity;
import android.util.Log;
import android.view.View;
public class MainActivity extends Activity {
String msg = "Android : ";
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Log.d(msg, "The onCreate() event");
}
public void startService(View view) {
startService(new Intent(getBaseContext(), MyService.class));
}
// Method to stop the service
public void stopService(View view) {
stopService(new Intent(getBaseContext(), MyService.class));
}
}

Ниже приводится содержимое MyService.java . Этот файл может иметь реализацию одного или нескольких методов, связанных с Сервисом, в зависимости от требований. Сейчас мы собираемся реализовать только два метода onStartCommand () и onDestroy ()

package com.example.tutorialspoint7.myapplication;
import android.app.Service;
import android.content.Intent;
import android.os.IBinder;
import android.support.annotation.Nullable;
import android.widget.Toast;
/**
* Created by TutorialsPoint7 on 8/23/2016.
*/
public class MyService extends Service {
@Nullable
@Override
public IBinder onBind(Intent intent) {
return null;
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
// Let it continue running until it is stopped.
Toast.makeText(this, "Service Started", Toast.LENGTH_LONG).show();
return START_STICKY;
}
@Override
public void onDestroy() {
super.onDestroy();
Toast.makeText(this, "Service Destroyed", Toast.LENGTH_LONG).show();
}
}

Далее будет измененное содержимое файла AndroidManifest.xml . Здесь мы добавили тег <service … />, чтобы включить нашу службу —

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.tutorialspoint7.myapplication">
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<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" />
</application>
</manifest>

Ниже будет содержимое файла res / layout / activity_main.xml, чтобы включить две кнопки:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Example of services"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:textSize="30dp" />
<TextView
android:id="@+id/textView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Tutorials point "
android:textColor="#ff87ff09"
android:textSize="30dp"
android:layout_above="@+id/imageButton"
android:layout_centerHorizontal="true"
android:layout_marginBottom="40dp" />
<ImageButton
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/imageButton"
android:src="@drawable/abc"
android:layout_centerVertical="true"
android:layout_centerHorizontal="true" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/button2"
android:text="Start Services"
android:onClick="startService"
android:layout_below="@+id/imageButton"
android:layout_centerHorizontal="true" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Stop Services"
android:id="@+id/button"
android:onClick="stopService"
android:layout_below="@+id/button2"
android:layout_alignLeft="@+id/button2"
android:layout_alignStart="@+id/button2"
android:layout_alignRight="@+id/button2"
android:layout_alignEnd="@+id/button2" />
</RelativeLayout>

Попробуем запустить наш модифицированный Hello World! приложение, которое мы только что изменили. Я предполагаю, что вы создали свой AVD при настройке среды. Чтобы запустить приложение из студии Android, откройте один из файлов активности вашего проекта и щелкните Значок запуска Android Studioзначок « Выполнить» на панели инструментов. Android Studio устанавливает приложение на ваш AVD и запускает его, и если с вашей настройкой и приложением все в порядке, оно отобразит следующее окно эмулятора —

Демонстрация службы Android

Теперь, чтобы запустить вашу службу, давайте нажмем кнопку Start Service , это запустит службу, и в соответствии с нашим программированием в методе onStartCommand () в нижней части симулятора появится сообщение Service Started , как показано ниже:

Запуск службы Android

Чтобы остановить службу, вы можете нажать кнопку «Остановить службу».

Select the fields to be shown. Others will be hidden. Drag and drop to rearrange the order.
  • Image
  • SKU
  • Rating
  • Price
  • Stock
  • Availability
  • Add to cart
  • Description
  • Content
  • Weight
  • Dimensions
  • Additional information
  • Attributes
  • Custom attributes
  • Custom fields
Click outside to hide the compare bar
Compare