Android Framework中的PolicyManager简介

2024-09-05 09:32

本文主要是介绍Android Framework中的PolicyManager简介,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

PolicyManager类位于framework\base\core\java\com\android\internal\policy目录中的PolicyManager.java文件中。PolicyManager主要用于创建Window类、LayoutInflater类和WindowManagerPolicy类,它扮演着简单工厂模式中的工厂类角色,而抽象产品角色由IPolicy接口实现,具体产品角色由Policy类实现。它们的关系如下图所示:

 加载中...

 

从下面三个类的代码可以看出,都使用了hide注解,因此,这三个类都是不对外公开的API,只限于Framework内部使用。

抽象产品类IPolicy实现如下(IPolicy.java):

[java]
 package com.android.internal.policy;
 
 import android.content.Context;
 import android.view.LayoutInflater;
 import android.view.Window;
 import android.view.WindowManagerPolicy;
 
 /**
  * {@hide}
  */
 
 /* The implementation of this interface must be called Policy and contained
  * within the com.android.internal.policy.impl package */
 public interface IPolicy {
     public Window makeNewWindow(Context context);
 
     public LayoutInflater makeNewLayoutInflater(Context context);
 
     public WindowManagerPolicy makeNewWindowManager();
 }
 package com.android.internal.policy;
 
import android.content.Context;
 import android.view.LayoutInflater;
 import android.view.Window;
 import android.view.WindowManagerPolicy;
 
/**
  * {@hide}
  */
 
/* The implementation of this interface must be called Policy and contained
  * within the com.android.internal.policy.impl package */
 public interface IPolicy {
     public Window makeNewWindow(Context context);
 
    public LayoutInflater makeNewLayoutInflater(Context context);
 
    public WindowManagerPolicy makeNewWindowManager();
 }
 
 具体产品类Policy实现如下(Policy.java):
 
[java]
 package com.android.internal.policy.impl;
 
 import android.content.Context;
 import android.util.Log;
 
 import com.android.internal.policy.IPolicy;
 import com.android.internal.policy.impl.PhoneLayoutInflater;
 import com.android.internal.policy.impl.PhoneWindow;
 import com.android.internal.policy.impl.PhoneWindowManager;
 
 /**
  * {@hide}
  */
 
 // Simple implementation of the policy interface that spawns the right 
 // set of objects 
 public class Policy implements IPolicy {
     private static final String TAG = "PhonePolicy";
 
     //需要在Policy类创建时预先加载的一些类 
     private static final String[] preload_classes = {
         "com.android.internal.policy.impl.PhoneLayoutInflater",
         "com.android.internal.policy.impl.PhoneWindow",
         "com.android.internal.policy.impl.PhoneWindow$1",
         "com.android.internal.policy.impl.PhoneWindow$ContextMenuCallback",
         "com.android.internal.policy.impl.PhoneWindow$DecorView",
         "com.android.internal.policy.impl.PhoneWindow$PanelFeatureState",
  "com.android.internal.policy.impl.PhoneWindow$PanelFeatureState$SavedState",
     };
 
     static {
         // 出于性能考虑,在Policy类加载时提前加载会用到的相关类 
         for (String s : preload_classes) {
             try {
         //加载指定类到Java虚拟机中,并执行类中的静态代码段 
                 Class.forName(s);
             } catch (ClassNotFoundException ex) {
                 Log.e(TAG, "Could not preload class for phone policy: " + s);
             }
         }
     }
 
     public PhoneWindow makeNewWindow(Context context) {
         return new PhoneWindow(context);
     }
 
     public PhoneLayoutInflater makeNewLayoutInflater(Context context) {
         return new PhoneLayoutInflater(context);
     }
 
     //PhoneWindowManager实现了WindowManagerPolicy接口     
     //这里返回值直接写成WindowManagerPolicy更合理些 
     public PhoneWindowManager makeNewWindowManager() {
         return new PhoneWindowManager();
     }
 }
 package com.android.internal.policy.impl;
 
