Now that the pit has arrived it’s time to start putting things in.
with the pit I’ve ordered 3 8″ LCD screens, two for MFD and one for the central console. I have my 27″ monitor and my PC to think about.
placing everything wasn’t easy, I need to think about where the power outlets are in the room, what goes to which outlet (I’m not fond of connecting the massive gaming rig to the same outlet with a treadmill or my soldering iron), where the window is (TIR hell!) and where the door is (I hate sitting with my back to the door – It makes me feel uncomfortable).
while I was trying to figure out where I would place the pit in my workroom, the Better half has suggested we trade room as here work room is more simple and there a lot of stuff in what was my room that are just bulky. So we swapped rooms, now I don’t have to deal with the treadmill, and I only have a closet full of shoes I need to allow access to.. Not the perfect man-cave, but hey, you take what you can get.
As a person grows into flight sims, his list of toys is getting longer (usually). Personally I’ve started collecting them things back in when I was 6 (circa 1989). My first proper stick I got at the age of 13, a CH FlightStick pro with the CH throttle – I still have them laying around. by 2011 my gaming station looked like this.
this covered the “basics” (or at least for a low budget enthusiest):
X-52 Pro
TIR4
TM MFD’s on Samsung U70 (USB 7″ screens).
with 20″ main monitor.
upgraded with time, I ended up with this:
TM Warthog
Saitek Combat pedals
TIR4 (same unit)
TM MFD’s (same units)
27″ Main Monitor
18.5″ LCD for displays
But after, after all the tinkering with the DED and Arduino,
I suddenly had to have some more. Armed with a itchy trigger finger and a surprisingly supportive better half (I still have no idea what went through her head) I went ahead with the “must have a pit” plan.
We’ll after we got the DED and FuelFlow sorted out it’s time to think on how to get everything packed for the real pit installation, in addition, when we have things running we get a better clue on available memory and CPU cycle limit. When I’ve changed the way the DED worked, I suddenly realized I’ve cleared the exact amout of memory to drive a second DED, or to be more precise, to drive the PFL. The PFL is identicle to the DED in size and resolution, the the adaptation was very easy, on the PC side of things, PFL uses exact same structure in the SharedMem. so it’s a matter of reusing the DED code.
OK, So we got the DED and FuelFlow sorted out. we got a way to get the data over and drive the screen. Before we go on, let’s talk a bit about Arduino boards.
Arduino Boards are ATMEGA based development board, putting the I/O pins available for quick connections. Basic Arduinos traditionally have 13 available digital I/O pins and 6 ADC 10bit “analog” Inputs.
the “classic” arduino board is the Arduino Uno.
Based on the ATMEGA328P, a 16MHZ, 2K RAM chip that uses an on-board RS232 chip to handle serial communication via 2 of the 13 IO pins. I’ve done my initial prototyping work on this board and it works with comms of up to 96000 baud reliably. you might start catching some errors but YMMV.
on the other side of the scale there is the Arduino Due.
the Duo is ARM based 84MHz chip with 96k RAM, it has 54 IO pins, 12 ADC pins and so on. it’s bigger then the Uno.
in the middle this is the Leonardo, it’s about the same size as the Uno, but uses a different Chip, the ATMEGA32u4. However, it’s his little brother the Arduino Micro, is the one I’ll focus about. the 32u4 is pretty much identical to the 328P with a few exceptions, it has 2.5K of RAM, a bit more I/O pins, but the most important feature on the chip is that it has native USB capability, which means it can do serial communication much faster then the Uno. the added bonus is it’s size, the Micro is TINY, it’s slightly less the 5cm long, and has male headers in two rows, which makes it breadboard compatible, and allows an easier mounting . So I chose it and everything I wrote was Micro Optimized. However I do indend to try and make the code in an Uno version (but with diminished capability) and in Due version (as Acef already has on – so why not).
now that we covered the basics, and we know how to run our FuelFlow, we can continue our dive into the project. DED screen was chosen as it is the closest I could get to the real thing from the selection of avaiable hardware. I chose the BuyDIsplay 2.8″ OLED Yellow-On-Black another option would be the New Haven 2.8″ OLED Yellow-On-Black they both use the same u8glib constructor and are interchangeable (different wiring is required of course).
Let’s look back at the DED in the “flightData.h” file.
in C a string is a char array ending with null character (ASCII 0)
so we actually have 5 lines of 25 chars ending with a 0 (from now it will be referred as “\0”)
DED is actually 5*24, so I don’t know why the extra \0, so we can safely only transmit the 24 bytes.
in Part 1 you saw a video with an early code, in that code I’ve sent the two arrays and drew them with the arduino, that required multiple passes on both arrays, costing many CPU cycles. I’ve decided to do the manipulation on the computer side, sending only one ANSI array. However that required a special font to be loaded onto the Arduino/Display. The font was drawn as TTF, re-positioned to correct ANSI position, and converted to the Format u8glib can use.
I’ve created the font using fontstruct and it’s available here
I ofcourse had to write the code to normlize the entire thing
The arduino side is very simple, so I will not elaborate much
char DED[5][26] = {{ 0 }};
void readDED() {
for (short i = 0; i < 5; i++) {
Serial.print("D");
Serial.print(i);
Serial.flush();
Serial.readBytes(DED[i], 25);
}
}
void drawDED() {
/// Begin Picture loop ///
dedDisp.firstPage();
do {
for (unsigned short i = 0; i < 5; i++ ) {
dedDisp.drawStr(DED_H_CONST, i * DED_CHAR_H + DED_V_CONST, DED[i]);
}
} while ( dedDisp.nextPage() );
/// End Picture loop ///
}
Combining this, with the code we saw in the previous part, gives us a DED and an animated FuelFlow. in the video you can also see the indexers modeled by 6 leds, but that code uses a different logic, and will be covered in a later post.
BTW – The code shown here is pretty old, so there is a bug in the FuelFlow code used here, the snippet in Post 2 is already corrected (one of the benefits of starting a blog late)
Let’s talk about a bit about the technical stuff. I think that going over the technical aspects will make some sense, and naturally help others in their quest.
I’ll have posts like that from time to time, covering technical aspects of the project. Which means that code examples, circuit schematics and random technical mambo jumbo are all legit in this type of posts.
Well, Acef has asked me for advice about his pit. I’ve been playing around with BMS sharedmem and Arduino just to get the hang of it. I’ve starded by getting an Arduino to show fuelflow on a simple 2X16 LCD and drive a servo to show Airbreak – all of that was done around May 2013 and I haven’t touched it since. until June 2014.
I’ve started toying around again with the Arduino After speaking with Acef about the progress of his pit. Using some LCD screens I had lying around I’ve started working on the code. it took me a few days but I finally got it to do some reasonable work. still had issues with highlights.
Well I’ll start off by saying that the Blog is a late start.
I’ve known from day one that I’ll need to blog this project, for others, as well as for myself. however this blog is starting in somewhat of a delay, as i’ve done some work already and got ahead. I’ve tried to document what I’ve done so far for this blog. but post affect posting, is a bit different.
With that said, I’m not posting any progress reports yet, as I have some issues to solve first.
What I’m actually trying to say, without much success is:
Welcome to my Pit blog.
I’m building an F-16 pit, for falcon BMS, As I mostly fly IAF F-16C Block 30 “Barak I” in ITO (which we at the 108th are developing), the Pit will be ITO block 30 inspired, I’ll try to walk the line between the real IAF block 30 and the BMS version of it.
The pit is based on the “ViperWIng” pit. Electronis are currently planned for Arduino, but more on that as we progress!
the THC construction. I have decided to use the services of a profesional carpenter to make the cuts I need. the cost was minor – around 15$. board are 18 mm and 4 mm plywood.
These are most of the parts – some pieces were too small for a “production line” carpenter to do (they do mostly furniture, and getting them to do all the fine details I need would have blown the price beyond any proportion). So I still have some fine tuning to do.
The THC box will have an opening on the right side (Keypad would be attached on the left) the opening will be covered with a slide door. this will allow access for maintenance. internaly the Box is partitioned to two. Front segment will house the Stick and support the mechanics, it is made of a thick back plate (sitting in the center of the outer box) and a very thin front plate to minimize the lose of stick length during it’s travel. Aft compartment is a sliding door with a thick plate on which the IPAC sits. it is also to allow easy access. (In theory I can get the whole controller out and work on it. Practicly I’m afraid the cables from the Keypad are too short :(. (I was originally planning on using IDE connectors – but My soldering is so bad, I’m better off without it).
Visible in this Image are the Middle buffer and the Aft slide door.
This is with the Front Buffer.
the parts not shown here are the right wall (short piece that will sit on the front, mainly to provide 4 side support of the plywood in front) and right slide door. I need to cut it and make a slide in it – in addition I still need to cut “handles” for the slide doors.
I also need to drill holes for the USB cable for the controller, for the cabling from the keypad, holes on the Mid buffer for the Guide rails that will allow the Stick to move back and forth and last are attaching two stubs to the mid buffer (and drill matching holes on the left wall of the box).
Some of it does not make sense right now – I know, I just can’t get it to make sense in writing nor in 2D sketches (and I cant really draw 3D). But hopefully as the Build will continue, it will make more and more sense.
And this is the link for the PDF with the sketches. all the notes are in Hebrew (sorry, didn’t think about it while I made it – I was too busy making it to make sense to the carpenter). All measurements on the PDF are in centimeters, but use them as guidelines only, do the math acceding to the wood you are going to use, 10, 12 and 15 mm plywood would be just as good, but will require you to do your calculations from scratch.
grooves were planed to be 3 mm deep and 4 mm wide, the equipment limitation stated 4 mm deep, I have fixed the measurements on the fly for some of the parts, other got some extra material I need to shave of with a file or sandpaper. in addition the grooves go from edge to edge of the wood, and not stop short as with the sketches.
then we need to wire up the key pad. each keypad PB will be connected with two lines. One unique for each of them – for a key stroke. Second will be connecting all the PBs to a single keystroke on the I-PAC that will function as a CTRL, SHIFT, ALT or what ever will be required to activate the layout for the keypad.
again, going with MAME project lines. I’m using CAT5 Network cables.
Word of advice – if possible use CAT5E cables and not normal CAT5. The CAT5E have thick copper wire as a conductor. while CAT5 use multiple very thin wires – that are much less durable.
This is how it looks like after all the wiring is done.
The last step that still needs to be done is connecting a diode to every lead for the joint connector.