vscode插件分享:看看它如何实现烟花抖动效果

本篇文章给大家分享一个vscode插件–power mode,编写代码边放烟花、编辑器还会抖动;一起来研究一下power mode插件实现烟花抖动效果的原理,一起来看看吧!

vscode插件分享:看看它如何实现烟花抖动效果

最近一直在研究 vscode 插件,今天给大家一分享一个效果特别炫的插件,名字叫 power mode。

1-1.gif

编写代码边放烟花、编辑器还会抖动。

效果很炫,但是我们肯定不能满足于会用,得研究下它是怎么实现的。

实现思路

在 vscode 里大家可能没啥思路,但如果这个效果放到网页里呢,文本改变的时候抖动编辑器、然后再上面出现一些烟花效果。这个可能有的同学就有思路了。【推荐学习:《vscode教程》】

抖动编辑器:抖动不也是个动画么,就是左右位移,这一秒右移,下一秒回到原位置,这样就抖起来了。

烟花效果:不管啥花里胡哨的烟花,给个 gif 我们就能搞定,就是在文本上方加一个元素,然后把 gif 放上去,下次加 gif 的时候把上次的删除。

这样就能在网页里实现编辑器抖动 + 放烟花效果了。

把这个效果放到 vscode 里实现也是一样的思路,因为 vscode 是基于 electron 实现的啊。

而 electron 又是基于 chromium + nodejs,也就是 ui 部分是网页。我们可以在 vscode 帮助里打开开发者工具:

2.png

然后,可以看到,这编辑器部分就是个 div 啊

3.png

所以刚才在网页里实现的效果,可以放到 vscode 里实现,思路一样。

思路是一样,但是具体怎么做呢?

这就需要了解下 vscode 的 extension api 了,其实也不难,我给大家介绍一下这里用到的 api:

首先,引入 vscode 包,所有的 api 都在这个包里。

import * as vscode from 'vscode';

然后,我们要给文本加样式,怎么加呢?

在 vscode 的编辑器里面加样式不是直接操作 dom 的,是受到限制的,要这样几步:

通过 vscode.window 拿到当前的 editor

const activeEditor = vscode.window.activeTextEditor;

拿到当前 editor 的正在编辑的位置

const cursorPosition = activeTextEditor.selection.active;

根据位置计算出要添加装饰的范围(range)

const newRange = new vscode.Range(    cursorPosition.with(cursorPosition.line, cursorPosition.character),    cursorPosition.with(cursorPosition.line, Math.max(0, cursorPosition.character + delta)));

创建装饰对象

vscode.window.createTextEditorDecorationType({    before: {        contentText:'',        textDecoration: `none; ${defaultCssString}${backgroundCssString} ${customCssString}`,    },    textDecoration: `none; position: relative;`,    rangeBehavior: vscode.DecorationRangeBehavior.ClosedClosed});

然后,给这段 range 的文本加装饰

activeEditor.setDecorations(decoration, [newRange]);

现在我们就在 vscode 编辑器里面,你正在编辑的位置,加上了一段样式。

装饰对象可以添加 before、after,这不就是伪元素么?没错,就是伪元素,而且还可以加一系列样式呢。加啥样式都可以。

到了这,是不是就有如何在编辑器里做那些效果的思路了呢?

接下来,我们来看看 power-mode 的实现细节。

代码实现

我们先从效果实现开始看吧,主要是抖动和放烟花:

抖动

抖动的原理我们分析过了,就是定时做位移。

首先,它定义了一系列的位移的装饰对象,就是通过 vscode.window.createTextEditorDecorationType 这个创建装饰对象的 api:

public activate = () => {    this.dispose();    this.negativeX = vscode.window.createTextEditorDecorationType({        textDecoration: `none; margin-left: 0px;`    });    this.positiveX = vscode.window.createTextEditorDecorationType({        textDecoration: `none; margin-left: ${this.config.shakeIntensity}px;`    });    this.negativeY = vscode.window.createTextEditorDecorationType({        textDecoration: `none; margin-top: 0px;`    });    this.positiveY = vscode.window.createTextEditorDecorationType({        textDecoration: `none; margin-top: ${this.config.shakeIntensity}px;`    });    this.shakeDecorations = [        this.negativeX,        this.positiveX,        this.negativeY,        this.positiveY    ];}

然后呢?就是定时让 editor 抖起来啊:

也是根据编辑的 position 算出 range,然后给这段 range 加装饰

