android锁屏

http://www.cnblogs.com/androidez/archive/2013/02/17/2915020.html

http://hxdawxyhxdawxy.iteye.com/blog/1651089

1.创建 MyAdmin 的广播接受者 继承 DeviceAdminReceiver

package com.example.lockscreen;

import android.app.admin.DeviceAdminReceiver;

public class MyAdmin extends DeviceAdminReceiver {

}

2.清单文件AndroidMenifest.xml中的配置:


<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.lockscreen"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="8" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="com.example.lockscreen.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

        <receiver android:name=".MyAdmin" >
            <meta-data android:name="android.app.device_admin"
                android:resource="@xml/my_admin"/>
            <intent-filter >
                <action android:name="android.app.action.DEVICE_ADMIN_ENABLED"/>
            </intent-filter>
        </receiver>
    </application>

</manifest>

3.在res文件建立xml/my_admin.xml文件:

<?xml version="1.0" encoding="utf-8" ?>
<device-admin xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- 
    limit-password  设置密码的规则
    watch-login 监控屏幕解锁尝试次数
    reset-password 更改屏幕解锁密码
    force-lock 设备自动锁屏
    wipe-data 删除全部的数据
    
     -->
    <uses-policies>
        <limit-password/>
        <watch-login />
        <reset-password />
        <force-lock />
        <wipe-data />
    </uses-policies>
</device-admin>

4.MainActivity代码

package com.example.lockscreen;

import android.app.Activity;
import android.app.admin.DevicePolicyManager;
import android.content.ComponentName;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;


public class MainActivity extends Activity {

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

    public void onClick(View v){
        // 设备安全管理服务    2.2之前的版本是没有对外暴露的 只能通过反射技术获取  
        DevicePolicyManager devicePolicyManager = (DevicePolicyManager) getSystemService(Context.DEVICE_POLICY_SERVICE);
        
        // 申请权限
        ComponentName componentName = new ComponentName(this, MyAdmin.class);
        // 判断该组件是否有系统管理员的权限
        boolean isAdminActive = devicePolicyManager.isAdminActive(componentName);
        if(isAdminActive){
            
            devicePolicyManager.lockNow(); // 锁屏
            
            devicePolicyManager.resetPassword("123", 0); // 设置锁屏密码
//            devicePolicyManager.wipeData(0);  恢复出厂设置  (建议大家不要在真机上测试) 模拟器不支持该操作
            
        } else {
            Intent intent = new Intent();
            // 指定动作名称
            intent.setAction(DevicePolicyManager.ACTION_ADD_DEVICE_ADMIN);
            // 指定给哪个组件授权
            intent.putExtra(DevicePolicyManager.EXTRA_DEVICE_ADMIN, componentName);
            startActivity(intent);
        }
        
        
    }
}


