首页
/ Ruboto 2 技术文档

Ruboto 2 技术文档

2024-12-17 13:00:55作者:董宙帆

本文档将详细介绍如何安装、使用 Ruboto 2,以及如何使用其 API。请按照以下指南进行操作。

1. 安装指南

首先,确保您的开发环境满足以下条件:

接下来,按照以下步骤进行安装:

  1. 创建一个新项目:

    • 在启动屏幕中选择 "Create New Project"。
    • 选择 "Phone and Tablet" 和 "No Activity" 作为项目模板。
    • 选择 "Java" 作为您的编程语言,并将 "Minimum SDK" 设置为 "API 27: Android 8.1 (Oreo)" 或更高。
  2. settings.gradle 文件的 dependencyResolutionManagement/repositories 部分添加 jcenter

    dependencyResolutionManagement {
        ...
        repositories {
            ...
            jcenter()
        }
    }
    
  3. app/build.gradle 文件中添加以下依赖项:

    dependencies {
      ...
      implementation fileTree(dir: 'libs', include: ['*.jar'])
      implementation 'com.linkedin.dexmaker:dexmaker:2.19.1'
      implementation 'me.qmx.jitescript:jitescript:0.4.1'
      implementation 'com.jakewharton.android.repackaged:dalvik-dx:7.1.0_r7'
    }
    
  4. 添加 gems.rb 文件:

    source 'https://rubygems.org/'
    
    gem 'ruboto', '~>2.0.dev', git: 'https://github.com/ruboto/ruboto.git'
    
  5. 确保在命令行中使用 JRuby:

    创建一个 .ruby-version 文件:

    jruby
    
  6. 初始化 Ruboto:

    jruby -S bundle
    jruby -S bundle exec ruboto init
    

    这将复制项目核心文件到您的项目。

  7. app 目录下添加 gems.rb 文件:

    source 'https://rubygems.org/'
    
    gem 'activerecord', '~>7.0'
    gem 'activerecord-jdbc-adapter', '~>70.1'
    gem 'sqldroid', '~>1.0'
    
  8. 添加 app/update_jruby_jar.sh 脚本:

    #!/usr/bin/env bash
    set -e
    
    VERSION="9.4.2.0"
    FULL_VERSION="${VERSION}"
    # FULL_VERSION="${VERSION}-SNAPSHOT" # 取消注释以使用本地快照
    # FULL_VERSION="${VERSION}-20190822.050313-17" # 取消注释以使用远程快照
    JAR_FILE="jruby-complete-${FULL_VERSION}.jar"
    DOWNLOAD_DIR="$HOME/Downloads"
    DOWNLOADED_JAR="${DOWNLOAD_DIR}/${JAR_FILE}"
    SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
    
    cd $SCRIPT_DIR
    
    [ ! -d $HOME/Downloads ] && mkdir $HOME/Downloads  # 如果目录不存在,创建目录
    [ ! -d ./libs ] && mkdir ./libs                    # 如果目录不存在,创建目录
    
    cd libs
    rm -f bcpkix-jdk15on-*.jar bcprov-jdk15on-*.jar bctls-jdk15on-*.jar cparse-jruby.jar generator.jar jline-*.jar jopenssl.jar jruby-complete-*.jar parser.jar psych.jar readline.jar snakeyaml-*.jar
    
    if test -f "${DOWNLOADED_JAR}"; then
      echo "找到下载的 JAR 文件"
    else
      echo "未找到 ${DOWNLOADED_JAR} - 正在下载。"
      curl "https://oss.sonatype.org/service/local/repositories/releases/content/org/jruby/jruby-complete/${VERSION}/jruby-complete-${VERSION}.jar" -o "${DOWNLOADED_JAR}"
    fi
    cp ${DOWNLOADED_JAR} .
    
    unzip -o -j ${JAR_FILE} '*.jar'
    
    # FIXME(uwe): 为什么删除这些文件?
    zip generator.jar -d json/ext/ByteListTranscoder.class
    zip generator.jar -d json/ext/OptionsReader.class
    zip generator.jar -d json/ext/Utils.class
    zip generator.jar -d json/ext/RuntimeInfo.class
    
    cd - >/dev/null
    
    cd src/main/java
    find * -type f | grep "org/jruby/" | sed -e 's/\.java//g' | sort > ../../../overridden_classes.txt
    cd - >/dev/null
    
    while read p; do
      unzip -Z1 libs/${JAR_FILE} | grep "$p\\.class" > classes.txt
      unzip -Z1 libs/${JAR_FILE} | egrep "$p(\\\$[^$]+)*\\.class" >> classes.txt
      if [[ -s classes.txt ]] ; then
        zip -d -@ libs/${JAR_FILE} <classes.txt
        if [[ ! "$?" == "0" ]] ; then
          zip -d libs/${JAR_FILE} "$p\\.class"
        fi
      fi
      rm classes.txt
    done < overridden_classes.txt
    
    rm overridden_classes.txt
    
    cd libs
    rm -f digest.jar
    cd - >/dev/null
    
  9. 使 app/update_jruby_jar.sh 脚本可执行:

    chmod u+x app/update_jruby_jar.sh
    
  10. 生成 jruby.jar

    app/update_jruby_jar.sh
    
  11. 生成启动活动:

    bundle exec ruboto gen class Activity --name StartupActivity
    
  12. 将启动活动意图过滤器添加到 app/src/main/AndroidManifest.xml 中的新活动标签:

    <activity android:name='StartupActivity' android:exported="true">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
            <action android:name="android.intent.action.VIEW" />
        </intent-filter>
    </activity>
    
  13. app/src/main/AndroidManifest.xml 中声明 Ruboto 组件和 SplashActivity:

    <activity android:name='org.ruboto.RubotoActivity' />
    <activity android:name='org.ruboto.RubotoDialog' android:theme='@android:style/Theme.Dialog' />
    <service
        android:name='org.ruboto.RubotoService'
        android:exported='false' />
    <activity
        android:name='org.ruboto.SplashActivity'
        android:configChanges='orientation|screenSize'
        android:exported='false'
        android:noHistory='true' />
    

    记得在更改后同步 Gradle 配置。

  14. 启动您的应用!

