DIY F/Stop Timer Construction
If you build this, please contact me (email address is in the headers of all the source files) as I'd like to have some idea of how many of these are out there. Of course if you have suggestions or bug reports, please send them in too.
Parts and Resources
You will require:
This was my first attempt at using KiCad so library files ended up spattered all over my filesystem. I've tried to include everything in the above zipfile but if there's something missing (note the modules and library directories in the zip; they are critical) and it won't build then email me. The plot subdirectory contains gerbers ready for PCB manufacture.
You don't need to use the official PCB, you can easily make up the circuit using an Arduino Prototyping Shield (about $3 on eBay) and a couple of hours with the soldering iron.
Practically everything can be bought from either eBay or your local electronics store; you shouldn't need to make an order to a huge online place like mouser/digikey but you can if you want.
From the source code archive, copy the Keypad, RotaryEncoder and FstopTimer directories to your Arduino Libraries directory and the fstop_driver (top level sketch) to your sketchbook. Make sure it compiles successfully.
Separate the PCB using a dremel, hacksaw or guillotine, following the lines as marked. You will need the main PCB and the rotary encoder PCB at this stage; put the TSL230/TSL235 PCBs aside for now. You may want to trim some more off the rotary encoder PCB in order to make it fit in your case, just don't encroach on where the pins get soldered.
The power supply components on the board (bridge and 470uF cap) should be left off if you're running on USB power or via the DC jack on the arduino, but are needed if you want to run from a 5VAC transformer. You could also use a 5V/0.5A switchmode supply module connected directly to VCC.
If using a TTL-compatible output device, e.g. anything with an optocoupler like an SSR module, connect it to the OUTTTL header and leave off the relay driver components (1k resistor, BC548 and 1N4004 to the left). Otherwise, connect your relay coil to OUT and short the OUTVCC header to set the relay's coil voltage to 5V. If the relay is not 5V, you can supply the higher voltage via the OUTVCC header - see the schematic for details. Use the prototyping jumper wires to make the connection from the timer PCB to your relay module.
If you want the timer to control your safelight (off during exposures for better image visibility and exposure metering), you must use an SPDT or DPDT relay. Connect your safelight using the NC connections and the enlarger using the NO connections, with power at Common. Don't forget to connect your chassis to mains ground for safety, unless you are using a sealed relay module like powerswitchtail.
The footswitch (NO momentary) is wired in parallel with the press-switch on the rotary encoder. Mount a 3.5mm panel socket on your case and connect it to the FOOT (tip) and GND (sleeve) pins on the PCB using the prototyping jumper wires. This is the means by which the timer PCB is grounded; if you don't have a footswitch socket then you should connect a separate wire from one of the GND pins on the timer to your chassis. You must not rely on an external (e.g. phone charger or DC wall-wart) for safety grounding as it may be unplugged!
The collector resistor for the LED backlight is required ONLY if the LCD module does not have one on-board. If you are using a JHD162A or any other module with included resistors that wants 5V for the backlight, then use a wire link here instead of a resistor. It's the 1k resistor closest to the centre of the PCB. If your backlight is raw LEDs with no current-limit resistor provided on the LCD module, choose whatever value your backlight requires (for a 5V supply) and install it here.
The rotary encoder gets mounted on a little daughter board and connected to the main board using 6 pins of header+sockets; this is to raise it to the front panel, level with the LCD. Solder the sockets onto the board first (you can't get to them once the encoder is soldered in!). You will need to put a small piece of paper or plastic under the encoder (they usually have a metal underside) to stop it shorting out the socket pins that it's right on top of.
Solder a row of pins onto the keypad. Make up a ribbon cable to go between the timer PCB and keypad - probably about 10cm depending on your case layout. To crimp the IDC (insulation displacement) connectors onto the ribbon, use a small vise: gently hold the connector in the vise jaws without compressing it, insert the cable and ensure it's properly lined up, then tighten the vise slowly until you feel the insulation puncture and/or the connector is clearly fully-crimped. Do not overtighten and crush the connector!
The ribbon connector has 16 pins (2 rows of 8) and the keypad connectors have just one row. One of the connector rows will be unused; use the outer row at one end and the inner row at the other end of the cable. If the keypad does nothing at all (you can't get past the startup text), you've probably plugged it in wrong (row mismatch) so there is no connection.
The LCD is mounted using a pin/socket row and optional 10mm PCB standoffs; the exact mechanical arrangement is up to you. In my timer, the LCD is bolted to the front of the case and attaches to the timer PCB only via the pins; the other option is to bolt it to the timer PCB with standoffs and leave it floating with respect to the case. Same applies for the rotary encoder PCB, but it must be screwed to the case front with its integral nut to prevent stress on the circuit boards.
Put it all in a box, compile the source and flash the Arduino. Plug the USB port of the Arduino into a USB power source (e.g. iPhone charger), it should boot up and show its welcome message.
If you see absolutely nothing on the LCD, adjust the contrast pot until text appears. If you see a row of solid blocks, it means you've not programmed the arduino correctly, e.g. selected the wrong PCB revision in fstop_driver.ino. If you see text but the backlight is off, check that you have chosen the correct backlight current-limit resistor, which is 0R (wire link) when using a JHD162A. Also go into the Config menu and attempt to change the backlight intensity as it may just be turned off. If your backlight is not red, you bought the wrong LCD!
If the keypresses result in unexpected behaviour, you probably have the pins to the keypad in the wrong order so it thinks you're pressing different keys. The most likely thing here is that you should invert the value of KEYPAD_REVERSE in fstop_driver (has the same effect as turning the cable around, which can be physically difficult). If you have a keypad with an unusual pinout, you will need to change the SCANCOL and SCANROW definitions in fstop_driver; you can re-order the pins in each group but must not swap pins between the groups.
If your rotary encoder causes the exposure to change double the expected value for each click, set ROTARY_DBLSTEP to 1 in fstop_driver. Alternatively if you get a change only on every second click, set it to 0. If your rotary encoder is backwards (clockwise decreasing), then toggle the value of ROTARY_REVERSE in fstop_driver.
Once you have all the user interface bits working, you will find that all the stored values (e.g. drydown factor, warmup exposure, test-strip values, etc) are completely invalid (because the EEPROM is blank) and causing strange times to be displayed. Go into the timer's Config menu, give it valid numbers, and it will store them.
Separate small PCBs are provided to mount a TSL230 or TSL235 and connect it to the main PCB via an 8-way ribbon cable. There is not yet any software support for these sensors, so just put them aside somewhere safe.
Fresh PCBs (revision A):
Assembled board, top:
With annotations as to component purpose
Assembled board, bottom:
Note that the contrast-adjust pot (blue thing) for the LCD has been mounted on this side for accessibility, and the pins for the Arduino go here too because the board will stack on top of the Arduino.
Rotary Encoder daughterboard:
with pin header on reverse:
Complete assembled stack, showing Arduino, new PCB and LCD:
Note that you can also see the keypad attached by ribbon cable.
Beginning installation in aluminium case (forgive the clumsy Dremel-work):
You can see here that I've removed the power-filter capacitor (this instance doesn't use it because it depends on USB-power) in order to clear the keypad. It's very very tight in that case...
Showing how the PCB stacks line up to get the encoder at the right
Installation of solid-state relay:
As you can see here, the case I chose is slightly too small for the PCB, so I've had to trim the right hand side fairly heavily. It doesn't encroach on any tracks, but it was a pretty ugly hack to cram it in there. Similar trimming of the rotary encoder PCB was required and that came very very close to the pins.
Finally, the completed item:
The 3.5mm port you can see at front-left is for attaching the foot-switch. It is connected in parallel with the push-switch of the rotary encoder.
I originally intended for the case to have a male/female pair of IEC sockets and an internal power supply transformer but it was nowhere near large enough to accommodate all of that. This particular instance therefore depends on an external USB power supply and the mains connections are flying-leads.