車機 Android 環境下利用 CarAudioService 實現自定義 Java 服務自啟動

来源:https://www.cnblogs.com/qidi-huang/archive/2023/12/12/start_customized_java_service_using_caraudioservice.html
-Advertisement-
Play Games

註意:本文基於 Android 11 進行分析 Qidi 2023.11.28 (MarkDown & Haroopad) 0. 簡介 Android RO (Resource Overlay) 機制 Overlay 實現的效果正如其字面意思,就是“在原有效果的基礎上再疊加一些效果”。 Androi ...


註意:本文基於 Android 11 進行分析
Qidi 2023.11.28 (MarkDown & Haroopad)


0. 簡介 Android RO (Resource Overlay) 機制

Overlay 實現的效果正如其字面意思,就是“在原有效果的基礎上再疊加一些效果”。

Android 提供了兩種實現方式:

通過 RO 機制,我們就可以將自己編寫的 Java 服務在系統啟動時運行起來。


1. 實現自定義 Java 服務

假設我們要實現的自定義服務名叫 myService,為了使它可以正常被 CarAudioService 拉起,需要在myServiceAndroidManifest.xml 中添加 directBootAware 屬性:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    coreApp="true"
    tools:ignore="MissingVersion"
    package="com.your_company_name.myService"
    android:sharedUserId="android.uid.system">
    ......
    <application
        android:allowBackup="true"
        tools:ignore="All"
        android:label="myService"
        android:persistent="true"
        android:directBootAware="true"
        android:supportsRtl="true" >

        <service
            android:name=".myService"
            android:singleUser="true"
            android:exported="true"
            android:permission="android.car.permission.CAR_CONTROL_AUDIO_SETTINGS"
            tools:ignore="All"
            android:enabled="true">
            <intent-filter>
                <action android:name="com.your_company_name.myService"/>
            </intent-filter>
        </service>

        <!-- functionalities of myService depend on calls to below libraries -->
        <uses-library
            android:name="com.your_company_name.audio"
            android:required="true"/>
        <uses-library
            android:name="com.your_company_name.effect"
            android:required="true"/>
    </application>
</manifest>

隨後實現 myService 代碼,和實現普通 service 沒有區別,示例 vendor/your_company_name/packages/src/com/your_company_name/myService.java 如下:

package com.your_company_name.myService;

// some dependent packages
import android.util.Log;
import xxxx;

public class myService extends Service {

	private static final String TAG = "myService";

	......

    @Override
    public IBinder onBind(Intent intent) {
        // return a binder object to caller
    }

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        return START_STICKY;
    }

    @Override
    public void onCreate() {
    	Log.i(TAG, "Creating myService...");
        super.onCreate();
        // creating and initializing myService
    }


	// implementation of some myService methods here
    ......


    @Override
    public boolean onUnbind(Intent intent) {
        return super.onUnbind(intent);
    }

    @Override
    public void onDestroy() {
        super.onDestroy();
    }

    @Override
    protected void attachBaseContext(Context base) {
        super.attachBaseContext(base);
    }
}

如此,自定義服務 myService 就編寫完成了。接下來我們還要做一些改動,讓 myService 在系統啟動時能自動被 CarAudioService 拉起。


2. 對 CarAudioService 配置文件進行編譯時 Overlay

CarAudioService 新建 Overlay 配置文件device/your_company_name/qcom/lunch_target_name/overlay/packages/services/Car/service/res/values/config.xml

<resources>
    <!-- The services that needs to be started earlier in the boot sequence and in particular order.
         Every item in this array contains a flatten component name of a service that needs to be
         started and a list of parameters after hashtag symbol. Here's the format:

         <item>com.bar.foo/.Service#bind={bind|start|startForeground},user={all|system|foreground},
         trigger={asap,userUnlocked}</item>

         bind: bind - start service with Context#bindService
               start - start service with Context#startService
               startForeground - start service with Context#startForegroundService
               If service was bound it will be restarted unless it is constantly crashing.
               The default value is 'start'
         user: all - the service will be bound/started for system and all foreground users
               system - the service will be started/bound only for system user (u0)
               foreground - the service will be bound/started only for foreground users
               The default value is 'all'
         trigger: indicates when the service needs to be started/bound
               asap - the service might be bound when user is not fully loaded, be careful with
                      this value, the service also needs to have directBootAware flag set to true
               userUnlocked - start service when user unlocked the device
               The default value is 'userUnlocked'

         If the service bound/started for foreground user it will be unbound/stopped when user
         is no longer foreground.
     -->
    <string-array translatable="false" name="config_earlyStartupServices">
        <item>com.your_company_name.myService/.myService#bind=start,user=system,trigger=asap</item>
    </string-array>
