高通Android 12/Android 13截屏

正常截屏Power+音量-键 组合键同时长按,实现截屏逻辑。

PhoneWindowManager #init #interceptScreenshotChord

复制代码
init(Context context, IWindowManager windowManager,
            WindowManagerFuncs windowManagerFuncs)

2、在PhoneWindowManager中init方法中注册广播

frameworks/base/services/core/java/com/android/server/policy/PhoneWindowManager.java

复制代码
        // zm fix
		IntentFilter screenfilter = new IntentFilter();
        screenfilter.addAction("android.intent.action.SCREEN_SHOT");
		context.registerReceiver(mScreenshotReceiver, screenfilter);

3、广播实现代码如下图所示

复制代码
    private BroadcastReceiver mScreenshotReceiver = new BroadcastReceiver() {
    @Override
    public void onReceive(Context context, Intent intent) {
        if ("android.intent.action.SCREEN_SHOT".equals(intent.getAction())) {
			Log.e("Receive Screen Shot Action","Screen Shot="+intent.getAction());
			String path = intent.getStringExtra("path");
            Log.e("onReceive", "Screenshot path: " + path);
            interceptScreenshotChord();
			copyLatestFile("/sdcard/Pictures/Screenshots",path);
			Log.e("onReceive", "Screenshot path completed: " + path);
			
        }
    }
};

4、自定义Service里面发送广播 代码如下所示

复制代码
 /**
     * 截屏
     *
     * @param path
     */
    public boolean capture(String path) {
		Log.e("capture","=========start capture=============");
		Intent intent = new Intent("android.intent.action.SCREEN_SHOT");
		intent.putExtra("path", path);
        mContext.sendBroadcast(intent);
	 
    }

5、PhoneWindowManager中调用 是发广播到 PhoneWindowManager interceptScreenshotChord中调用,具体源码细节,大家感兴趣去源码跟下哈,这里不再赘述哈。

复制代码
    private void interceptScreenshotChord() {
        mHandler.removeCallbacks(mScreenshotRunnable);
        mScreenshotRunnable.setScreenshotType(TAKE_SCREENSHOT_FULLSCREEN);
        mScreenshotRunnable.setScreenshotSource(SCREENSHOT_KEY_CHORD);
        mHandler.postDelayed(mScreenshotRunnable, getScreenshotChordLongPressDelay());
    }

6、最后截屏具体实现代码逻辑 如下所示

复制代码
private class ScreenshotRunnable implements Runnable {
        private int mScreenshotType = TAKE_SCREENSHOT_FULLSCREEN;
        private int mScreenshotSource = SCREENSHOT_KEY_OTHER;

        public void setScreenshotType(int screenshotType) {
            mScreenshotType = screenshotType;
        }

        public void setScreenshotSource(int screenshotSource) {
            mScreenshotSource = screenshotSource;
        }

        @Override
        public void run() {
            mDefaultDisplayPolicy.takeScreenshot(mScreenshotType, mScreenshotSource);
        }
    }

    private final ScreenshotRunnable mScreenshotRunnable = new ScreenshotRunnable();

到这里基本结束,转载请注明出处,高通Android 12/Android 13截屏-CSDN博客谢谢!

相关推荐
石山岭11 小时前
自己动手写了一个 Android 虚拟定位 App:GPSSimulate 技术实
android·前端
杉氧13 小时前
副作用 (Side Effects) 全攻略:如何像大师一样掌控 Composable 的生命周期?
android·架构·android jetpack
Kapaseker18 小时前
Kotlin Toolchain 0.11 发布:主要是把 Amper 干没了
android·kotlin
三少爷的鞋19 小时前
Android 现代架构不需要事件总线进阶篇
android
杉氧1 天前
深入理解 Compose 重组机制:快照系统如何驱动 UI 精准刷新?
android·架构·android jetpack
召钱熏1 天前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
杉氧1 天前
深度解析:Jetpack Compose 核心架构与底层原理 —— 十年安卓老兵的“破茧重生”
android·架构·android jetpack
通玄1 天前
Jetpack Compose 入门系列(七):ViewModel 与界面状态管理
android
落魄Android在线炒饭1 天前
Android Framework 开发技巧:android.jar 生成与系统快速编译验证
android
如此风景1 天前
Kotlin Flow操作符学习
android·kotlin