ホームボタンを停止または上書きできないことはわかっています。ホームボタンをクリックしたときの方法で拡張する方法はありますか、ホームボタンの機能を妨げることなくカウンタを増やす必要があります。アンドロイドでホームボタンをクリックしたときにカウンタを追加できますか?
1
A
答えて
0
は、それが動作しますが、次のコードを試してみてください。
HomeWatcher mHomeWatcher = new HomeWatcher(this);
mHomeWatcher.setOnHomePressedListener(new OnHomePressedListener() {
@Override
public void onHomePressed() {
// do something here...
}
@Override
public void onHomeLongPressed() {
}
});
mHomeWatcher.startWatch();
HomeWatcherクラス
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.util.Log;
public class HomeWatcher {
static final String TAG = "hg";
private Context mContext;
private IntentFilter mFilter;
private OnHomePressedListener mListener;
private InnerRecevier mRecevier;
public HomeWatcher(Context context) {
mContext = context;
mFilter = new IntentFilter(Intent.ACTION_CLOSE_SYSTEM_DIALOGS);
}
public void setOnHomePressedListener(OnHomePressedListener listener) {
mListener = listener;
mRecevier = new InnerRecevier();
}
public void startWatch() {
if (mRecevier != null) {
mContext.registerReceiver(mRecevier, mFilter);
}
}
public void stopWatch() {
if (mRecevier != null) {
mContext.unregisterReceiver(mRecevier);
}
}
class InnerRecevier extends BroadcastReceiver {
final String SYSTEM_DIALOG_REASON_KEY = "reason";
final String SYSTEM_DIALOG_REASON_GLOBAL_ACTIONS = "globalactions";
final String SYSTEM_DIALOG_REASON_RECENT_APPS = "recentapps";
final String SYSTEM_DIALOG_REASON_HOME_KEY = "homekey";
@Override
public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
if (action.equals(Intent.ACTION_CLOSE_SYSTEM_DIALOGS)) {
String reason = intent.getStringExtra(SYSTEM_DIALOG_REASON_KEY);
if (reason != null) {
Log.e(TAG, "action:" + action + ",reason:" + reason);
if (mListener != null) {
if (reason.equals(SYSTEM_DIALOG_REASON_HOME_KEY)) {
mListener.onHomePressed();
} else if (reason.equals(SYSTEM_DIALOG_REASON_RECENT_APPS)) {
mListener.onHomeLongPressed();
}
}
}
}
}
}
}
OnHomePressedインタフェース
public interface OnHomePressedListener {
public void onHomePressed();
public void onHomeLongPressed();
}
+0
それは私のために完全に動作します –
3
これが役立ちます。そのためには、サービスとブロードキャストレシーバーを使用する必要があります。
MainActivty.java
public class MainActivity extends AppCompatActivity {
private Button btn_startservice;
private Button btn_stopservice;
private TextView tv_servicecounter;
ServiceDemo myService;
boolean isBound;
BroadcastReceiver broadcastRec = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
int datapassed = intent.getIntExtra("value", 0);
tv_servicecounter.setText(String.valueOf(datapassed));
}
};
@RequiresApi(api = Build.VERSION_CODES.JELLY_BEAN)
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
tv_servicecounter = (TextView) findViewById(R.id.tv_activity_main_count);
btn_startservice = (Button) findViewById(R.id.btn_activity_main_startservices);
btn_stopservice = (Button) findViewById(R.id.btn_activity_main_stopservices);
btn_startservice.setOnClickListener(
new View.OnClickListener() {
@RequiresApi(api = Build.VERSION_CODES.JELLY_BEAN_MR1)
@Override
public void onClick(View v) {
Intent objIntent = new Intent(MainActivity.this, ServiceDemo.class);
if (!isBound) {
bindService(objIntent, myConnection, Context.BIND_AUTO_CREATE);
isBound = true;
startService(objIntent);
} else {
isBound = false;
unbindService(myConnection);
}
}
}
);
btn_stopservice.setOnClickListener(
new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent objIntent = new Intent(MainActivity.this, ServiceDemo.class);
if (isBound) {
isBound = false;
unbindService(myConnection);
stopService(objIntent);
} else {
stopService(objIntent);
}
}
}
);
}
@Override
protected void onResume() {
registerReceiver(broadcastRec, new IntentFilter("USER_ACTION"));
super.onResume();
}
@Override
protected void onStop() {
this.unregisterReceiver(broadcastRec);
super.onStop();
}
private ServiceConnection myConnection = new ServiceConnection() {
public void onServiceConnected(ComponentName className,
IBinder service) {
myService = ((ServiceDemo.MyLocalBinder) service).getService();
isBound = true;
}
public void onServiceDisconnected(ComponentName arg0) {
isBound = false;
}
};
@Override
protected void onDestroy() {
super.onDestroy();
if (isBound) {
unbindService(myConnection);
isBound = false;
}
}
}
DemoService.java
public class ServiceDemo extends Service {
int i;
private MyThread mythread;
public boolean isRunning = false;
Notification notification;
@Override
public void onCreate() {
super.onCreate();
Log.d(TAG, "onCreate");
mythread = new MyThread();
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
Toast.makeText(this, "Service Started", Toast.LENGTH_SHORT).show();
if (!isRunning) {
mythread.start();
isRunning = true;
}
return START_STICKY;
}
@Override
public void onDestroy() {
super.onDestroy();
mythread.interrupt();
Toast.makeText(this, "Service Destroyed", Toast.LENGTH_SHORT).show();
}
public void sendBrodcastMsg(int value) {
Intent intent = new Intent();
intent.setAction("USER_ACTION");
intent.putExtra("value", value);
sendBroadcast(intent);
}
@RequiresApi(api = Build.VERSION_CODES.JELLY_BEAN)
class MyThread extends Thread {
static final long DELAY = 100;
@Override
public void run() {
while (isRunning) {
try {
i++;
Thread.sleep(DELAY);
sendBrodcastMsg(i);
shownotification();
} catch (InterruptedException e) {
isRunning = false;
e.printStackTrace();
}
}
stopSelf();
}
}
@RequiresApi(api = Build.VERSION_CODES.JELLY_BEAN)
public void shownotification() {
Intent in = new Intent(this, MainActivity.class);
PendingIntent pIntent = PendingIntent.getActivity(this, (int) System.currentTimeMillis(), in, 0);
notification = new NotificationCompat.Builder(this)
.setContentTitle(String.valueOf(i))
.setContentText(String.valueOf(i))
.setSmallIcon(R.drawable.musicplayer)
.setContentIntent(pIntent)
.setAutoCancel(true).build();
;
startForeground(101, notification);
}
public class MyLocalBinder extends Binder {
ServiceDemo getService() {
return ServiceDemo.this;
}
}
private final IBinder myBinder = new MyLocalBinder();
@Override
public IBinder onBind(Intent arg0) {
// TODO Auto-generated method stub
return myBinder;
}
}
activity_main.xml
<?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.yudiz.servicedemo.MainActivity">
<TextView
android:id="@+id/tv_activity_main_count"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="ABC"
android:gravity="center"/>
<Button
android:id="@+id/btn_activity_main_startservices"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/tv_activity_main_count"
android:text="Start Services"/>
<Button
android:id="@+id/btn_activity_main_stopservices"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/btn_activity_main_startservices"
android:text="Stop Services" />
</RelativeLayout>
のAndroidManifest.xml
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
<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=".ServiceDemo"
android:enabled="true">
</service>
</application>
+0
素晴らしい答えをありがとう、私は最初からユーザーのためにこれをupvoteします。 –
0
新しいホーム画面のアクティビティ(カテゴリCATEGORY_HOME
のACTION_MAIN
)を作成し、受け取ったインテント(ホーム)の数をカウントし、実際のホームを開始することができます。
関連する問題
- 1. 製品を追加するときにカウンタを追加する
- 2. ホームボタンをクリックしたときに呼び出す方法は?
- 3. アンドロイドのホームボタンをクリックすると、フレームAS3を保存します
- 4. アンドロイドのチェックボックスにパディングを追加できませんでした
- 5. クリックにカーソルを追加することはできますか?
- 6. アンドロイドのホームボタンを押したときアプリを終了
- 7. UIButtonをプログラムで追加するときにクリックできない
- 8. gwtボタンをクリックすると@UiHandlerを追加できますか?
- 9. Flink 1.3.2でカウンタを追加できません
- 10. コンポーネントをクリックしたときに本体にクラスを追加しますか?
- 11. ボタンをクリックしたときにスクロールビューを追加しようとしました
- 12. javascriptでボタンをクリックしたときの音の追加
- 13. ボタンをクリックしたときにテキストファイルを追加するObjective-C
- 14. C#WinForms |ボタンをクリックしたときにラベルを追加する
- 15. EclipseのAntビューでタスクをクリックしたときのアクションを追加します。
- 16. アンドロイド4のデフォルト書体にカスタムフォントを追加できますか?
- 17. jQueryクリックしたときにIDにスタイリングを追加する
- 18. クリックしたときにQLabelに画像を追加する
- 19. Moreボタンをクリックしたときにtableviewに画像を追加
- 20. ImageViewをクリックすると他のウェブサイトを追加できます
- 21. ユーザーがホームボタンをクリックしたときにiOSアプリをリセットするにはどうすればよいですか?
- 22. アンドロイドのTabbarアプリにAlertDialogを追加できませんか?
- 23. Javaでカウンタを追加するには?
- 24. PHPのwhileループでカウンタを追加し、私はこのカウンタに達すると
- 25. アンドロイドのアクションバーにタイマーを追加することはできますか?
- 26. アンドロイドの空のMainActivityにボタンを追加することはできますか?
- 27. WebView:ユーザーがwebviewリンクをクリックしたときにカスタムヘッダーを追加します。
- 28. アンドロイドのホームボタンを押すとネイティブハンドルに反応しますか?
- 29. googleplusプラグインを追加した後、アンドロイドAPKをビルドできませんか? ionic1
- 30. ボタンを追加しました。クリックしたときにテーブルを表示したいです。
ホームボタンを押すと、onPause()とonStop()がそれぞれ呼び出されます。静的カウンタを持ち、onStopでインクリメントすることができます。しかし、ホームボタンが押されていることを保証するものではありません。なぜなら、これらのメソッドは別の方法で呼ばれるかもしれないからです。 – AwaisMajeed
ありがとうございます。 –
特定の解決策が必要な場合は、私の答えを確認してください – AwaisMajeed