import{_ as o,r as p,o as i,c,b as n,d as a,a as l,e as s}from"./app.71f0fa75.js";const t={},r=l('

Quick Start

Integrate YukiHookAPI into your project.

Environment Requirements

Automatically Build Project

YukiHookAPI provides an automated build tool that can help you quickly build an Android standard project template with Xposed Module dependencies, and use the built template to start the next step directly.

You can click here to check it out.

Manually Configure Project

If you don't want to use automated build tools, you can still manually configure project dependencies as follows.

Create Project

Use Android Studio or IntelliJ IDEA to create a new Android project and select Kotlin in the Language column to automatically add basic dependencies.

Integration Dependencies

',12),d=s("We recommend using Kotlin DSL as the Gradle build script language and "),u={href:"https://github.com/HighCapable/SweetDependency",target:"_blank",rel:"noopener noreferrer"},v=s("SweetDependency"),y=s(" to manage dependencies."),A=l(`

SweetDependency Method

Add the repositories and dependencies in your project's SweetDependency configuration file.

The following example

repositories:
  # \u2757Must be added when used as an Xposed Module, otherwise optional
  rovo89-xposed-api:
    url: https://api.xposed.info/
  # MavenCentral has a 2-hour cache,
  # if the latest version cannot be integrated, please add this
  sonatype-oss-releases:

plugins:
  # \u2757Must be added when used as an Xposed Module, otherwise optional
  com.google.devtools.ksp:
    version: +
  ...

libraries:
  # \u2757Must be added when used as an Xposed Module, otherwise optional
  de.robv.android.xposed:
    api:
      version: 82
      repositories:
        rovo89-xposed-api
  com.highcapable.yukihookapi:
    api:
      version: +
    # \u2757Must be added when used as an Xposed Module, otherwise optional
    ksp-xposed:
      version-ref: <this>::api
  ...

After adding it, run Gradle Sync and all dependencies will be autowired.

Next, deploy plugins in your project build.gradle.kts.

The following example

plugins {
    // \u2757Must be added when used as an Xposed Module, otherwise optional
    autowire(libs.plugins.com.google.devtools.ksp)
    // ...
}

Then, deploy dependencies in your project build.gradle.kts.

The following example

dependencies {
    // Basic dependencies
    implementation(com.highcapable.yukihookapi.api)
    // \u2757Must be added when used as an Xposed Module, otherwise optional
    compileOnly(de.robv.android.xposed.api)
    // \u2757Must be added when used as an Xposed Module, otherwise optional
    ksp(com.highcapable.yukihookapi.ksp.xposed)
}

Add repositories in your project build.gradle.kts or build.gradle.

Kotlin DSL

repositories {
    google()
    mavenCentral()
    // \u2757Must be added when used as an Xposed Module, otherwise optional
    maven { url("https://api.xposed.info/") }
    // MavenCentral has a 2-hour cache, if the latest version cannot be integrated, please add this URL
    maven { url("https://s01.oss.sonatype.org/content/repositories/releases/") }
}

Groovy DSL

repositories {
    google()
    mavenCentral()
    // \u2757Must be added when used as an Xposed Module, otherwise optional
    maven { url 'https://api.xposed.info/' }
    // MavenCentral has a 2-hour cache, if the latest version cannot be integrated, please add this URL
    maven { url 'https://s01.oss.sonatype.org/content/repositories/releases/' }
}

Add plugins in your project build.gradle.kts or build.gradle.

Kotlin DSL

plugins {
    // \u2757Must be added when used as an Xposed Module, otherwise optional
    id("com.google.devtools.ksp") version "<ksp-version>"
}

Groovy DSL

plugins {
    // \u2757Must be added when used as an Xposed Module, otherwise optional
    id 'com.google.devtools.ksp' version '<ksp-version>'
}

Add dependencies in your project build.gradle.kts or build.gradle.

Kotlin DSL

dependencies {
    // Basic dependency
    implementation("com.highcapable.yukihookapi:api:<yuki-version>")
    // \u2757Must be added when used as an Xposed Module, otherwise optional
    compileOnly("de.robv.android.xposed:api:82")
    // \u2757Must be added when used as an Xposed Module, otherwise optional
    ksp("com.highcapable.yukihookapi:ksp-xposed:<yuki-version>")
}

Groovy DSL

dependencies {
    // Basic dependency
    implementation 'com.highcapable.yukihookapi:api:<yuki-version>'
    // \u2757Must be added when used as an Xposed Module, otherwise optional
    compileOnly 'de.robv.android.xposed:api:82'
    // \u2757Must be added when used as an Xposed Module, otherwise optional
    ksp 'com.highcapable.yukihookapi:ksp-xposed:<yuki-version>'
}
`,27),m=s("Please modify "),b=n("strong",null,"",-1),D=s(" to the latest version found "),h={href:"https://github.com/google/ksp/releases",target:"_blank",rel:"noopener noreferrer"},C=s("here"),B=s(),g=n("strong",null,"(please note to select your current corresponding Kotlin version)",-1),k=s("."),F=n("p",null,[s("Please change "),n("strong",null,""),s(" to the latest version "),n("a",{href:"../about/changelog"},"here"),s(".")],-1),f={class:"custom-container danger"},w=n("p",{class:"custom-container-title"},"Pay Attention",-1),x=n("p",null,[s("The "),n("strong",null,"api"),s(" and "),n("strong",null,"ksp-xposed"),s(" dependency versions of "),n("strong",null,"YukiHookAPI"),s(" must correspond one-to-one, otherwise a version mismatch error will occur.")],-1),q=s("We recommend using "),_={href:"https://github.com/HighCapable/SweetDependency",target:"_blank",rel:"noopener noreferrer"},M=s("SweetDependency"),I=s(" to autowire dependencies for you."),X=l(`

Configure Java Version

Modify the Java version of Kotlin in your project build.gradle.kts or build.gradle to 11 or above.

Kotlin DSL

android {
    compileOptions {
        sourceCompatibility = JavaVersion.VERSION_11
        targetCompatibility = JavaVersion.VERSION_11
    }
    kotlinOptions {
        jvmTarget = "11"
    }
}

Groovy DSL

android {
    compileOptions {
        sourceCompatibility JavaVersion.VERSION_11
        targetCompatibility JavaVersion.VERSION_11
    }
    kotlinOptions {
        jvmTarget = '11'
    }
}

Notice

Since API 1.0.80, the Java version used by Kotlin defaults to 11, and versions 1.8 and below are no longer supported.

Use as Xposed Module

Add the base code to your AndroidManifest.xml.

The following example

<!-- Set as Xposed Module -->
<meta-data
    android:name="xposedmodule"
    android:value="true" />

<!-- Set your Xposed Module description -->
<meta-data
    android:name="xposeddescription"
    android:value="Fill in your Xposed Module description" />

<!-- The minimum Xposed version number -->
<!-- If you are using EdXposed/LSPosed, the minimum recommended is 93 -->
<meta-data
    android:name="xposedminversion"
    android:value="93" />

<!-- Optional: Configure support for New XSharedPreferences without adjusting xposedminversion to 93 -->
<meta-data
    android:name="xposedsharedprefs"
    android:value="true"/>

Create a Hook entry class in your project, implements IYukiHookXposedInit and add the annotation @InjectYukiHookWithXposed.

The following example

@InjectYukiHookWithXposed
object HookEntry : IYukiHookXposedInit {

    override fun onHook() = YukiHookAPI.encase {
        // Your code here.
    }
}

Suggestion

Please configure YukiHookAPI in the onInit method and set the isDebug mode to the following form.

The following example

override fun onInit() = configs {
    isDebug = BuildConfig.DEBUG
}

YukiHookAPI will print all logs for debugging by default.

For a release build, be sure to turn off debugging to prevent a lot of log stuffing on the user's device.

You can also extends Application of your Module App from ModuleApplication to achieve a complete user experience.

For more functions, please refer to ModuleApplication.

Then, you can start writing Hook code.

For configuration details related to use as an Xposed Module, you can click here to continue reading.

If you are currently using Hook APIs such as Rovo89 Xposed API, you can refer to Migrate from Other Hook APIs.

Use as Hook API

Integration

Create your custom Application.

Pay Attention

Regardless of the Hook Framework you use, you need to add its docking Xposed dependency support.

If the target Hook Framework does not integrate Rovo89 Xposed API, you need to implement and connect XposedBridge by yourself.

Add YukiHookAPI.encase method to attachBaseContext.

The following example

override fun attachBaseContext(base: Context?) {
    // Load Hook Framework
    //
    // Your code here.
    //
    // Load YukiHookAPI
    YukiHookAPI.encase(base) {
        // Your code here.
    }
    super.attachBaseContext(base)
}

Then, you can start writing Hook code in much the same way you would use it as an Xposed Module.

For configuration details related to use as a Hook API, you can click here to continue reading.

Notice

YukiHookPrefsBridge, YukiHookDataChannel and Resources Hook functionality will not work when using a custom Hook Framework instead of the full Xposed Module.

`,28);function S(H,j){const e=p("ExternalLinkIcon");return i(),c("div",null,[r,n("p",null,[d,n("a",u,[v,a(e)]),y]),A,n("p",null,[m,b,D,n("a",h,[C,a(e)]),B,g,k]),F,n("div",f,[w,x,n("p",null,[q,n("a",_,[M,a(e)]),I])]),X])}const Y=o(t,[["render",S],["__file","quick-start.html.vue"]]);export{Y as default};