当应用程序在后台运行时,如何检测Android上的触摸输入

时间:2018-11-25 04:53:52

标签: android android-studio gesture

我想检测是否在其他屏幕上做出了特定手势(不是在打开应用的用户界面时显示)

我已经在某些手机中看到它,您做出'C'手势,相机就会打开。 Android Studio中有类似的东西吗?

1 个答案:

答案 0 :(得分:0)

您可以使用在后台运行的服务来做到这一点。

您知道,有些应用程序正在使用此技能,例如Facebook Messenger。

您可以在FloatingService.kt的setOnTouchListener回调实现中处理触摸事件。

请参考我的源代码。


[FloatingService.kt]

package com.antasis9.android.playground

import android.app.Service
import android.content.Context
import android.content.Intent
import android.graphics.PixelFormat
import android.os.IBinder
import android.util.Log
import android.view.LayoutInflater
import android.view.ViewGroup
import android.view.WindowManager
import android.widget.Button

class FloatingService : Service() {
        override fun onStartCommand(intent: Intent?, flags: Int, startId: Int): Int {
                Log.d("FloatingService", "FloatingService.onStartCommand()");

                val layout = LayoutInflater.from(this).inflate(R.layout.activity_floating, null)
                layout.setOnTouchListener { v, event ->

                        // HANDLE TOUCH EVENT HERE!

                        Log.d("FloatingService", "v: $v, event: $event")
                        false
                }

                val layoutParams = WindowManager.LayoutParams(
                                WindowManager.LayoutParams.MATCH_PARENT,
                                WindowManager.LayoutParams.MATCH_PARENT,
                                WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY,
                                WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE,
                                PixelFormat.TRANSLUCENT
                )

                (getSystemService(Context.WINDOW_SERVICE) as WindowManager).addView(layout, layoutParams)

                return super.onStartCommand(intent, flags, startId)
        }

        override fun onBind(intent: Intent): IBinder? {
                return null
        }
}

[activity_floating.xml]

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@android:color/transparent">
</android.support.constraint.ConstraintLayout>

[MainActivity.java]

我使用活动来启动FloatingService,但是您可以通过其他方式来启动该服务。

package com.antasis9.android.playground;

import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;

public class MainActivity extends AppCompatActivity {

        @Override
        protected void onCreate(Bundle savedInstanceState) {
                super.onCreate(savedInstanceState);
                setContentView(R.layout.activity_main);

                findViewById(R.id.button).setOnClickListener(new View.OnClickListener() {
                        @Override
                        public void onClick(View v) {
                                Intent intent = new Intent(getApplicationContext(), FloatingService.class);
                                startService(intent);
                        }
                });

                findViewById(R.id.button2).setOnClickListener(new View.OnClickListener() {
                        @Override
                        public void onClick(View v) {
                                Intent intent = new Intent(getApplicationContext(), FloatingService.class);
                                stopService(intent);
                        }
                });
        }
}

[AndroidManifest.xml]

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
        package="com.antasis9.android.playground">

        <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />

        <application
                android:allowBackup="true"
                android:icon="@mipmap/ic_launcher"
                android:label="@string/app_name"
                android:roundIcon="@mipmap/ic_launcher_round"
                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=".FloatingService"
                        android:enabled="true"
                        android:exported="false"></service>
        </application>
</manifest>

[这是最后一步]

您应该打开“在其他应用程序上显示”选项。

您可以在“设置”->“应用”->“选择您的应用名称”中找到此选项

Turn on 'display over other apps' option