Android 는 BroadcastReceiver 를 사용 하여 강제 오프라인 을 실현 합 니 다.
새 항목 Broadcast 03.강제 오프라인 기능 은 모든 활동 을 닫 고 로그 인 인터페이스 로 돌아 가 야 합 니 다.그래서 모든 활동 을 관리 하기 위해 Activity Collector 클래스 를 만 듭 니 다:
public class ActivityCollector {
public static List<Activity> activities = new ArrayList<Activity>();
public static void addActivity(Activity activity) {
activities.add(activity);
}
public static void removeActivity(Activity activity) {
activities.remove(activity);
}
public static void finishAll() {
for (Activity activity : activities) {
if (!activity.isFinishing()) {
activity.finish();
}
}
}
}
이 클래스 에 서 는 이벤트 추가,이벤트 제거,모든 활동 닫 기 등 세 가지 방법 을 정의 합 니 다.그리고 BaseActivity 클래스 를 다른 모든 종류의 부모 클래스 로 새로 만 듭 니 다.
public class BaseActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
ActivityCollector.addActivity(this);
}
@Override
protected void onDestroy() {
super.onDestroy();
ActivityCollector.removeActivity(this);
}
}
BaseActivity 클래스 에 서 는 Activity Collector 류 의 addActivity()와 removeActivity()방법 을 호출 하여 다른 클래스 가 BaseActivity 류 를 계승 할 때 이 두 가지 방법 을 자동 으로 다시 씁 니 다.로그 인 인터페이스의 레이아웃 login.xml 작성:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginLeft="10dp"
android:gravity="center"
android:text="account:"
android:textSize="16dp" />
<EditText
android:id="@+id/et_account"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_margin="10dp"
android:layout_weight="1"
android:hint="please input account" />
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:layout_marginLeft="10dp"
android:gravity="center"
android:text="password:"
android:textSize="16dp" />
<EditText
android:id="@+id/et_password"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_margin="10dp"
android:layout_weight="1"
android:hint="please input password"
android:inputType="numberPassword" />
</LinearLayout>
<Button
android:id="@+id/bt_login"
android:layout_width="120dp"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:text="Login" />
</LinearLayout>
로그 인 활동 을 작성 합 니 다.새 LoginActivity 는 BaseActivity 에서 계승 하여 로그 인 논 리 를 실현 합 니 다.계 정 이 admin 이 고 비밀번호 가 123456 일 때 만 로그 인 에 성공 할 수 있 습 니 다.
public class LoginActivity extends BaseActivity {
private EditText accountEdit;
private EditText passwordEdit;
private Button login;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.login);
accountEdit = (EditText) findViewById(R.id.et_account);
passwordEdit = (EditText) findViewById(R.id.et_password);
login = (Button) findViewById(R.id.bt_login);
login.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
String account = accountEdit.getText().toString();
String password = passwordEdit.getText().toString();
if ("admin".equals(account) && "123456".equals(password)) {
Intent intent = new Intent(LoginActivity.this, MainActivity.class);
startActivity(intent);
finish();
} else {
Toast.makeText(LoginActivity.this, " , ", Toast.LENGTH_SHORT).show();
}
}
});
}
}
로그 인 성공 하면 MainActivity 메 인 화면 에 들 어 갑 니 다.저 희 는 activitymain 레이아웃 에 Button 을 추가 하고 이 단 추 를 누 르 면 강제 오프라인 방송 을 보 냅 니 다.
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.beijing.broadcast03.MainActivity">
<Button
android:id="@+id/bt_force_offline"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="Send force offline broadcast" />
</RelativeLayout>
MainActivity 인터페이스 에서 단 추 를 누 르 면 라디오 를 보 내 는 논리:
public class MainActivity extends AppCompatActivity {
private Button forceOffline;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
forceOffline = (Button) findViewById(R.id.bt_force_offline);
forceOffline.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent intent = new Intent("com.beijing.broadcast03.FORCE_OFFLINE");
sendBroadcast(intent);
}
});
}
}
여기에 com.beijing.broadcast 03.FORCE 라 는 값 을 보 냈 습 니 다.오프라인 방송.라디오 수신 자 Force OfflineReceiver 를 만 들 고 BroadcastReceiver 를 계승 합 니 다.Force OfflineReceiver 는 라디오 를 받 으 면 강제 오프라인 의 목적 을 달성 하기 위해 대화 상 자 를 팝 업 합 니 다.
public class ForceOfflineReceiver extends BroadcastReceiver {
@Override
public void onReceive(final Context context, Intent intent) {
AlertDialog.Builder dialogBuilder = new AlertDialog.Builder(context);
dialogBuilder.setTitle("Warning");
dialogBuilder.setMessage(" , 。");
dialogBuilder.setCancelable(false);
dialogBuilder.setPositiveButton("OK", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
ActivityCollector.finishAll();// Activity
Intent intent = new Intent(context, LoginActivity.class);
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
context.startActivity(intent);// LoginActivity
}
});
AlertDialog alertDialog = dialogBuilder.create();
alertDialog.getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT);// AlertDialog ,
alertDialog.show();
}
}
여기 서 AlertDialog.Builder 를 통 해 대화 상 자 를 만 듭 니 다.setCancelable()방법 을 사용 하여 대화 상 자 를 취소 할 수 없 는 것 으로 설정 해 야 합 니 다.(리 턴 키 를 누 르 면 대화 상 자 를 종료 할 수 없습니다.)이 어 setPositiveButton()방법 으로 대화 상자 에 확인 단 추 를 등록 하고 확인 단 추 를 누 르 면 Activity Collector 의 finishAll()방법 으로 모든 활동 을 없 애고 LoginActivity 인터페이스 에 다시 들 어 갑 니 다.라디오 수신 자 에서 이 벤트 를 시작 하기 때문에 인 텐트 에 FLAG 를 꼭 붙 여야 합 니 다.ACTIVITY_NEW_TASK 라 는 로고.마지막 으로 대화 상자 의 종 류 를 TYPE 로 설정 해 야 합 니 다.SYSTEM_ALERT,그렇지 않 으 면 라디오 수신 자 에 게 대화 상 자 를 꺼 낼 수 없습니다.현재 AndroidManifest.xml 에 설 정 된 작업 이 남아 있 습 니 다:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.beijing.broadcast03">
<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".BaseActivity" />
<activity android:name=".LoginActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity android:name=".MainActivity"/>
<receiver android:name=".ForceOfflineReceiver">
<intent-filter>
<action android:name="com.beijing.broadcast03.FORCE_OFFLINE" />
</intent-filter>
</receiver>
</application>
</manifest>
세 가지 주의 할 점 이 있 습 니 다.우선,Force Offline Receiver 에서 시스템 단계 의 대화 상 자 를 꺼 냈 습 니 다.Android.permission.SYSTEM 을 설명해 야 합 니 다.ALERT_WINDOW 권한;그 다음 에 LoginActivity 를 주요 활동 으로 등록 해 야 한다.마지막 으로 Force OfflineReceiver 를 등록 하고 com.beijing.broadcast 03.FORCE 를 받 도록 지정 합 니 다.오프라인 방송.현재 프로그램 을 실행 하여 효 과 를 보고 먼저 로그 인 인터페이스 에 들 어가 계 정과 비밀 번 호 를 입력 할 수 있 습 니 다.
계 정 admin 과 비밀 번 호 를 123456 입력 한 후 Login 단 추 를 누 르 면 메 인 화면 에 들 어 갑 니 다.
라디오 를 보 내 는 버튼 을 계속 누 르 면 라디오 가 나온다.Force Offline Receiver 가 이 방송 을 받 으 면 강제 오프라인 상태 임 을 알 리 는 대화 상자 가 나타 납 니 다.
이 때 사용 자 는 더 이상 조작 을 할 수 없고 확인 단 추 를 누 르 고 다시 로그 인 인터페이스 로 돌아 갈 수 있 습 니 다.이로써 방송 수신 자 를 통 해 오프라인 을 강제 하 겠 다 는 목 표 는 달성 됐다.
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Bitrise에서 배포 어플리케이션 설정 테스트하기이 글은 Bitrise 광고 달력의 23일째 글입니다. 자체 또는 당사 등에서 Bitrise 구축 서비스를 사용합니다. 그나저나 며칠 전 Bitrise User Group Meetup #3에서 아래 슬라이드를 발표했...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.