LED Matrix

As part of a project to find and organise small parts such as lego I’ve designed and built some RS485 addressable matrix displays.  These have a simple protocol to set an address (1 character) for each module and turn on one LED at a time in the matrix.   They are intended to be chained together.   There is a small step-down power supply on each board that drop the 12-24v power down to 5V using the LM2574 switching regulator.   Each board has a 4pin mini din connector which has the twisted pair signal, ground and power.

led_mat1

led_mat2

The project which will use these boards is a web application that can store where parts are stored in storage units.  The idea is that one LED in the matrix will light up to indicate the position of a part as you move through a pick list in the web app.  As only one LED lights up at a time it is possible to drive the single LED from the ATMega processor.

I originally wrote the server side project that stores where parts are in node.js, angular and MongoDB, however I have recently moved this to a Spring cloud application (mainly as a learning exercise).  The code is available at node or Spring.   The PCB layout was done in circuit maker and I will post it in a follow on post.   I am yet to check in the ATMega (Arduino) code but will package this up soon.

I’m currently updating all of this and also building some scales (connected on RS485) to weigh parts.   I’ll post an update in the next few weeks along with some instructions on how to get the code up and running.

Circuitmaker vs Eagle

I’ve been on the Circuitmaker beta since it went public and I’ve finally designed and order my first board.   The board is a RS485 addressable LED matrix (I’ll post some screenshots later).  I normally use Eagle for boards so there was a bit of a learning curve to get up and running with Circuitmaker.  In general I found Circuitmaker to be pretty good, however I’m likely to go back to Eagle for my next design.   Here are a few of the pros and cons:-

Pros

The 3D model was really useful for this design as it was a compact design were the matrix mounts on top.  The 3D model was great for checking clearences.  It also gives a slightly better indication of how difficult surface mount hand soldering will be.

While routing DRC are applied which allows you to easily and automatically avoid DRC issues.

Bigger boards than Eagle (free).

Cons

The component system can be slow and awkward to use.   All the components are looked up on Civa and have to be fully specced (i.e. values).  This is good if you wanted to produce a BOM that you can order directly from, however for the things I do I’de rather have configurable components which I can adjust and then manually enter the BOM with my supplier of choice.  You also need to have a network connection at all times.

In general I found it has a lot of spinners while you wait for network.  Even clicking a component on the schematic has a significant delay.

Windows only.  I’m normally a Mac user and I like being able to share my designs between my Mac an PC.

It has its own version control system.  As I like to store my designs on github which I can link too, the fact that Circuitmaker has its own internal eco system, which doesn’t seem to be easy to share outside Circuitmaker, is not ideal.  Some users have expressed issues with not having closed designs.  Personally I don’t think this is a problem as all my designs tend to be open.

Gerber export was tricky as it doesn’t output a board outline by default.  You have to add a keep out layer for the board shape.

Conclusion

I think if Circuitmaker was a little less sluggish and maybe had a better component system  it would be preferable to Eagle in a lot of cases for me so I’ll be looking at future updates to see if the situation improves, however for the time being though I’m going to go back to Eagle.

Ethernet motor control board

I’ve got a prototype motor control board up and running.   The board has 4 motor channels and is based on the ATMega and ENC28J60 Ethernet controller.  It has 2 through hole mounted H-bridges to control the motors.   The schematics are available on github and some example code will be there shortly.

I’ve done some testing on channel one and it seems to be all working correctly.   I’ve built a simple test UDP server using the Arduino libraries and this is all working correctly so far.   The only issue is that the original design did not use the PWM pins for the enable lines so there will need to be some bit banging for speed control.   I intend to update the design in the future to enable this.

A few pictures:-

Motor controller assembled

Motor controller assembled

Testing the motor controller

Testing the motor controller

These will eventually make it into the underwater ROV.   The idea was to control over ethernet and send video back over ethernet using a cheap IP camera.

Boards

I have received the latest revisions of a few boards I recently ordered.  I assembled the the newest Gardenstation board and there was an issue with shift registers (MR was being held low).   Some board hacks got it working and I’ve fixed the Eagle file and switched the display header pins around (will update in github shortly).

