Android判斷手機(jī)ROM

有時候需要判斷手機(jī)系統(tǒng)的ROM,檢測ROM是MIUI、EMUI還是Flyme,可以使用getprop命令,去系統(tǒng)build.prop文件查找是否有對應(yīng)屬性來判斷是什么ROM。build.prop的介紹可以看Android build.prop簡介

  1. 小米

小米官方文檔:如何識別小米設(shè)備/MIUI系統(tǒng)
判斷小米設(shè)備
Build.MANUFACTURER是否為Xiaomi
查詢build.prop是否有ro.miui.ui.version.name屬性
ps:Build.MODEL是機(jī)器型號,小米2是MI 2
判斷MIUI版本
ro.miui.ui.version.name返回V5表示是MIUI V5系統(tǒng),V6表示MIUI V6系統(tǒng)

  1. 華為

查詢build.prop是否有ro.build.version.emui屬性

  1. OPPO

查詢build.prop是否有ro.build.version.opporom屬性

  1. VIVO

查詢build.prop是否有ro.vivo.os.version屬性

  1. 錘子

查詢build.prop是否有ro.smartisan.version屬性

  1. 魅族

Build.DISPLAY是否包含“FLYME”字符串

  1. 360

Build.MANUFACTURER為“QIKU”或“360”

  1. 樂視

待測試。。。

如果官方?jīng)]有給出用哪個屬性判斷,就要自己來決定了,一般系統(tǒng)ROM登記都有一個內(nèi)部版本號,是個不錯的選擇,例如小米ro.miui.ui.version.code,華為ro.build.hw_emui_api_level

附代碼:

public class Rom {

    private static final String TAG = "Rom";

    public static final String ROM_MIUI = "MIUI";
    public static final String ROM_EMUI = "EMUI";
    public static final String ROM_FLYME = "FLYME";
    public static final String ROM_OPPO = "OPPO";
    public static final String ROM_SMARTISAN = "SMARTISAN";
    public static final String ROM_VIVO = "VIVO";
    public static final String ROM_QIKU = "QIKU";

    private static final String KEY_VERSION_MIUI = "ro.miui.ui.version.name";
    private static final String KEY_VERSION_EMUI = "ro.build.version.emui";
    private static final String KEY_VERSION_OPPO = "ro.build.version.opporom";
    private static final String KEY_VERSION_SMARTISAN = "ro.smartisan.version";
    private static final String KEY_VERSION_VIVO = "ro.vivo.os.version";

    private static String sName;
    private static String sVersion;

    public static boolean isEmui() {
        return check(ROM_EMUI);
    }

    public static boolean isMiui() {
        return check(ROM_MIUI);
    }

    public static boolean isVivo() {
        return check(ROM_VIVO);
    }

    public static boolean isOppo() {
        return check(ROM_OPPO);
    }

    public static boolean isFlyme() {
        return check(ROM_FLYME);
    }

    public static boolean is360() {
        return check(ROM_QIKU) || check("360");
    }

    public static boolean isSmartisan() {
        return check(ROM_SMARTISAN);
    }

    public static String getName() {
        if (sName == null) {
            check("");
        }
        return sName;
    }
    
    public static String getVersion() {
        if (sVersion == null) {
            check("");
        }
        return sVersion;
    }

    public static boolean check(String rom) {
        if (sName != null) {
            return sName.equals(rom);
        }

        if (!TextUtils.isEmpty(sVersion = getProp(KEY_VERSION_MIUI))) {
            sName = ROM_MIUI;
        } else if (!TextUtils.isEmpty(sVersion = getProp(KEY_VERSION_EMUI))) {
            sName = ROM_EMUI;
        } else if (!TextUtils.isEmpty(sVersion = getProp(KEY_VERSION_OPPO))) {
            sName = ROM_OPPO;
        } else if (!TextUtils.isEmpty(sVersion = getProp(KEY_VERSION_VIVO))) {
            sName = ROM_VIVO;
        } else if (!TextUtils.isEmpty(sVersion = getProp(KEY_VERSION_SMARTISAN))) {
            sName = ROM_SMARTISAN;
        } else {
            sVersion = Build.DISPLAY;
            if (sVersion.toUpperCase().contains(ROM_FLYME)) {
                sName = ROM_FLYME;
            } else {
                sVersion = Build.UNKNOWN;
                sName = Build.MANUFACTURER.toUpperCase();
            }
        }
        return sName.equals(rom);
    }

    public static String getProp(String name) {
        String line = null;
        BufferedReader input = null;
        try {
            Process p = Runtime.getRuntime().exec("getprop " + name);
            input = new BufferedReader(new InputStreamReader(p.getInputStream()), 1024);
            line = input.readLine();
            input.close();
        } catch (IOException ex) {
            Log.e(TAG, "Unable to read prop " + name, ex);
            return null;
        } finally {
            if (input != null) {
                try {
                    input.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
        return line;
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 走安卓開發(fā)不可避免的遇到很多機(jī)型,并且去適配。下面分享兩個工具類,可以直接識別機(jī)型: ** * Created w...
    sakura_L閱讀 1,624評論 0 2
  • 最近有個需求需要建一個service永遠(yuǎn)在后臺運行來接收推送消息和一些定時器工作,首先想到的就是雙進(jìn)程守護(hù)原則...
    lib93閱讀 1,758評論 0 2
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,578評論 19 139
  • 有關(guān)alertview消失時,animated屬性的設(shè)置為YES和NO產(chǎn)生的問題 大體邏輯是:彈出alert(此a...
    碼農(nóng)的思念閱讀 321評論 0 0
  • 第一次采用聽書的方式完成一本書,有些細(xì)節(jié)沒太注意,但大體內(nèi)容基本清楚了。 之前看過《夏山學(xué)校畢業(yè)生》,里面記錄了一...
    三分歸一閱讀 290評論 0 2

友情鏈接更多精彩內(nèi)容