Circuitjs web 在线电路模拟器应用简介

2024-08-24 03:12

本文主要是介绍Circuitjs web 在线电路模拟器应用简介,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Circuitjs 是一款 web 在线电路模拟器, 可以在浏览器上方便地模拟各种模拟或数字的电路, 用户无需安装各种软件, 生成的电路也支持在线分享给其它用户.

访问地址

下述地址我部署的一个版本: https://cc.xiaogd.net/

此版本的特色是界面翻译成中文时尽量保留了英文, 因此在某些地方显示时可能有点拥挤, 除此之外, 与其它纯英文或纯中文的版本功能上并无差别.

使用简介

点击前述地址即可打开首页:

circuitjs 首页

默认情况下, 会给出一个示例的 LRC 电路.

另一个数字电路示例:

另一个我制作并分享的数字电路的示例参见: 三位(3 bit)二进制加法虚拟电路示例

打开效果如下:

在线可互动操作的三位(3 bit)二进制加法虚拟电路示例图

创建新的空白电路

默认给出的示例电路只是起一个演示作用, 如果你要创建自己的电路, 可以点击 菜单--电路--空白的电路 从而打开一个新的空白电路.

circuitjs 新建空白电路

当然, 你也可以通过拖动鼠标选中全部组件, 再按 Delete 全部删除它们.

添加组件

清空默认的示例电路后, 可以通过 菜单--绘制 菜单添加自己想要的组件.

下面以添加一个继电器为例, 通过点击 菜单--绘制--无源元件--添加继电器 后便处于添加继电器状态, 此时的鼠标光标变为十字光标"+"形状:

circuitjs 添加继电器

此时只要在空白处按住鼠标左键不放拖动鼠标, 即可在面板上添加一个继电器:

circuitjs 添加继电器

如果是横向拖动便放置一个横向排列的继电器, 纵向拖动就放置一个纵向排列的继电器

注意: 根据自己所需的组件宽度和高度决定释放的时机. 当然, 拖放完成后依然可以继续调整宽度或高度.

连续添加组件

选择添加组件后, 系统默认即是连续添加, 因此添加一个组件后, 继续处在添加该组件状态, 用户可以继续拖动以添加更多的类似组件.

鼠标光标继续处在十字光标"+"形状

退出添加状态

如不再需要继续添加组件, 可以通过按 Esc 键退出添加状态.

此时光标回到默认的状态(选择组件状态)

快捷键

对于常见组件, 反复通过菜单去选择也是比较繁琐的, 系统考虑到这一点, 也为那些常用组件添加了快捷键.

点开菜单时, 位于菜单右侧的那些字母即是对应的快捷键, 如下图所示:

circuitjs 菜单快捷键

用户通过按某个对应的快捷键, 即可快速处于添加所对应组件的状态.

下面是一些常用组件及相应的快捷键:

  • ESC : 退出组件添加状态(回到选择组件状态)
  • w : 导线(wire)
  • r : 电阻器(resistor)
  • R : 继电器(Relay)
  • s : 开关(switch)
  • v : 二端口直流电压源(voltage source, 2-terminal)
  • V : 单端口直流电压源(Voltage source, 1-terminal)
  • g : 接地(groud)
  • l : LED 灯
  • t : 文本(text)
  • i : 逻辑输入(logic input)
  • o : 逻辑输出(logic output)
  • 1 : 非门
  • 2 : 与门
  • @(Shift + 2) : 与非门
  • 3 : 或门
  • #(Shift + 3) : 或非门
  • 4 : 异或门

注意: 快捷键是区分大小写的.

比如, 继电器的快捷键是大写的 R, 因此需要按 Shift + R 来激活; 如果是小写的字母则单按对应键即可.

更多的组件快捷键以及那些与拖动等相关的组合快捷键, 用户可以在菜单中找到相应提示.

还可以通过 菜单--选项--快捷键... 查看所有快捷键, 分配新的快捷键或调整现有的快捷键.

更多快捷键参考: Circuitjs 快捷键

自动吸附及对齐特性

为了方便对齐及准确连接线路, 拖动或拉长(缩短)组件时, 移动或变长变短的距离总是以某个固定值的整数倍离散地变化, 并自动吸附到最接近的一个位置上.

这为连线带来了方便, 只要拖动到大概的连接点位置并释放, 线路即能准确地连接起来.

移动组件时也能够更方便地对齐.

连接电路的一些小技巧

为快速连接组件, 添加组件或导线时, 把鼠标的光标置于待连接组件或导线的连接点上, 然后按住左键开始拖动, 而释放时光标的位置位于另一个连接点上, 则拖动结束后两个连接点即已与新添加的组件或导线连接上.

选择, 调整及移动

处于选择状态时, 单击某个组件可选中对应组件.

注意: 如果处在添加组件状态, 须先按 Esc 退出, 见前述描述.

也可以通过按住鼠标左键拖动形成一个选择框的方式选择多个组件.