I’ve assembled on ROV control board although at present I’m not able to burn the bootloader on the AVR.   I suspect there is some issues with the soldering of the ENC ethernet controller.   Elecrow removed the solder mask between the ENC chip pins which made it extremely hard to hand solder.

I’ve embarked upon a reflow oven project (based on a Kmart $35 toaster oven).   I had a quick test at the weekend and managed to successfully reflow some parts to a test board.   The thermocouple I’m using has been slow to respond (my voltmeter one is much quicker) so it got a bit too hot.   The Arduino control code is available here https://github.com/markpudd/reflow_oven.

Quick Update

This is a quick update as the blog hasn’t been updated in a while.   I’ve been traveling so haven’t had a lot of time to post.   The arcade machine is finished bar the marque at the top of the cabinet and I will try an post some photos next week. I’ve made some minor changes to the Garden Station in order to add a power light and fix a few minor issues in time for the Australian spring/summer!  I order new PCBs from http://www.elecrow.com which I received last week however I’m currently in the US so won’t be able to assemble until next week. Finally I designed a small board to provide AVR with Ethernet and an H-bridge to use in a ROV project I’ve started to build.   The board parts have all been received and are waiting for me when I return home next week.   The design is on github – https://github.com/markpudd/rov_control.   I’ll probably hand solder the first one but I’m thinking of making reflow oven for future projects.

Arcade Control Board

I’ve finally got round to posting about the raspberry pi arcade.   I’ve build an ATMega based board to convert all the controls to SPI for the raspberry pi, modded the ada-friut retro arcade library to use the SPI based control inputs and etched a PCB for the control board.

I home etched the PCB using the toner transfer method which I find to be a bit of a pain to get a decent result.  The best way I’ve found is to print on magazine paper, then iron on for 5 minutes and finally run through a laminator four or five times.  Here is the result:-

 

board

The board does a few thing.   It has 2 9-Pin D connectors for the player 1 and player 2 controls.   The layout is the same as an old atari joystick (in theory you could plug in old Atari comparable joysticks).   The unused pins on the D connector are used for the extra buttons and the player 1/2 buttons.  The joystick axis connect to analogue inputs on the ATMega to save a few pins.  There is also an input for a coin mech to add credits, at the coin mech requires 12v the board requires a 12v and 5v supply.   The 5v supply goes thorough a regulator so that the board runs at 3.3V (8Mhz) this removes the need for logic level conversion between the board and PI.

The above pictured board had a few issues (it also had a zener for the coin op mech which has been removed).   I put a few jumper wires on the bottom to correct the issues, most of which were due to eagle not connecting nodes so I should probably pay more attention to the ERC check.  An updated design is checked int github at https://github.com/markpudd/PiArcadeBoard.  Here is the populated board connected up:-

Boardsfixes

The other thing I’ve done is sprayed the cabinet black, added the coin mech and stated to put on the plexi glass:-

Arcade

Only a couple of more things to finish (bevel and marquee) so will post later in the week with the finished result!

 

Arcade Controls

The Raspberry Pi arcade now has controls!

Internals

The controls have been connected to an Arduino which then uses SPI to connect to the Raspberry Pi.   The following hardware design was used:-

PI-Arduino-SPI-lc

Its important to use a logic level converter for the 5v to 3.3v conversion.

After hunting around for good ways to simulate key presses on the Pi I stumbled across the Adafruit retrogame code which uses GPIO as inputs.   I’ve forked this on github and changed it to request the state of the buttons over SPI and update the presses.  It currently polls and doesn’t seem to be using much CPU, although it would be possible to use a separate GPIO pin to tell the Pi that there is a change in state.   The code is available at https://github.com/markpudd/Adafruit-Retrogame.   This also includes the Arduino code to connect the inputs too.

The SPI protocol basically send an 0xFF command to the Arduino which returns 3 byte, which are P1 status,P2 Status and Aux Status.   The Aux status is used for P1/P2 button and the coin mech.

I’m currently building an input board to replace the Arduino which is basically the ATMega broken out with some connector for P1/P2 and aux.   I’ll publish this at the end of the week.

I also added some audio amplifier and speaker this week.  There is still a bit to do on this project such as getting some artwork printed, painting the cabinet and fixing up the monitor mounts!