В Android, как я реализую глобальную службу сенсорного отслеживания, которая работает, даже если на экране работают другие приложения - PullRequest
0 голосов
/ 05 ноября 2019

Я работаю над созданием приложения для Android, которое работает в качестве фонового сервиса и нацелено на запись координат всех сенсорных событий. Я попробовал несколько решений и предложений, но они не сработали, как я планировал. Я определил, что GlobalTouchService расширяет службу, реализует View.OntouchListener. Это работает, когда приложение работает на переднем плане, но я хочу обнаруживать сенсорные события, когда другие приложения работают на переднем плане. Это решение всегда возвращает нули в качестве координат касания, когда другие приложения работают на переднем плане.

Это мой MainActivity:

package com.token.simpledatabaseproject;

import android.annotation.SuppressLint;
import android.app.Service;
import android.content.Intent;
import android.graphics.Color;
import android.graphics.PixelFormat;
import android.icu.text.AlphabeticIndex;
import android.os.Build;
import android.os.IBinder;
import android.util.Log;
import android.view.Gravity;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.view.WindowManager;
import android.widget.LinearLayout;
import android.widget.LinearLayout.LayoutParams;

public class GlobalTouchService extends Service implements View.OnTouchListener {

WindowManager.LayoutParams params;

private String TAG = this.getClass().getSimpleName();
private WindowManager mWindowManager;
private LinearLayout touchLayout;

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

@SuppressLint("ClickableViewAccessibility")
@Override
public void onCreate() {
    super.onCreate();
    touchLayout = new LinearLayout(this);
    LayoutParams lp = new LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT);
    touchLayout.setLayoutParams(lp);       
    touchLayout.setBackgroundColor(Color.CYAN);
    touchLayout.setOnTouchListener(this);
    mWindowManager = (WindowManager) getSystemService(WINDOW_SERVICE);


    params = new WindowManager.LayoutParams(
            WindowManager.LayoutParams.WRAP_CONTENT,
            WindowManager.LayoutParams.WRAP_CONTENT,
            WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY,
            WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE
                    | WindowManager.LayoutParams.FLAG_NOT_TOUCH_MODAL
                    | WindowManager.LayoutParams.FLAG_WATCH_OUTSIDE_TOUCH
                    | WindowManager.LayoutParams.FLAG_LAYOUT_NO_LIMITS,
            PixelFormat.TRANSLUCENT);

    params.gravity = Gravity.CENTER_HORIZONTAL | Gravity.TOP;
    params.x = 0;
    params.y = 100;
    WindowManager wm = (WindowManager) getSystemService(WINDOW_SERVICE);
    wm.addView(touchLayout, params);

}

@Override
public void onDestroy() {
    if (mWindowManager != null) {
        if (touchLayout != null) mWindowManager.removeView(touchLayout);
    }
    super.onDestroy();
}

@Override
public boolean onTouch(View v, MotionEvent event) {
    Log.d("Touchhhhhhhhhhhhhh: ", String.valueOf(event.getX()) + String.valueOf(event.getY()));
    return true;
 }
}

Это мой GlobalTouchService:

package com.token.simpledatabaseproject;

import android.annotation.SuppressLint;
import android.app.Service;
import android.content.Intent;
import android.graphics.Color;
import android.graphics.PixelFormat;
import android.os.IBinder;
import android.util.Log;
import android.view.Gravity;
import android.view.MotionEvent;
import android.view.View;
import android.view.WindowManager;
import android.widget.LinearLayout;
import android.widget.LinearLayout.LayoutParams;

public class GlobalTouchService extends Service implements View.OnTouchListener {

WindowManager.LayoutParams params;
private String TAG = this.getClass().getSimpleName();
private WindowManager mWindowManager;
private LinearLayout touchLayout;

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

@SuppressLint("ClickableViewAccessibility")
@Override
public void onCreate() {
    super.onCreate();
    // create linear layout
    touchLayout = new LinearLayout(this);
    // set layout width 30 px and height is equal to full screen
    LayoutParams lp = new LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT);
    touchLayout.setLayoutParams(lp);
    // set color if you want layout visible on screen
    touchLayout.setBackgroundColor(Color.CYAN);
    // set on touch listener
    touchLayout.setOnTouchListener(this);

    // fetch window manager object
    mWindowManager = (WindowManager) getSystemService(WINDOW_SERVICE);


    params = new WindowManager.LayoutParams(
            WindowManager.LayoutParams.WRAP_CONTENT,
            WindowManager.LayoutParams.WRAP_CONTENT,
            WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY,
            WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE
                    | WindowManager.LayoutParams.FLAG_NOT_TOUCH_MODAL
                    | WindowManager.LayoutParams.FLAG_WATCH_OUTSIDE_TOUCH
                    | WindowManager.LayoutParams.FLAG_LAYOUT_NO_LIMITS,
            PixelFormat.TRANSLUCENT);


    params.gravity = Gravity.CENTER_HORIZONTAL | Gravity.TOP;
    params.x = 0;
    params.y = 100;
    WindowManager wm = (WindowManager) getSystemService(WINDOW_SERVICE);
    wm.addView(touchLayout, params);

}


@Override
public void onDestroy() {
    if (mWindowManager != null) {
        if (touchLayout != null) mWindowManager.removeView(touchLayout);
    }
    super.onDestroy();
}

@Override
public boolean onTouch(View v, MotionEvent event) {

    Log.d("Touchhhhhhhhhhhhhh: ", String.valueOf(event.getX()) + String.valueOf(event.getY()));      
    return true;
 }
}
...