Как заблокировать / разблокировать все входящие / исходящие звонки / текстовые сообщения в Android?
Я разрабатываю андроид-приложение для подростков, они не могут делать / принимать любые входящие / исходящие звонки / текстовые сообщения во время вождения, а также они могут менять статус, независимо от того, за рулем он или нет. В моем приложении я хочу обрабатывать обе ситуации Блокировать / разблокировать входящие / исходящие звонки / текстовые сообщения. Если у вас есть идеи, связанные с этим вопросом, пожалуйста, поделитесь со мной.
Благодарю.
3 ответа
После 8 часов НИОКР я нашел собственное решение для моего вопроса:
manifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.deactivateimservicedemo"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="19" />
<uses-feature android:name="android.hardware.telephony" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.PROCESS_OUTGOING_CALLS" />
<uses-permission android:name="android.permission.CALL_PHONE" />
<!-- For Incoming Text messages -->
<uses-permission android:name="android.permission.RECEIVE_SMS" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name="com.example.deactivateimservicedemo.MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
activity_main.xml
<LinearLayout 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:orientation="horizontal"
tools:context="com.example.deactivateimservicedemo.MainActivity$PlaceholderFragment" >
<Button
android:id="@+id/btnActivate"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Activate" />
<Button
android:id="@+id/btnDeactivate"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Deactivate" />
</LinearLayout>
MainActivity.java
package com.example.deactivateimservicedemo;
import java.lang.reflect.Method;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.telephony.TelephonyManager;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import com.android.internal.telephony.ITelephony;
public class MainActivity extends ActionBarActivity {
private Button btnActivate, btnDeactivate;
private BroadcastReceiver receiver;
private IntentFilter filter;
private boolean isReceiverRegistered;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
btnActivate = (Button) findViewById(R.id.btnActivate);
btnActivate.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View arg0) {
/*Register Receiver*/
registerReceiver(receiver, filter);
isReceiverRegistered = true;
}
});
btnDeactivate = (Button) findViewById(R.id.btnDeactivate);
btnDeactivate.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
/*UnRegister Receiver*/
if(isReceiverRegistered){
Log.i("Receiver is", "Register");
unregisterReceiver(receiver);
}else {
Log.i("Receiver is", "Not Register");
}
}
});
filter = new IntentFilter();
filter.addAction("android.intent.action.PHONE_STATE");
filter.addAction("android.provider.Telephony.SMS_RECEIVED");
receiver = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
Log.i("Intent Action", action);
if(intent!=null){
if(action.equals("android.intent.action.PHONE_STATE")){
try {
TelephonyManager tm = (TelephonyManager) context
.getSystemService(Context.TELEPHONY_SERVICE);
Class<?> c = Class.forName(tm.getClass().getName());
Method m = c.getDeclaredMethod("getITelephony");
m.setAccessible(true);
com.android.internal.telephony.ITelephony telephonyService = (ITelephony) m
.invoke(tm);
telephonyService.endCall();
} catch (Exception e) {
Log.e("Exception", e.toString());
}
}else if(action.equals("android.provider.Telephony.SMS_RECEIVED")){
Bundle extras = intent.getExtras();
if (extras != null) {
abortBroadcast();
}
}
}
}
};
}
@Override
protected void onDestroy() {
btnDeactivate.performClick();
super.onDestroy();
}
}
Вот и все.
Используйте новый Activity API для определения, когда пользователь находится в режиме вождения.
Чтобы заблокировать входящий вызов, вам нужно прослушать события TelephonyManager.CALL_STATE_RINGING и прекратить входящий вызов. Смотрите пример кода здесь
Я не уверен, что вы имеете в виду, блокируя входящие SMS. Вы хотите удалить прибывающие смс, когда пользователь за рулем (плохая идея)? Если так - прочитайте это. Этот метод должен работать как минимум для Android < 4.4. Не забудьте назначить наивысший приоритет вашему SMS-получателю.
Есть несколько попыток. Используйте GooglePlayServices Drive Api https://developer.android.com/google/play-services/drive.html
Тогда вы можете проверить скорость. Если это выше 6 км / ч, вы можете зарегистрировать телефонию и SMS BroadcastReceiver.
С приемниками вы можете обрабатывать поступающие вещи. Вот как это должно быть сделано.
Другой попыткой является проверка GPS Position с PositionChance, например, 10 метров, вычисление времени между прыжками с места, и, если оно составляет менее 2 секунд для 10 метров, вы также можете включить это, используя AlarmManager, который блокирует материал как минимум на 30 минут.
Другая попытка - проверка CellID (позиция) и проверка того, как часто он меняется на новый CellID (позиция).
http://www.devx.com/wireless/Article/40524 Это хороший пример того, как получить местоположение с помощью CellID