按快捷键 Ctrl + A 可全选.

在组件上点击并按住不放移动鼠标(拖动), 即可移动组件.

在某些组件上, 选择某个端点上拖动, 则只是该端点位置改变, 另一端固定不动, 结果是组件(或其自带的连接线)被拉长, 缩短或是被旋转.

某些复杂的组件可能还有其它的控制点, 鼠标移上去后可显示出来, 拖动这些组件带来的变化根据具体组件情况而定.

另: 一些复杂组件可能不支持拉长, 缩短或旋转等操作.

放大与缩小

滚动鼠标滚轮可以放大或缩小整个画布.

或是通过 菜单--编辑--放大菜单--编辑--缩小 实现.

欲回到原始的 100% 的大小(没有缩放), 通过 菜单--编辑--缩放100% 实现;

上述三个操作对应的快捷键为:

  • 0 : 缩放100%
  • - : 缩小
  • + : 放大

编辑属性

在组件上单击鼠标右键, 在弹出的快捷菜单上选择 编辑:

circuitjs 组件属性值编辑

在弹出的对应组件的属性窗口上, 显示了那些可以编辑的属性值, 调整相关值, 然后点击 确定 即可改变相应属性值:

circuitjs 组件属性值编辑

添加方框及文本

除了可以添加那些功能性的组件外, 你还可以添加一些说明性的文字及辅助装饰性的方框(虚线框).

具体例子见前述 三位(3 bit)二进制加法虚拟电路示例

通过 菜单--绘制--输出和标签--添加文本 可以添加文字

也可以通过快捷键 t.

通过 菜单--绘制--输出和标签--添加提示框 可以添加方框.

运行, 停止与重置

在界面右侧边栏上, 有相关功能性控制界面.

默认情况下, 即处在 运行 状态下.

点击 运行 / 停止 按钮, 可以停止实时模拟.

此时 运行 / 停止 按钮处于红色状态:

circuitjs 停止模拟按钮状态

如果先前电路还有电流等流动, 则此刻会处于停止状态.

再次单击 运行 / 停止, 则又开启实时模拟, 电流等又重新流动.

如果发现电流没有流动, 或是相关的灯等没有亮, 或是其它异常, 你可能需要检查导线是否连接良好, 对应的开关是否处于闭合状态等.

注: 通过 菜单--选项--显示电流 可以调整电流显示状态, 如果没有勾选, 则也不会显示电流的流动.

点击 “重置” 按钮可以将电路状态重置.

如果你发现电路模拟运行有异常, 你可以尝试重置看是否可以解决问题.

开关控制

单击开关可以改变开关的闭合状态.

断开时单击可以闭合开关; 闭合后再度单击又可以重新断开.

circuitjs 开关断开及闭合状态

另: 某些数字式逻辑输入组件(可以视作为电源与开关的综合体), 没有模拟开关的那种断开或闭合的图示, 但通常会有相应的文字提示, 点击相应文字切换其断开或闭合状态.

显示为 L(Low, 表示低电压) 或 0 表示断开;

显示为 H(High, 表示高电压) 或 1 表示闭合.

circuitjs 数字逻辑开关断开及闭合状态

也可以通过查看与之相连的导线的颜色判断其开闭状态. 导线颜色为高亮的绿色表示接上了电压; 反之, 处于灰白色则暗示没有接上.

另: 接地端总是灰白色.

示波器

画布下方为示波器, 可以实时显示组件的电流, 电压等值随时间的变化(波形).

点击每个示波器左下角的"齿轮"按钮, 可调出示波器设置窗口.

circuitjs 示波器 scope

如不需要示波器, 可以在"齿轮"按钮上鼠标右键, 然后在弹出的快捷菜单中选择"删除".

拖动示波器区域上方的横线可以调整示波器区域的大小.

注: 横线缺省不显示, 鼠标移动到示波器区域上方附近时, 会呼出该横线

保存, 导入, 导出及分享

电路画好后, 点击 菜单--文件--另存为, 在弹出的小窗口中, 点击文件链接可以将电路下载保存为一个本地的 txt 文本文件.

circuitjs 另存为 save as

点击 菜单--文件--打开, 然后选择一个先前保存的电路文件, 则可以将其打开.

导入, 导出与文件的另存为和打开类似, 区别在于, 你需要自行拷贝文件内容并转储.

点击 菜单--文件--导出图片 可以将画布中的电路作为 png 图片导出.

点击 菜单--文件--导出链接 可以生成一个分享链接地址, 你可以将此地址发给别人以分享你创建的电路.

注意: 导出链接时, 因为电路内容直接以转义的查询字符串的形式附在地址后面, 所以生成的链接地址可能会特别长.

另外一种分享的方式是使用一个可公开访问的互联网资源地址.

比如, 前述的 三位(3 bit)二进制加法虚拟电路示例 就是这样一种形式. 首先把电路另存为本地的一个文件, 然后上传至你的个人网站或网盘上, 并得到一个外部访问的地址.