### Android 机制实现与解决方案 #### 一、机制概述 Android机制主要通过 `KeyguardManager` 和 `PowerManager` 来管理设备的幕状态以及定行为。当设备进入状态时,CPU 可能会被置入低功耗模式,这会影响应用中的定时器、服务以及其他后台操作的行为。 为了应对这些情况,发者可以采用多种方式来确保应用在状态下仍能正常运行。以下是几种常见的实现方法及其对应的解决方案: --- #### 二、保持 Service 运行并模拟音频播放 一种常见的方式是在时启动一个前台服务 (Foreground Service),并通过该服务播放一段无声的 MP3 文件以防止系统将应用判定为闲置而终止其进程[^1]。 ```java public class SilentAudioService extends Service { private MediaPlayer mediaPlayer; @Override public int onStartCommand(Intent intent, int flags, int startId) { mediaPlayer = new MediaPlayer(); try { AssetFileDescriptor afd = getAssets().openFd("silent.mp3"); mediaPlayer.setDataSource(afd.getFileDescriptor(), afd.getStartOffset(), afd.getLength()); mediaPlayer.prepare(); mediaPlayer.setLooping(true); mediaPlayer.start(); } catch (IOException e) { stopSelf(); } return START_STICKY; } @Override public void onDestroy() { super.onDestroy(); if (mediaPlayer != null && mediaPlayer.isPlaying()) { mediaPlayer.stop(); mediaPlayer.release(); } } @Nullable @Override public IBinder onBind(Intent intent) { return null; } } ``` 上述代码展示了如何创建一个播放无声音频的服务,并将其设为循环播放。需要注意的是,这种方式可能会增加电量消耗,因此应谨慎使用。 --- #### 三、解决 Handler 和 CountDownTimer 停止运行的问题 当设备进入或休眠状态时,系统的 CPU 将被关闭,从而导致基于消息队列的任务(如 `Handler` 或 `CountDownTimer`)无法继续执行。可以通过以下两种方式进行改进[^2]: 1. **WakeLock** 使用 PowerManager 提供的 WakeLock API 获取部分唤醒权限,使 CPU 即使在幕熄灭的情况下也能维持运行。 ```java PowerManager powerManager = (PowerManager) getSystemService(Context.POWER_SERVICE); PowerManager.WakeLock wakeLock = powerManager.newWakeLock(PowerManager.PARTIAL_WAKE_LOCK, "MyApp::WakeLockTag"); wakeLock.acquire(); // 执行任务... wakeLock.release(); ``` 2. **AlarmManager 配合 Broadcast Receiver** 利用 AlarmManager 定期触发广播接收器,即使在情况下也可以重新激活计时逻辑。 ```java Intent alarmIntent = new Intent(context, MyBroadcastReceiver.class); PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, alarmIntent, 0); AlarmManager alarmManager = (AlarmManager) context.getSystemService(ALARM_SERVICE); long triggerTime = System.currentTimeMillis() + intervalMillis; alarmManager.setExactAndAllowWhileIdle(AlarmManager.RTC_WAKEUP, triggerTime, pendingIntent); ``` 这两种方法各有优劣,需根据具体需求权衡选择。 --- #### 四、持续定位功能的支持 对于需要长时间进行 GPS 跟踪的应用程序来说,安卓高版本引入了更严格的省电策略,可能导致后位置更新中断。针对此问题可采取如下措施[^3]: 1. **请求前台服务权限** 创建一个带有通知栏提示的 Foreground Service 并绑定至 LocationClient 上。 ```java Notification notification = new NotificationCompat.Builder(this, CHANNEL_ID) .setContentTitle("Location Tracking") .setSmallIcon(R.drawable.ic_location).build(); startForeground(NOTIFICATION_ID, notification); ``` 2. **配置 Battery Optimization 白名单** 引导用户手动将应用程序加入电池优化例外列表中,减少因 Doze Mode 导致的影响。 ```java Intent intent = new Intent(Settings.ACTION_REQUEST_IGNORE_BATTERY_OPTIMIZATIONS); intent.setData(Uri.parse("package:" + getPackageName())); startActivity(intent); ``` 以上手段能够有效缓解大部分场景下的定位丢失现象。 --- #### 五、禁用默认界面 如果目标是完全移除标准密码输入框,则可通过修改 AOSP Framework 参数达成目的[^4]。例如编辑 `config_enableKeyguardService` 设置项为 false 后编译生成自定义 ROM 版本即可生效。 ```xml <bool name="config_enableKeyguardService">false</bool> ``` 不过这种方法仅适用于拥有源码控制权的企业级环境部署场合,普通第三方 APP 不具备此类能力。 --- ### 总结 综上所述,面对 Android 系统带来的挑战可以从多个角度出发寻找对策,包括但不限于借助多媒体资源强制活跃进程、运用高级电源管理模式保障核心组件在线时间延长以及调整框架层参数规避干扰等等。每种技术都有各自适应范围,请依据实际业务诉求合理选用最佳实践组合。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值