Version: 1.3
语言 : 中文
Create a custom activity
将 Unity 集成到 Android 应用程序中

Specify Android Player or HMI Android Player command-line arguments

A use-case for extending the custom activity is to pass start-up command-line arguments when you launch the Android Player or HMI Android Player. For information on the command-line arguments available, see Command-line arguments.

To specify start-up arguments for your application:

  1. Create a custom activity and set it as the application entry point.
  2. In the custom activity, override the String UnityPlayerActivity.updateUnityCommandLineArguments(String cmdLine) method.
  3. In the method, concatenate the cmdLine argument with your own start-up arguments then return the result. Important: The cmdLine argument can be an empty string or null so make sure your code handles these possible values.

The following example shows how to specify start-up arguments to select the graphics API based on the current device:

package com.company.product;
import com.unity3d.player.UnityPlayerActivity;
import android.os.Bundle;
import android.os.Build;

public class OverrideExample extends UnityPlayerActivity {
    private boolean preferVulkan() {
        // 在 Google Pixel 设备上使用 Vulkan
        if (Build.MANUFACTURER.equals("Google") && Build.MODEL.startsWith("Pixel"))
            return true;
        else
            return false;
    }

    private boolean preferES2() {
        // 在运行 Android 5.1 或更早版本的设备上使用 OpenGL ES 2.0
        if (Build.VERSION.SDK_INT <= Build.VERSION_CODES.LOLLIPOP_MR1)
            return true;
        else
            return false;
    }

    private String appendCommandLineArgument(String cmdLine, String arg) {
        if (arg == null || arg.isEmpty())
            return cmdLine;
        else if (cmdLine == null || cmdLine.isEmpty())
            return arg;
        else
            return cmdLine + " " + arg; 
    } 

    @Override protected String updateUnityCommandLineArguments(String cmdLine)
    {
        if (preferVulkan())
            return appendCommandLineArgument(cmdLine, "-force-vulkan");
        else if (preferES2())
            return appendCommandLineArgument(cmdLine, "-force-gles20");
        else
            return cmdLine; // 让 Unity 根据 PlayerSettings 选择图形 API
    }

    @Override protected void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
    }
}

Additional ways to specify command-line arguments

Apart from the custom activity, you can specify command-line arguments in the following ways:

  • In Android Studio: If you open your project in Android Studio, you can pass startup command-line arguments to Tuanjie through Launch Flags in Run/Debug Configurations dialog.
  • Via Android Debug Bridge (adb): You can pass command-line arguments by launching an Android application via adb using the following code.
adb shell am start -n "<package_name>/<activity_name>" -e unity <command_line_arguments>
Create a custom activity
将 Unity 集成到 Android 应用程序中