import android.content.Context;
 import android.util.Log;
 
import com.android.internal.policy.IPolicy;
 import com.android.internal.policy.impl.PhoneLayoutInflater;
 import com.android.internal.policy.impl.PhoneWindow;
 import com.android.internal.policy.impl.PhoneWindowManager;
 
/**
  * {@hide}
  */
 
// Simple implementation of the policy interface that spawns the right
 // set of objects
 public class Policy implements IPolicy {
     private static final String TAG = "PhonePolicy";
 
    //需要在Policy类创建时预先加载的一些类
     private static final String[] preload_classes = {
         "com.android.internal.policy.impl.PhoneLayoutInflater",
         "com.android.internal.policy.impl.PhoneWindow",
         "com.android.internal.policy.impl.PhoneWindow$1",
         "com.android.internal.policy.impl.PhoneWindow$ContextMenuCallback",
         "com.android.internal.policy.impl.PhoneWindow$DecorView",
         "com.android.internal.policy.impl.PhoneWindow$PanelFeatureState",
  "com.android.internal.policy.impl.PhoneWindow$PanelFeatureState$SavedState",
     };
 
    static {
         // 出于性能考虑,在Policy类加载时提前加载会用到的相关类
         for (String s : preload_classes) {
             try {
      //加载指定类到Java虚拟机中,并执行类中的静态代码段
                 Class.forName(s);
             } catch (ClassNotFoundException ex) {
                 Log.e(TAG, "Could not preload class for phone policy: " + s);
             }
         }
     }
 
    public PhoneWindow makeNewWindow(Context context) {
         return new PhoneWindow(context);
     }
 
    public PhoneLayoutInflater makeNewLayoutInflater(Context context) {
         return new PhoneLayoutInflater(context);
     }
 
    //PhoneWindowManager实现了WindowManagerPolicy接口  
     //这里返回值直接写成WindowManagerPolicy更合理些
     public PhoneWindowManager makeNewWindowManager() {
         return new PhoneWindowManager();
     }
 }
 
 工厂类PolicyManager实现如下(PolicyManager.java):
 
[java]
 <pre class="java" name="code">package com.android.internal.policy;
 
 import android.content.Context;
 import android.view.LayoutInflater;
 import android.view.Window;
 import android.view.WindowManagerPolicy;
 
 import com.android.internal.policy.IPolicy;
 
 /**
  * {@hide}
  */
 
 public final class PolicyManager {
     private static final String POLICY_IMPL_CLASS_NAME =
         "com.android.internal.policy.impl.Policy";
 
     private static final IPolicy sPolicy;
 
     static {
        // 运行时动态装载IPolicy实现类 
         try {
            //加载Policy类的同时会执行其中的静态代码段 
             Class policyClass = Class.forName(POLICY_IMPL_CLASS_NAME);
             sPolicy = (IPolicy)policyClass.newInstance();
         } catch (ClassNotFoundException ex) {
             throw new RuntimeException(
                     POLICY_IMPL_CLASS_NAME + " could not be loaded", ex);
         } catch (InstantiationException ex) {
             throw new RuntimeException(
                     POLICY_IMPL_CLASS_NAME + " could not be instantiated", ex);
         } catch (IllegalAccessException ex) {
             throw new RuntimeException(
                     POLICY_IMPL_CLASS_NAME + " could not be instantiated", ex);
         }
     }
 
     // 构造函数私有,保证是单例类 
     private PolicyManager() {}
 
     // The static methods to spawn new policy-specific objects 
     public static Window makeNewWindow(Context context) {
         return sPolicy.makeNewWindow(context);
     }
 
     public static LayoutInflater makeNewLayoutInflater(Context context) {
         return sPolicy.makeNewLayoutInflater(context);
     }
 
     public static WindowManagerPolicy makeNewWindowManager() {
         return sPolicy.makeNewWindowManager();
     }
 }
 <pre class="java" name="code">package com.android.internal.policy;
 
