首页
/ 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 社区。

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

项目优选

收起
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
352
263
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
64
114
管伊佳ERP管伊佳ERP
管伊佳ERP基于SpringBoot框架和SaaS模式,立志为中小企业提供开源好用的ERP软件,目前专注进销存+财务+生产功能。主要模块有零售管理、采购管理、销售管理、仓库管理、财务管理、报表查询、系统管理等。支持预付款、收入支出、仓库调拨、组装拆卸、订单等特色功能。拥有商品库存、出入库统计等报表。同时对角色和权限进行了细致全面控制,精确到每个按钮和菜单。
Java
15
2
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
254
233
carboncarbon
轻量级、语义化、对开发者友好的 golang 时间处理库
Go
6
1
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
76
106
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
156
16
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
330
140
cloudpodscloudpods
开源、云原生的多云管理及混合云融合平台
Go
68
5
IImageKnife
专门为OpenHarmony打造的一款图像加载缓存库,致力于更高效、更轻便、更简单
ArkTS
13
9