Skip to content

Latest commit

 

History

History
81 lines (56 loc) · 2.91 KB

README.md

File metadata and controls

81 lines (56 loc) · 2.91 KB

UniCHIP8

A CHIP-8 implementation for Unity 3D, based on Laurence Muller's tutorial, "How to write an emulator (CHIP-8 interpreter)"

Creating a basic CHIP-8 virtual machine

First, import the UniCHIP asset package into your project.

Getting started

  1. Drag a UniCHIP8 prefab from the prefabs folder into your scene.
  2. Optionally, type in the name of a ROM file located in the Roms folder
  3. Ensure the UniCHIP8's Power State property is checked
  4. Position the camera near the quad so it takes up most of the view
  5. Press Play in the Unity Editor

Creating a basic UniCHIP8 prefab

  1. Create a quad named Screen
  2. Assign the UniCHIP8Screen material to it
  3. Create an empty GameObject named UniCHIP8
  4. Add the UniCHIP8 component to the UniCHIP8 GameObject
  5. Assign your Screen quad to the UniCHIP8's Screen Object property
  6. Optionally, assign the beep sound to the UniCHIP8's Speaker Sound property
  7. Optionally, type in the name of a ROM file located in the Roms folder
  8. Ensure the UniCHIP8's Power State property is checked
  9. Position the camera near the quad so it takes up most of the view
  10. Press Play in the Unity Editor

Interacting with Unity

UniCHIP8 offers a number of custom opcodes to interact with your scenes.

To enable UniCHIP8 Extensions:

  1. Disable the Compatibility Mode property on your UniCHIP8 instance
  2. Add a UniCHIP8 Router from the prefabs folder
  3. Assign it to the Router property on your UniCHIP8 instance

To make the UniCHIP8 aware of other GameObjects in a scene, they must have the UniCHIP8Node component on them and have a UniCHIP8Router assigned.

UniCHIP8 Opcode Summary

Misc
  test              call              broadcast
  send              reparent          destroy

Transform
  move              rotate            scale
  moveX             rotateX           scaleX
  moveY             rotateY           scaleY
  moveZ             rotateZ           scaleZ
  lookAt

Create
  create            createCube        createSphere
  createCylinder    createCapsule     createPlane
  createQuad        createEmpty       createDirectionalLight
  createPointLight  createSpotLight

Materials
  addMaterial       setMaterialColor
  
Lights
  setLightColor     setLightIntensity

Machine state
  clockMultiplier   logging           compatiblityMode
  pause             halt              powerDown

See the UniCHIP8 wiki for more information.

License

UniCHIP8 is made available under the MIT license. See LICENSE.md for additional details.

Other

The default UniCHIP8 system beep sound is modified from beep-6 in "Interface beeps"