Simulate reflection and refraction of light.
- Simulate various light sources: ray, beam, and point source
- Simulate reflection in linear, circular, and parabolic mirror
- Simulate beam splitter
- Simulate refraction in linear or circular interfaces, including both refracted and reflected rays
- Simulate ideal lens/mirror, which obeys lens/mirror equation
- View extensions of rays to see if they converge to a virtual image
- View real images, virtual images, and virtual objects directly
- View images that can be observed from some given position
- Distance, angular, energy flow, and momentum flow measurements
- Export as SVG diagram
If you created a good sample, please submit a pull request to let others see your work!
Clone the repo: git clone https://github.com/ricktu288/ray-optics.git
Open simulator/index.html
locally in you browser (or start an http server in the repo directory if "Sample" does not work).
The structure of a tool is described in the template here. To view the code of an existing tool, you can search for objTypes['id_of_the_tool'] =
in index.js
.
Name on the toolbar | ID of the tool |
---|---|
Ray | laser |
Beam | parallel |
Point source | radiant |
Mirrors -> Segment | mirror |
Mirrors -> Circular Arc | arcmirror |
Mirrors -> Ideal Curved | idealmirror |
Mirrors -> Parabolic | parabolicmirror |
Mirrors -> Beam Splitter | beamsplitter |
Glasses -> Half-plane | halfplane |
Glasses -> Circle | circlelens |
Glasses -> Free-shape | refractor |
Glasses -> Ideal Lens | lens |
Glasses -> Spherical Lens | sphericallens |
Blocker | blackline |
Ruler | ruler |
Protractor | protractor |
Detector | power |
Text | text |
I'm sorry that most of the comments in index.js
are in Chinese. For now, you can see the template for some explanations in English.
After you complete the code objTypes['id_of_your_tool'] = {...};
, a quick way to test it without modifying the toolbar is to execute the code directly in your browser's developer tool. And when you want to choose the tool, execute AddingObjType = 'id_of_your_tool'
.
You can just search for an existing tool id such as protractor
or beamsplitter
in simulator/ToolBarViewModel.js
, simulator/index.html
, simulator/index.js
, and simulator/locales/en.js
and add the corresponding lines for your tools. And also include an exported SVG image (use the "export" button) of your tools in img/id_of_your_tool.svg
cropped to a suitable size.
If you create a useful tool, please submit a pull request to let others use your tool! (We will add the Chinese locales for it.)
Copyright 2016–2021 Yi-Ting Tu, Johnson
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Ray Optics Simulation includes or depends upon the following third-party software, either in whole or in part. Each third-party software package is provided under its own license.
FileSaver.js is distributed under the MIT license. The source code is available at: https://github.com/eligrey/FileSaver.js
canvas2svg is distributed under the MIT license. The source code is available at: https://github.com/gliffy/canvas2svg
Bootstrap is distributed under the MIT license. The source code is available at: https://github.com/twbs/bootstrap
jQuery is distributed under the MIT license. The source code is available at: https://github.com/jquery/jquery
Knockout is distributed under the MIT license. The source code is available at: https://github.com/knockout/knockout
模擬光的反射與折射
- 模擬多種光源:光線、平行光、點光源
- 模擬直線形、弧形、拋物線形鏡子的反射
- 模擬分光鏡(beam splitter)
- 模擬直線型與弧形界面的折射,包括反射光與折射光
- 模擬理想透鏡/面鏡(符合透鏡/面鏡公式)
- 顯示光線的延長線以觀察是否成虛像
- 直接檢視實像、虛像與虛物
- 顯示從某一位置能觀察到的像
- 距離、角度、能量流與動量流量測
- 匯出為SVG圖形
如果您建立了有意義的範例,歡迎發pull request給我們!