private shake = () => {    if (!this.config.enableShake) {        return;    }   // 当前 editor    const activeEditor = vscode.window.activeTextEditor;  // 要抖动的 range,也就是当前行    const xRanges = [];    for (let i = 0; i  0.5) {        activeEditor.setDecorations(this.negativeX, []);        activeEditor.setDecorations(this.positiveX, xRanges);    } else {        activeEditor.setDecorations(this.positiveX, []);        activeEditor.setDecorations(this.negativeX, xRanges);    }    if (Math.random() > 0.5) {        activeEditor.setDecorations(this.negativeY, []);        activeEditor.setDecorations(this.positiveY, this.fullRange);    } else {        activeEditor.setDecorations(this.positiveY, []);        activeEditor.setDecorations(this.negativeY, this.fullRange);    }    clearTimeout(this.shakeTimeout);    this.shakeTimeout = setTimeout(() => {        this.unshake();    }, 1000);}

如上,就是定时加不同的位移样式,随机上下左右抖。

火龙果写作 火龙果写作

用火龙果,轻松写作,通过校对、改写、扩展等功能实现高质量内容生产。

火龙果写作 106 查看详情 火龙果写作

放烟花

然后我们来放烟花,思路我们分析过了,就是在编辑的位置加上一个 gif,然后下次放的时候去掉上次的。

来按流程走一遍:

// 当前编辑器const activeEditor = vscode.window.activeTextEditor;// 当前编辑位置const cursorPosition = vscode.window.activeTextEditor.selection.active;// 要加装饰的范围const delta = left ? -2 : 1;const newRange = new vscode.Range(    cursorPosition.with(cursorPosition.line, cursorPosition.character),    cursorPosition.with(cursorPosition.line, Math.max(0, cursorPosition.character + delta)));//创建装饰对象const decoration = vscode.window.createTextEditorDecorationType({    before: {        // before 样式    },    textDecoration: `当前元素样式`,    rangeBehavior: vscode.DecorationRangeBehavior.ClosedClosed});// 给该范围加装饰activeEditor.setDecorations(decoration, [newRange]);

加装饰的流程我们走完了,但是样式还没填,怎么加呢?

首先当前元素要相对定位,然后加个 before 伪元素,设置为绝对定位并且 left 和 top 为负数。

之后就是设置背景图片了,power mode 提供了这么多 gif 可选。

4.png

所以呢,装饰对象就是这样的:

// 背景图片的样式const backgroundCss = this.getBackgroundCssSettings(explosionUrl);//位置的样式const defaultCss = {    position: 'absolute',    [CSS_LEFT] : `-10px`,    [CSS_TOP]: `-1.2rem`,    width: `${this.config.explosionSize}ch`,    height: `${this.config.explosionSize}rem`,    display: `inline-block`,    ['z-index']: 1,    ['pointer-events']: 'none',};// 样式对象转换为字符串const backgroundCssString = this.objectToCssString(backgroundCss);const defaultCssString = this.objectToCssString(defaultCss);const customCssString = this.objectToCssString(this.config.customCss || {});// 创建装饰对象const decoration = vscode.window.createTextEditorDecorationType({    before: {        contentText:'',        textDecoration: `none; ${defaultCssString}${backgroundCssString} ${customCssString}`,    },    textDecoration: `none; position: relative;`,    rangeBehavior: vscode.DecorationRangeBehavior.ClosedClosed});

性能优化

每次编辑都加一个 gif 性能肯定很差,所以得做优化,可以从触发频率、同时存在的 gif 数量来考虑:

节流,每1秒只能触发一次

5.png

gif 存在一段时间就删掉

6.png

大功告成,这样我们把抖动和放烟花在 vscode 里面实现了一遍。

但是,还得加个触发的入口。

什么时候触发呢?涉及到两个 api:

编辑文本的时候,出现效果

vscode.workspace.onDidChangeTextDocument(onDidChangeTextDocument);

修改了插件配置的时候,重新设置插件对象

vscode.workspace.onDidChangeConfiguration(onDidChangeConfiguration);

从怎么触发的,到触发后干什么,我们都清楚了,接下来呢,还要会怎么注册这个插件到 vscode 中。

插件注册

注册插件就是在 package.json 里面配置一下,指定触发时机:

"activationEvents": [    "*"]

指定插件入口:

  "main": "./out/src/extension",

指定插件的配置:

"contributes": {    "configuration": {      "title": "Power Mode",      "properties": {        "powermode.enabled": {          "default": false, // 默认值          "type": "boolean",// 值类型          "description": "Enable to activate POWER MODE!!!"        }      }    }}

总结

vscode 基于 electron,而 electron 基于 chromium,所以还是用网页来做 ui 的,那么很多网页里面的效果,基本都可以在编辑器实现。

但是是受约束的,要熟悉整个加装饰的流程:

拿到当前编辑器 (activeEditor)拿到当前编辑的位置 (position)算出要加装饰的范围 (range)创建装饰对象 (decorationType)给那段范围的文本加装饰 (addDecoration)

抖动和放烟花都是基于这个 api 实现的,不过抖动是做上下左右的随机位移,放烟花是在编辑的位置加动图。

实现思路有了,还得指定触发的入口,也就是文本编辑的时候(onDidChangeTextDocument)。还有配置改变也得做下处理(onDidChangeConfiguration)。

之后,注册到 vscode 就可以了,在 package.json 里面配置入口(main)、生效事件(activeEvent)、配置项(contibutes.configuration)

希望这篇文章能够帮你理清 vscode 里面一些编辑效果的实现思路。

兄弟萌,让我们一起在 vscode 里面放烟花吧!

7-1.gif

(插件名叫 vscode-power-mode,感兴趣可以体验一下,或者去看看源码)。

原文地址:https://juejin.cn/post/6982416460723257352作者:zxg_神说要有光

更多编程相关知识,请访问:编程入门!!

以上就是vscode插件分享:看看它如何实现烟花抖动效果的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 21:04:26
下一篇 2025年11月8日 21:05:47

相关推荐

  • VSCode选择范围提供者实现

    Selection Range Provider是VSCode中用于实现层级化代码选择的API,通过注册provideSelectionRanges方法,按光标位置从内到外逐层扩展选择范围,如从变量名扩展至函数体;需结合AST解析构建准确的SelectionRange链式结构以提升选择智能性。 在 …

    2025年12月6日 开发工具
    000
  • VSCode终端美化:功率线字体配置

    首先需安装Powerline字体如Nerd Fonts,再在VSCode设置中将terminal.integrated.fontFamily设为’FiraCode Nerd Font’等支持字体,最后配合oh-my-zsh的powerlevel10k等Shell主题启用完整美…

    2025年12月6日 开发工具
    000
  • VSCode入门:基础配置与插件推荐

    刚用VSCode,别急着装一堆东西。先把基础设好,再按需求加插件,效率高还不卡。核心就三步:界面顺手、主题舒服、功能够用。 设置中文和常用界面 打开软件,左边活动栏有五个图标,点最下面那个“扩展”。搜索“Chinese”,装上官方出的“Chinese (Simplified) Language Pa…

    2025年12月6日 开发工具
    000
  • VSCode性能分析与瓶颈诊断技术

    首先通过资源监控定位异常进程,再利用开发者工具分析性能瓶颈,结合禁用扩展、优化语言服务器配置及项目设置,可有效解决VSCode卡顿问题。 VSCode作为主流的代码编辑器,虽然轻量高效,但在处理大型项目或配置复杂扩展时可能出现卡顿、响应延迟等问题。要解决这些性能问题,需要系统性地进行性能分析与瓶颈诊…

    2025年12月6日 开发工具
    000
  • VSCode的悬浮提示信息可以自定义吗?

    可以通过JSDoc、docstring和扩展插件自定义VSCode悬浮提示内容,如1. 添加JSDoc或Python docstring增强信息;2. 调整hover延迟与粘性等显示行为;3. 使用支持自定义提示的扩展或开发hover provider实现深度定制,但无法直接修改HTML结构或手动编…

    2025年12月6日 开发工具
    000
  • VSCode插件:GitLens使用详解

    GitLens是VSCode中强大的Git增强插件,提供行级代码追踪、提交历史浏览、版本对比、跨文件导航及与GitHub等平台集成;通过启用Current Line Blame和In-Line Blame,可实时查看每行代码的作者与修改时间;支持按分支、作者过滤提交记录,比较差异,并利用Go Bac…

    2025年12月6日 开发工具
    000
  • VSCode调试:快速定位与修复问题

    掌握VSCode调试技巧可提升开发效率。首先设置断点并配置launch.json文件,通过“运行和调试”面板启动调试;程序暂停时利用变量窗格查看数据状态,结合调用栈追溯函数执行路径;使用调试控制台动态执行代码、验证逻辑;针对高频调用场景,可设置条件断点(如i===100)或日志断点输出信息而不中断执…

    2025年12月6日 开发工具
    000
  • VSCode界面优化:精简布局与元素

    通过隐藏冗余组件和调整视觉元素可提升VSCode专注度。依次操作:1. 用Ctrl+B和Ctrl+J快捷键或设置隐藏侧边栏与面板;2. 在设置中关闭活动栏显示,并在settings.json中设置”window.titleBarStyle”: “inline&#8…

    2025年12月6日 开发工具
    000
  • VSCode后端:Flask应用调试指南

    答案:配置VSCode调试Flask需安装Flask、编写入口文件、在launch.json中设置调试参数,然后设断点并启动调试会话。具体步骤包括创建launch.json文件并配置program、env和args等选项,确保使用正确Python解释器,避免端口占用,最后通过运行和调试面板启动应用,…

    2025年12月6日 开发工具
    000
  • VSCode调试技巧:断点与变量监控

    VSCode调试功能强大,断点设置与变量监控是核心。2. 点击行号设断点,右键可配条件或日志断点,侧边栏统一管理。3. 暂停时通过变量面板、悬停提示、监视表达式实时查看值。4. 调用栈面板展示函数执行路径,点击可查各层上下文。5. 综合运用这些技巧能高效定位逻辑问题,提升调试效率。 调试是开发过程中…

    2025年12月6日 开发工具
    000
  • 如何管理和同步VSCode的扩展配置,以便在新设备上快速恢复开发环境?

    使用 Settings Sync 是最快方式,通过 GitHub 账号同步扩展、设置、快捷键和代码片段;也可手动导出扩展列表(code –list-extensions > extensions.txt)并在新设备安装,结合备份 settings.json 等配置文件实现环境快速恢…

    2025年12月6日 开发工具
    000
  • VSCode扩展包管理依赖解析

    VSCode扩展依赖通过package.json中的extensionDependencies声明,安装时自动解析并提示用户安装所需扩展,确保按顺序激活且禁止循环依赖,依赖间通过contributes.api共享功能,使用vsce打包时需手动处理生产依赖和性能优化,最终实现扩展间的协同运行与API调…

    2025年12月6日 开发工具
    000
  • VSCode代码转换:编码格式处理

    遇到乱码时先查看文件编码,点击右下角编码名称选择“通过编码重新打开”,尝试 UTF-8、GBK 等常用编码以正确显示内容;2. 确认后可选择“通过编码保存”将文件转换为 UTF-8 等标准编码,便于跨平台协作;3. 为避免重复操作,可在设置中将 “files.encoding&#8221…

    2025年12月6日 开发工具
    000
  • VSCode插件更新:保持功能兼容性

    更新VSCode插件需确保兼容性,避免配置失效或冲突。建议更新前检查依赖关系、阅读变更日志,确认API与版本适配;优先在预发布环境测试新版本;对关键项目通过extensions.json锁定推荐版本;更新后监控命令、语言服务等运行状态,发现问题及时回退。合理管理更新节奏可兼顾新特性与稳定性。 更新V…

    2025年12月6日 开发工具
    000
  • VS Code扩展生态剖析:API设计与商店发布全流程指南

    VS Code扩展成功源于其插件化架构与丰富API。通过Activation Events、Contribution Points和Extension Host实现高效稳定的功能扩展,结合vscode.commands、languages、window、workspace等核心API提供完整开发支持…

    2025年12月6日 开发工具
    000
  • VSCode快捷键:括号与缩进处理

    VSCode默认自动补全括号引号,可用Ctrl+Z撤销或设置中关闭;2. Enter或→可跳过自动闭合符号;3. Tab和Shift+Tab用于调整选中行的缩进;4. Shift+Alt+F格式化文件或选中代码,可设保存时自动格式化;5. 光标靠近括号时高亮匹配,Ctrl+Shift+快速跳转配对括…

    2025年12月6日 开发工具
    000
  • VSCode时间线:文件修改历史与代码追溯系统

    时间线功能是VSCode内置的代码追溯工具,通过整合Git历史记录提供文件修改的时间轴视图。用户可查看提交哈希、作者、时间、提交信息及变更行数,点击记录预览差异并还原版本。该功能依赖Git仓库,支持查看某行修改者、对比历史版本、恢复误删代码等操作,未启用Git时仅显示本地保存点。结合GitLens等…

    2025年12月6日 开发工具
    000
  • VS Code配置作用域:机器特定与资源限定设置

    机器特定设置用于本地环境配置,如终端变量和Python路径,存储于用户配置目录,不共享;资源限定设置存于项目.vscode/settings.json,可共享并确保团队代码风格统一,优先级更高。应根据个性化需求与项目规范选择作用域,敏感信息需结合env文件管理。 VS Code 支持多种配置作用域,…

    2025年12月6日 开发工具
    000
  • 如何配置VSCode以支持对容器内应用程序的远程调试?

    答案是使用VSCode Remote – Containers扩展结合Docker实现远程调试。首先安装Docker、VSCode及Remote – Containers扩展,然后在项目根目录创建.devcontainer文件夹并配置devcontainer.json,指定基…

    2025年12月6日 开发工具
    000
  • 构建VSCode金融量化交易环境与实时数据回测

    搭建基于VSCode的金融量化交易环境需先配置Python及VSCode相关扩展,再创建虚拟环境并安装依赖;接着通过AKShare等工具接入历史与实时数据;随后使用Backtrader构建双均线策略并回测;最后对接实盘接口实现自动化交易,形成完整工作流。 搭建一个基于VSCode的金融量化交易环境,…

    2025年12月6日 开发工具
    000

发表回复

登录后才能评论
关注微信