VSCode如何进行安卓开发?Code FA项目实战分享

本篇文章带大家了解一下vscode如何进行安卓开发?希望对需要的朋友有所帮助!

VSCode如何进行安卓开发?Code FA项目实战分享

vs code 大部分是由 ts 编写,上层 UI 可以运行在各个系统的浏览器中,但 vs code 基于 electron 框架,这个框架提供了对 node 的支持,一些浏览器内核中的 js 引擎没有的 api,例如 I/O,系统内核的一些交互等。而 code-server 则是解决了脱离 electron 的问题。目前安卓上有一个叫 aid learing 的软件,自带 VS Code ,看了一下原理差不多,并不是 linux 图形界面打开的 VS Code,也是打开的 webview 连接本地的服务,但这个玩意占磁盘内存太高,整个下载安装完就干掉6个g。【推荐学习:《vscode入门教程》】

客户端框架

客户端是用 Flutter 进行的开发,而这个框架的选用并不是为了跨端,仅仅是为了快速尝试,还有基础能力的使用。

实现方法分析

code-server 在 github 发布的版本中是有 arm64 架构的,整个下载后,开终端解压执行就挂了,这个虽然是 arm64,并且带有一个 arm64 的 node,但是是为完整 linux 准备的。也就是说,node 中硬编码了 /usr /lib 等这些路径,并且附带的 node_modules 中也有大量的使用到 linux 特有节点的路径,这些安卓上都没有。后来一想,termux 中自带的环境也是有 libllvm gcc nodejs 的,把整个 node_mudules 一删,再手动 install 一下,就行了。所以整个流程大致分为两类。

初始尝试方案:非完整Linux

启动 termux 环境

安装 node,python,libllvm,clang

下载 code-server arm64,解压

处理兼容,删除 node_modules ,重新 yarn install

执行 bin/code-server 启动服务

经过一些测试发现,这种模式有一些问题。

下载的依赖太多,由于源都在我的个人服务器,会下很久。编译太久,yarn install 的时候调用了 gcc 的编译,整个过程特别耗时。启动的 vs code 用不了搜索代码(正常情况能支持这个功能)磁盘占用太大,一阵操作下来,直接1.6g磁盘空间给干没了,主要是 npm install 拉了很多东西,还生成了一堆缓存,node_modules 嘛,比黑洞还重的东西。

不过按照以上的流程过一遍后,code-server 内的 node_modules 已经是安卓 arm64 可用的模块了,二次打包 code-server,流程就可以简化成如下

启动 termux 环境

安装 node

下载 code-server arm64,解压

执行 bin/code-server

但还是会存在编辑器无法搜索代码的 bug,node 虽然只有 20m ,但还是在个人服务器,下行带宽 5mb,大概 700kb/s ,emmm,要集成到 apk 内的话,得集成 deb ,调 dpkg 去安装,放弃。

最后使用方案:完整Linux

启动 termux 环境

下载并安装完整 Linux(30m)

下载 code-server arm64(自带node能用了)

执行 bin/code-server 启动服务

最终是选用了完整 Linux 的方式,除了安装需要的体积更小之外,还有完整源的支持,异常 bug 的避免等。由于整个 VS Code 的启动需要的 130mb 的内存都是第一次打开需要的,所以将这些内存的占用放到服务器上,由 app 启动再下载的意义并不大,最后就全都作为资源文件集成到了 apk 内。

具体实现

启动 termux 环境

这个过程之前有现成的轮子了,只需要按照 termux-package 的编译脚本编译一个 bootstrap 集成到 apk,app 启动进行解压,然后根据符号链接格式进行恢复就行。终端是 termare_view。

bootstrap 是一个带有最小依赖的类 linux 环境,有bash,apt 等。

具体实现代码