import android.content.Context;
 import android.view.LayoutInflater;
 import android.view.Window;
 import android.view.WindowManagerPolicy;
 
import com.android.internal.policy.IPolicy;
 
/**
  * {@hide}
  */
 
public final class PolicyManager {
     private static final String POLICY_IMPL_CLASS_NAME =
         "com.android.internal.policy.impl.Policy";
 
    private static final IPolicy sPolicy;
 
    static {
        // 运行时动态装载IPolicy实现类
         try {
            //加载Policy类的同时会执行其中的静态代码段
             Class policyClass = Class.forName(POLICY_IMPL_CLASS_NAME);
             sPolicy = (IPolicy)policyClass.newInstance();
         } catch (ClassNotFoundException ex) {
             throw new RuntimeException(
                     POLICY_IMPL_CLASS_NAME + " could not be loaded", ex);
         } catch (InstantiationException ex) {
             throw new RuntimeException(
                     POLICY_IMPL_CLASS_NAME + " could not be instantiated", ex);
         } catch (IllegalAccessException ex) {
             throw new RuntimeException(
                     POLICY_IMPL_CLASS_NAME + " could not be instantiated", ex);
         }
     }
 
    // 构造函数私有,保证是单例类
     private PolicyManager() {}
 
    // The static methods to spawn new policy-specific objects
     public static Window makeNewWindow(Context context) {
         return sPolicy.makeNewWindow(context);
     }
 
    public static LayoutInflater makeNewLayoutInflater(Context context) {
         return sPolicy.makeNewLayoutInflater(context);
     }
 
    public static WindowManagerPolicy makeNewWindowManager() {
         return sPolicy.makeNewWindowManager();
     }
 }
 

这篇关于Android Framework中的PolicyManager简介的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1138575

相关文章

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

Android自定义Scrollbar的两种实现方式

《Android自定义Scrollbar的两种实现方式》本文介绍两种实现自定义滚动条的方法,分别通过ItemDecoration方案和独立View方案实现滚动条定制化,文章通过代码示例讲解的非常详细,... 目录方案一:ItemDecoration实现(推荐用于RecyclerView)实现原理完整代码实现

Android App安装列表获取方法(实践方案)

《AndroidApp安装列表获取方法(实践方案)》文章介绍了Android11及以上版本获取应用列表的方案调整,包括权限配置、白名单配置和action配置三种方式,并提供了相应的Java和Kotl... 目录前言实现方案         方案概述一、 androidManifest 三种配置方式

Android WebView无法加载H5页面的常见问题和解决方法

《AndroidWebView无法加载H5页面的常见问题和解决方法》AndroidWebView是一种视图组件,使得Android应用能够显示网页内容,它基于Chromium,具备现代浏览器的许多功... 目录1. WebView 简介2. 常见问题3. 网络权限设置4. 启用 JavaScript5. D

Android如何获取当前CPU频率和占用率

《Android如何获取当前CPU频率和占用率》最近在优化App的性能,需要获取当前CPU视频频率和占用率,所以本文小编就来和大家总结一下如何在Android中获取当前CPU频率和占用率吧... 最近在优化 App 的性能,需要获取当前 CPU视频频率和占用率,通过查询资料,大致思路如下:目前没有标准的

Android开发中gradle下载缓慢的问题级解决方法

《Android开发中gradle下载缓慢的问题级解决方法》本文介绍了解决Android开发中Gradle下载缓慢问题的几种方法,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、网络环境优化二、Gradle版本与配置优化三、其他优化措施针对android开发中Gradle下载缓慢的问

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

Golang的CSP模型简介(最新推荐)

《Golang的CSP模型简介(最新推荐)》Golang采用了CSP(CommunicatingSequentialProcesses,通信顺序进程)并发模型,通过goroutine和channe... 目录前言一、介绍1. 什么是 CSP 模型2. Goroutine3. Channel4. Channe