</resources>

然後在 makefile 中將上述 overlay 文件路徑添加到環境變數 PRODUCT_PACKAGE_OVERLAYS 中。以我使用的代碼環境為例,在 device/your_company_name/qcom/lunch_target_name/lunch_target_name.mk 中添加以下語句(當然你也可以添加到別的 makefile 中,比如 device.mk):

PRODUCT_PACKAGE_OVERLAYS += device/your_company_name/qcom/$(TARGET_PRODUCT)/overlay

至此,所有需要的改動都已完成。接下來只要確保編譯通過,並燒寫到板子上,就能在開機日誌中看到 myService 被拉起來的列印了。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • EF Core 提供兩種主要方法來保持 EF Core 模型和資料庫架構同步。至於我們應該選用哪個方法,請確定你是希望以 EF Core 模型為準還是以資料庫為準。 如果希望以 EF Core 模型為準,請使用遷移。 對 EF Core 模型進行更改時,此方法會以增量方式將相應架構更改應用到資料庫, ...
  • .NET Core MVC基礎之返迴文件類型📄 前言 上一篇文章講了基礎的返回類型,這篇文章講解如何返迴文件類型給瀏覽器下載。 系列文章 .NET MVC基礎之頁面傳值方式 通過圖片流來返回圖片 返回類型介紹 在返迴文件之前,要知道MIME 類型,這裡介紹常用的幾種: text/plain:純文本 ...
  • 模型創建分為正向工程(CodeFirst)與反向工程(DbFirst). 正向工程的模型配置也可以創建任意的資料庫關係對象,如:欄位,欄位說明,表,索引,外鍵等等。 可在派生上下文中替代 OnModelCreating 方法,並使用 ModelBuilder API 來配置模型。 此配置方法最為有效 ...
  • 1. 快速入門 創建新的控制台項目 dotnet new console -o EFGetStarted cd EFGetStarted 安裝 Entity Framework Core 要安裝 EF Core,請為要作為目標對象的 EF Core 資料庫提供程式安裝程式包。 本教程使用 SQLit ...
  • 在開發過程中有時候我們需要對現有對象進行克隆,我們可以使用DeepCloner類庫來完成這個需求功能。 DeepCloner 類庫 功能: 深度克隆: DeepCloner 提供深度克隆對象的能力,遞歸地克隆對象圖中的所有引用類型屬性。 迴圈引用處理: 能夠處理對象圖中的迴圈引用,防止無限遞歸。 自 ...
  • 一:背景 1. 講故事 上周有位朋友找到我,說他的程式經常會偶發性崩潰,一直沒找到原因,自己也抓了dump 也沒分析出個所以然,讓我幫忙看下怎麼回事,那既然有 dump,那就開始分析唄。 二:Windbg 分析 1. 到底是哪裡的崩潰 一直跟蹤我這個系列的朋友應該知道分析崩潰第一個命令就是 !ana ...
  • 前言 上一篇,我只實現了一鍵檢測代碼變化,本篇才是真正的實現了一鍵打包發佈 效果圖 客戶端打包待發佈文件 /// <summary> /// 把多個文件添加到壓縮包 (保留文件夾層級關係) /// </summary> public static async Task<ZipFileResult> ...
  • 文件資源管理器(WIN+E快捷鍵打開的窗格)就這樣的,然後我們就會進某個磁碟找對應的文件或文件夾下的文件,進行一定的操作 但是有註意過嗎 ,這些窗格“展示列”(先這樣稱呼吧,官方的名稱應該是:可用的列,例如:,官網地址:如何更改在 Windows 資源管理器中的列設置 - Microsoft 支持) ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...