function initApp(){  cd ${RuntimeEnvir.usrPath}/  echo 准备符号链接...  for line in `cat SYMLINKS.txt`  do    OLD_IFS="$IFS"    IFS="←"    arr=($line)    IFS="$OLD_IFS"    ln -s ${arr[0]} ${arr[3]}  done  rm -rf SYMLINKS.txt  TMPDIR=/data/data/com.nightmare.termare/files/usr/tmp  filename=bootstrap  rm -rf "$TMPDIR/$filename*"  rm -rf "$TMPDIR/*"  chmod -R 0777 ${RuntimeEnvir.binPath}/*  chmod -R 0777 ${RuntimeEnvir.usrPath}/lib/* 2>/dev/null  chmod -R 0777 ${RuntimeEnvir.usrPath}/libexec/* 2>/dev/null  apt update  rm -rf $lockFile  export LD_PRELOAD=${RuntimeEnvir.usrPath}/lib/libtermux-exec.so  install_vs_code  start_vs_code  bash}

RuntimeEnvir.usrPath 是 /data/data/$package/files/usr/bin

安装完整 Linux 和 code-server

这个我从好几个方案进行了筛选,起初用的 atlio 这个开源,整个开源依赖 python,并且有一个requirement.txt ,需要执行 python -r requirement.txt,依赖就是一大堆,后来换了 proot-distro,纯 shell,所以只需要直接集成到 apk 内就行。

1.安装 ubuntu

install_ubuntu(){  cd ~  colorEcho - 安装Ubuntu Linux  unzip proot-distro.zip >/dev/null  #cd ~/proot-distro  bash ./install.sh  apt-get install -y proot  proot-distro install ubuntu  echo '$source' > $ubuntuPath/etc/apt/sources.list}

2.安装 code-server

install_vs_code(){  if [ ! -d "$ubuntuPath/home/code-server-$version-linux-arm64" ];then    cd $ubuntuPath/home    colorEcho - 解压 Vs Code Arm64    tar zxvf ~/code-server-$version-linux-arm64.tar.gz >/dev/null    cd code-server-$version-linux-arm64  fi}

启动 code-server

直接用 proot-distro 启动就行,非常方便

–termux-home 参数:开启 app 沙盒的 home 挂载到 ubuntu 的 /root 下,这样 ubuntu 就能用 app 里面的文件夹了。

start_vs_code(){  install_vs_code  mkdir -p $ubuntuPath/root/.config/code-server 2>/dev/null  echo '  bind-addr: 0.0.0.0:8080  auth: none  password: none  cert: false  ' > $ubuntuPath/root/.config/code-server/config.yaml  echo -e "x1b[31m- 启动中..x1b[0m"  proot-distro login ubuntu -- /home/code-server-$version-linux-arm64/bin/code-server}

其实整个实现其实是没啥难度的,全都是一些 shell 脚本,也是得益于之前的 Termare 系列的支持,有兴趣的可以看下这个组织。然后就是打开 webview 的过程了,如果觉得性能不好,你可以用局域网的电脑来进行连接。看一下非首次的启动过程

WebView 实现方案

首先去 pub 看了一下 webview 的插件,官方目前正在维护的 webview 有这样的提示

Snyk Code Snyk Code

当下比较流行的代码安全检查工具

Snyk Code 26 查看详情 Snyk Code

Hybrid composition mode has a built-in keyboard support while Virtual displays mode has multiple keyboard issuesHybrid composition mode requires Android SKD 19+ while Virtual displays mode requires Android SDK 20+Hybrid composition mode has performence limitations when working on Android versions prior to Android 10 while Virtual displays is performant on all supported Android versions

也就是说开启 hybird 后,安卓10以下有性能限制,而使用虚拟显示器的话,键盘问题会很多。

实际尝试的时候,OTG 连接的键盘基本是没法用的。

再分析了下这个场景,最后还是用的原生 WebView,这里有些小坑。

必须启用项

        WebSettings mWebSettings = mWebView.getSettings();        //允许使用JS        mWebSettings.setJavaScriptEnabled(true);        mWebSettings.setJavaScriptCanOpenWindowsAutomatically(true);        mWebSettings.setUseWideViewPort(true);        mWebSettings.setAllowFileAccess(true);        // 下面这行不写不得行        mWebSettings.setDomStorageEnabled(true);        mWebSettings.setDatabaseEnabled(true);        mWebSettings.setAppCacheEnabled(true);        mWebSettings.setLoadWithOverviewMode(true);        mWebSettings.setDefaultTextEncodingName("utf-8");        mWebSettings.setLoadsImagesAutomatically(true);        mWebSettings.setSupportMultipleWindows(true);

路由重定向

有些场景 VS Code 会打开一个新的窗口,例如点击 file -> new window 的时候,不做处理,webview 会调起系统的浏览器。

        //系统默认会通过手机浏览器打开网页,为了能够直接通过WebView显示网页,必须设置        mWebView.setWebViewClient(new WebViewClient() {            @Override            public boolean shouldOverrideUrlLoading(WebView view, String url) {                //使用WebView加载显示url                view.loadUrl(url);                //返回true                return true;            }        });

浏览器正常跳转

例如终端输出了 xxx.xxx,ctrl + 鼠标点击,预期是会打开浏览器的。

mWebView.setWebChromeClient(webChromeClient);WebChromeClient webChromeClient = new WebChromeClient() {        @Override        public boolean onCreateWindow(WebView view, boolean isDialog, boolean isUserGesture, Message resultMsg) {            WebView childView = new WebView(context);//Parent WebView cannot host it's own popup window.            childView.setBackgroundColor(Color.GREEN);            childView.setWebViewClient(new WebViewClient() {                @Override                public boolean shouldOverrideUrlLoading(WebView view, String url) {                    context.startActivity(new Intent(Intent.ACTION_VIEW, Uri.parse(url)));                    return true;                }            });            WebView.WebViewTransport transport = (WebView.WebViewTransport) resultMsg.obj;            transport.setWebView(childView);//setWebView和getWebView两个方法            resultMsg.sendToTarget();            return true;        }    };

可行性探索

这个能干嘛?安卓屏幕那么小,电脑能本地用 VsCode 干嘛要连安卓的?

有一个 vs code 加一个完整的 linux 环境,能 cover 住一些场景的开发了,安卓开发等除外。开发程序到 arm 板子的同学,PC 上还得弄一堆交叉编译工具链,并且每次编译调试过程也很繁琐,现在就能本地写本地编译。

正巧,买了一个平板,爱奇艺之余,也能作为程序员的一波生产力了。

1.png

编译 C 语言

选了一个一直在学习的项目,scrcpy,一堆 c 源码,最后很顺利的编译下来了。

2.png

Web 开发

移动端的网页调试一直都是问题,作为野路子前端的我也很无奈,一般会加一些 vconsole 的组件来获取调试日志。

之前个人项目速享适配移动端 web 就是这么干的

现在,我们可以本地开发,本地调试,有 node 整个前端大部分项目都能拉下来了,真实的移动端物理环境。试试out.gif

写博客

本篇文章完全是在这个安卓版的 VS Code 中完成的,使用 hexo 本地调式

4.png

写文档

5.png

6.png

写后台,接口测试

写一点简单的后台,如 python 的 fastapi,flask,并通过 rest client 进行接口测试

8.png

最后

为了让其他的用户能直接使用到这个 app,我将其上架到了酷安。

看了下 vscodium 和 code-server 的开源协议都是 MIT,如果有侵权的地方辛苦评论区提醒一下鄙人。

Code FA 酷安下载地址

Code FA 个人服务器下载地址

个人软件快捷下载地址

开源地址

随便玩,有问题评论区留言,觉得不错的给个 star,文章不错的给个赞,

以上就是VSCode如何进行安卓开发?Code FA项目实战分享的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/502255.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 20:55:19
下一篇 2025年11月8日 20:56:12

相关推荐

  • 如何在Golang中使用VS Code远程开发

    使用VS Code通过Remote – SSH扩展连接远程服务器,安装Go工具链及插件,配置launch.json实现远程调试,结合SSH优化与Go Modules提升开发效率。 在Golang项目开发中,使用VS Code进行远程开发能极大提升效率,尤其是在处理云服务器、容器或跨平台项…

    2025年12月16日
    000
  • 如何在Golang中配置调试工具

    安装Delve调试器并配置VS Code或命令行即可高效调试Go程序。1. 使用go install安装dlv并验证版本;2. 在VS Code中安装Go扩展并创建launch.json配置调试;3. 通过dlv debug或dlv test调试主程序或测试代码,设置断点、单步执行和查看变量值。 在…

    2025年12月16日
    000
  • 如何在Golang中配置VS Code开发环境

    首先安装Go并配置环境变量,再安装VS Code及其官方Go扩展,接着通过命令面板安装gopls、delve等工具,然后创建项目并初始化go mod,在.vscode中配置launch.json以支持调试,最后启用保存自动格式化即可完成开发环境搭建。 要在Golang中配置VS Code开发环境,关…

    2025年12月16日
    000
  • Golang如何配置远程调试功能

    答案:Go语言可通过Delve工具实现远程调试。首先在远程服务器使用dlv exec启动程序并监听指定端口,确保防火墙放行该端口;然后在本地通过VS Code或dlv connect命令连接调试会话,即可进行断点设置与变量查看等操作。 Go语言支持通过dlv(Delve)工具实现远程调试,适合在服务…

    2025年12月16日
    000
  • 如何在Golang中使用VSCode终端进行构建

    首先确保Go环境正确安装并配置,通过VSCode终端运行go命令进行构建。使用Ctrl + `打开终端,确认项目根目录后执行go build或go run等命令完成编译运行。依赖管理推荐使用Go Modules,首次构建前运行go mod tidy下载依赖。终端输出错误可直接定位问题,构建过程与系统…

    2025年12月16日
    000
  • Golang如何安装并配置Visual Studio Code插件

    答案是安装Go扩展并配置工具链。先安装VS Code的官方Go插件,再通过go install命令安装gopls、dlv等工具,最后在设置中启用保存时格式化和代码诊断功能。 要在 Visual Studio Code 中配置 Go(Golang)开发环境,关键是安装合适的插件并正确设置相关工具。下面…

    2025年12月16日
    000
  • 使用Windows调试Go (Golang) 代码

    本文旨在提供在Windows%ignore_a_1%下调试Go (Golang) 代码的有效方法。由于GDB在Windows上的局限性,本文将探讨替代方案,包括使用集成开发环境(IDE)以及其他调试工具,帮助开发者更高效地定位和解决Go程序中的问题。 在Windows环境下调试Go代码,开发者可能会…

    2025年12月16日
    000
  • Golang如何在IDE中配置调试环境

    安装Delve调试器并配置IDE是Golang调试的核心。首先通过go install github.com/go-delve/delve/cmd/dlv@latest安装Delve,运行dlv version验证安装;若命令未找到,需将GOBIN(通常为$GOPATH/bin)加入系统PATH。在…

    2025年12月16日
    000
  • Golang调试工具安装与配置示例

    Delve是Go语言专用调试工具,支持断点、变量查看和堆栈追踪。通过go install安装后,可用dlv version验证;在VS Code中配置launch.json可实现图形化调试;命令行下使用break、continue、locals等命令进行调试操作;注意权限、路径及模块模式问题。 Go…

    2025年12月16日
    000
  • Golang插件管理与代码提示优化实践

    答案:合理配置Go语言服务器gopls与编辑器插件可显著提升开发效率。建议使用VS Code配合最新Go扩展,启用gopls并关闭旧工具;配置completeUnimported、usePlaceholders等提升补全体验;通过GOPROXY加速模块下载;在多模块项目中使用gopls.work文件…

    2025年12月16日
    000
  • Golang如何在IDE中调试远程程序

    使用Delve可在IDE中实现Go远程调试。先在服务器安装Delve并以headless模式启动,监听指定端口;再在GoLand或VS Code中配置远程连接,确保源码路径一致;通过SSH隧道可提升安全性,最终实现如本地般断点调试。 在Go语言开发中,调试远程程序是常见的需求,尤其是在生产环境或容器…

    好文分享 2025年12月16日
    000
  • Golang Docker容器环境搭建与开发示例

    首先搭建Go与Docker环境,再编写Web服务并创建Dockerfile,最后构建镜像运行容器实现应用容器化。 在现代后端开发中,Go语言(Golang)与Docker的结合越来越普遍。这种组合不仅能提升开发效率,还能保证应用在不同环境中的稳定性。本文将带你一步步搭建Golang的Docker开发…

    2025年12月16日
    000
  • Golang VSCode开发环境插件配置与优化

    答案:配置VSCode的Go开发环境需安装Go插件、gopls和Delve,启用保存格式化与代码诊断,配置launch.json实现高效编码与调试。 使用 VSCode 搭建高效的 Golang 开发环境,关键在于合理配置插件与编辑器设置。核心目标是提升编码效率、获得智能提示、快速跳转和便捷调试能力…

    2025年12月16日
    000
  • 深入探索Go语言交互式调试:从GDB到Delve

    Go语言的交互式调试功能至关重要,开发者可通过多种工具实现断点设置、单步执行等操作。本文将首先介绍传统的GDB调试方式及其在IDE中的集成,随后重点阐述Go语言原生调试器Delve的优势与使用,并结合主流IDE提供详细的调试实践指南,助您高效定位和解决Go程序中的问题。 Go语言调试基础:GDB 在…

    2025年12月16日
    000
  • Golang本地调试环境搭建与常见问题解析

    正确安装并配置Delve是搭建Golang本地调试环境的核心。首先确认Go已安装并设置环境变量,推荐使用Go Modules管理依赖,通过go mod init初始化项目;接着执行go install安装Delve调试器,运行dlv version验证安装,macOS用户需注意代码签名问题;然后在V…

    2025年12月16日
    000
  • Golang IDE集成开发环境配置与调优

    答案:本文以VS Code为例,介绍Go语言开发环境的配置与优化。需安装最新版VS Code及官方 Go 扩展,并确保 Go 环境(建议1.19+)正确安装;首次打开 .go 文件时自动安装 gopls(语言服务器)、delve(调试器)等工具。关键工具包括 goimports(自动格式化与导入管理…

    2025年12月16日
    000
  • Golang开发环境调试工具配置与使用方法

    Delve是Go官方推荐调试工具,通过go install安装后可用dlv debug启动调试,支持命令行与VS Code图形化调试,配合launch.json配置可实现断点、变量查看等功能,关闭编译优化可解决断点失效与变量优化问题。 Go语言开发中,良好的调试工具能大幅提升开发效率。合理配置调试环…

    2025年12月16日
    000
  • Go语言文件命名规范:以下划线或点号开头文件的特殊处理

    Go语言的go build命令会忽略文件名以下划线或点号开头的源文件。这一行为由标准库go/build包定义,旨在排除临时文件或编辑器相关文件。因此,开发者应避免使用此类命名方式来定义包的有效源代码,否则其中定义的函数和类型将无法被导入和使用,影响程序的正常构建和运行。 Go构建工具的文件识别机制 …

    2025年12月16日
    000
  • Go 语言中以 _ 开头的文件行为解析

    本文深入探讨了Go语言中以 _ 或 . 开头的文件在 go build 命令下的特殊处理机制。这些文件通常被Go工具链视为非源码文件而忽略,导致其中定义的函数和类型无法被编译和导入。文章将解析其背后的原理,提供示例说明,并给出在Go项目开发中文件命名和管理方面的最佳实践与注意事项。 Go 文件命名约…

    2025年12月16日
    000
  • Golang环境搭建如何在不同操作系统统一配置

    统一Go版本管理、环境变量、项目结构和工具链,使用gvm/Scoop管理版本,标准化GOPATH、GO111MODULE,通过Go Modules确保依赖一致,配置VS Code与golangci-lint统一开发环境,提升跨平台协作效率。 在不同操作系统(Windows、macOS、Linux)中…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信