2. 项目使用说明

要使用 Ruboto 2 项目,请确保遵循上述安装指南。一旦安装完成,您可以通过 Android Studio 运行和调试您的项目。

3. 项目 API 使用文档

目前,Ruboto 2 的详细 API 文档尚未提供。请参考官方 GitHub 仓库和相关社区资源以获取更多信息。

4. 项目安装方式

Ruboto 2 的安装方式已在安装指南中详细说明。请按照上述步骤进行安装。

希望本文档能帮助您顺利使用 Ruboto 2。如果您有任何问题或建议,请随时联系 Ruboto 社区。

热门项目推荐
相关项目推荐

项目优选

收起
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
46
34
PDFMathTranslatePDFMathTranslate
PDF scientific paper translation with preserved formats - 基于 AI 完整保留排版的 PDF 文档全文双语翻译,支持 Google/DeepL/Ollama/OpenAI 等服务,提供 CLI/GUI/Docker
Python
25
2
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
171
39
RuoYi-VueRuoYi-Vue
🎉 基于SpringBoot,Spring Security,JWT,Vue & Element 的前后端分离权限管理系统,同时提供了 Vue3 的版本
Java
164
33
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
248
63
RuoYi-Cloud-Vue3RuoYi-Cloud-Vue3
🎉 基于Spring Boot、Spring Cloud & Alibaba、Vue3 & Vite、Element Plus的分布式前后端分离微服务架构权限管理系统
Vue
21
17
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
892
0
GitCode光引计划有奖征文大赛GitCode光引计划有奖征文大赛
GitCode光引计划有奖征文大赛
16
1
RuoYi-CloudRuoYi-Cloud
🎉 基于Spring Boot、Spring Cloud & Alibaba的分布式微服务架构权限管理系统,同时提供了 Vue3 的版本
Java
25
10
advanced-javaadvanced-java
Advanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。
JavaScript
389
102