比如像这样的: https://www.xiaogd.net/static/circuit/c-3bit-adder-demo.txt

你需要测试在直接访问这个地址时, 浏览器能正确打开并显示这个文件的内容, 类似下图的例子:

circuitjs 分享的资源地址打开示例

然后你把这个地址取代下述这个分享链接模板上的 “{你的资源地址}” :

https://cc.xiaogd.net/?startCircuitLink={你的资源地址}

最后形成类似下述的一个完整地址:

上述例子的最终结果是这样: https://cc.xiaogd.net?startCircuitLink=https://www.xiaogd.net/static/circuit/c-3bit-adder-demo.txt

也即是资源地址作为查询参数 startCircuitLink 的值传递.

用户访问上述地址时, 应用会去对应的资源地址加载电路文件并显示.

注意: 你需要确保地址是可以公开访问到的.

比如你放在某些云盘应用上并分享时, 你作为登录用户是可以访问, 但其它人未必能访问.

另: 你的资源站点需要支持跨域访问(cors), 如果是你的个人站点, 你可以将 cc.xiaogd.net 加入到你的允许名单中.

问题及注意事项

最后说说使用过程中可能会碰到的一些问题及排解方式.

  1. 灯不亮

    • 如果你添加了一个灯, 却发现它不亮, 你需要检查连线是否正常, 开关是否闭合, 与之相连的电阻是否过大, 或者电源的功率(电压)是否足够, 另外则是灯本身的额定功率, 电阻等是否合适.
    • 在做数字电路相关模拟时, 使用 LED 灯即可; 如果你使用普通的灯, 则要注意其标称的功率及对应的电阻值是否合适(通过 右键--编辑 查看).
    • 此外, 灯还有 预热时间冷却时间 等属性, 因此, 你合上开关后, 它可能过一阵子才逐渐变亮; 关闭时, 则是逐渐熄灭.
  2. 线的交叉点

    • 当两条导线十字交叉时, 如果上面没有一个实心的小圆点, 表明两条导线并没有连接在一起;
    • 只有有小圆点时, 才说明导线是彼此互连的.
    • 红点: 出现红点说明线路重叠, 但实际上没有连接到一起.
  3. 电流过大

    • 如果整体电路的电压, 电阻等配置不合理, 可能导致出现模拟的电流过大的情形, 此时下方的状态提示文字中可能显示"电流过大"之类的异常信息, 你需要检查并设置合适的值.

反馈与联系

如果你在使用过程中遇到有问题, 可以在我的主页 果冻的猿宇宙 给出的书签链接中跟我联系及反馈.

当然, 不保证能解决你的问题~

关于 circuitjs 电路模拟器的介绍就到这里.

这篇关于Circuitjs web 在线电路模拟器应用简介的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1101286

相关文章

Spring常见错误之Web嵌套对象校验失效解决办法

《Spring常见错误之Web嵌套对象校验失效解决办法》:本文主要介绍Spring常见错误之Web嵌套对象校验失效解决的相关资料,通过在Phone对象上添加@Valid注解,问题得以解决,需要的朋... 目录问题复现案例解析问题修正总结  问题复现当开发一个学籍管理系统时,我们会提供了一个 API 接口去

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

使用IntelliJ IDEA创建简单的Java Web项目完整步骤

《使用IntelliJIDEA创建简单的JavaWeb项目完整步骤》:本文主要介绍如何使用IntelliJIDEA创建一个简单的JavaWeb项目,实现登录、注册和查看用户列表功能,使用Se... 目录前置准备项目功能实现步骤1. 创建项目2. 配置 Tomcat3. 项目文件结构4. 创建数据库和表5.

Linux中Curl参数详解实践应用

《Linux中Curl参数详解实践应用》在现代网络开发和运维工作中,curl命令是一个不可或缺的工具,它是一个利用URL语法在命令行下工作的文件传输工具,支持多种协议,如HTTP、HTTPS、FTP等... 目录引言一、基础请求参数1. -X 或 --request2. -d 或 --data3. -H 或

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

手把手教你idea中创建一个javaweb(webapp)项目详细图文教程

《手把手教你idea中创建一个javaweb(webapp)项目详细图文教程》:本文主要介绍如何使用IntelliJIDEA创建一个Maven项目,并配置Tomcat服务器进行运行,过程包括创建... 1.启动idea2.创建项目模板点击项目-新建项目-选择maven,显示如下页面输入项目名称,选择

java中VO PO DTO POJO BO DO对象的应用场景及使用方式

《java中VOPODTOPOJOBODO对象的应用场景及使用方式》文章介绍了Java开发中常用的几种对象类型及其应用场景,包括VO、PO、DTO、POJO、BO和DO等,并通过示例说明了它... 目录Java中VO PO DTO POJO BO DO对象的应用VO (View Object) - 视图对象