Search the Community
Showing results for tags 'arduino'.
-
I have a touch screen monitor below my main one when I fly in flight simulators like Falcon BMS or DCS or Microsoft Flight Simulator. It's great for the MFD buttons, as opposed to the actual wired USB Thrustmaster MFD's physically attached to the screen like I used to have, and I can use the monitor for other things, too. But one thing I would love to have attached to the screen would be the Course and Heading knobs of the HSI (horizontal situation indicator) . It would need to be removable so I can store it when not in use. I've heard about a micro-suction tape that can stick to anything smooth and flat without leaving a residue or losing stickiness, so this is a good excuse to buy some and play around with sticking things to my monitors. ← On the left is the (green) Arduino Micro board I used to test the concept with a rotary encoder on a breakout board, where I wrote the initial sketch with the Joystick and Encoder libraries. Later, because I didn't want to sacrifice my Arduino Micro to this controller, I bought a 3 pack of these much smaller Sparkfun Pro Micro clones for fifteen bucks (blue one in the middle). That one is gonna stay there for future tests and such, they'll be the heart of many projects in the future since they cost so little and include so much! My DIY USB Game Controller - Rotary Encoders as Course & Heading Knobs for Falcon BMS / DCS / FSX *parts list with links at bottom The initial goals I had for this project were: Two Rotary Encoders with Push Buttons recognized as USB Game Controller in Windows Thin and flat, without taking up too much viewing space on the monitor Can stick and restick to the monitor with micro-suction tape USB connector can be removed so it can be boxed (NetDot magnetic) Fine control for one-degree per detent and Fast Speeds for turning quickly Encased in semi-rigid form like shrink wrap so it won't scratch the monitor Total cost for one single unit less than $10 First, I affixed the Rotary Encoders and the Pro Micro clone to an 8cm x 2cm prototype PCB with a couple header pins bent outwards and crimped down, and with the two blue solid copper switch wires soldered in place from the top. I also ran the 10k Ohm resistors for the switches now. These are for the push buttons built into the rotary encoders, and although they only have two pegs on the actual component, they require three wires from the controller board (ground, 5 volt power, and the blue switch wire going to the Pro Micro). All this added plenty of structure. There is no wiggle or play, I'm not gonna try to break it, but it is very rigid now. Here's a close look at the first stage of soldering. (okay, don't look too close) I don't have the highest quality tools or solder, or even a lot of skill and experience at this, but it's good enough -- and good enough should always be good enough for a DIY project for personal use. If I wanted to, I could order a custom circuit board if I was going to make a bunch of these, but I'm happy as it is. It is so cheap to buy some of this stuff, if you messed up, you can always just buy another. Those Pro Micro controller boards cost about as much as a value meal at a fast food joint, so you can literally afford to make mistakes as you learn even if you're on a very tight budget like I am. A homemade carbon filter fume extractor, a simple soldering iron with a power switch and a temperature controller, some handy dandy helping hands and that brass soldering tip cleaner make little projects like this very easy, and all these items together costs less than the Logitech mouse to it's right. Good enough to play. If anyone reading this has any idea to get into working with things like this, my advice is to jump right in, get the most basic stuff you can get, not the cheapest, but things with good reviews from some good online store like Amazon, Sparkfun, Adafruit, etc. Soldering the top side here, used one of the helping hands to hold a string of solder from the spool. When I'm dealing with tiny bits that are between 0.5mm-2mm, anything that helps is appreciated. One slip and this 225C soldering iron would burn through any one of those tiny chips or components on the board. I find myself holding my breath and doing one or two, then letting go for a sec. I had to redo a few, and I always wait for it to cool down so I don't transfer too much heat to this poor little board. I had a few bits of solid copper wire with colored insulators, from a breadboard jumpers kit, so I cut some to length, but used others as is. This resulted in an odd looking crossover of the Orange and Yellow wires, but they are not taller than the micro USB port on the other side of the board and that's fine. Once I was all done, I tested every connection for continuity and unintentional bridges, and it all checked out, so I encased it in shrink wrap. By some sort of miracle, it works, it looks decent, and I think that will do just great! I connected it to the computer and uploaded the sketch, which I had to modify slightly since I used a few different pins for the push buttons on the rotary encoders, now at pins 15 and 6 instead of 6 and 7. I am thoroughly hooked on these NetDot magnetic adapters. When I looked at the reviews for Pro Micro boards, one of the only issues I saw that I'd be concerned with is accidentally popping the micro-USB port off the Pro Mini board if dropped or yanked too hard. A magnetic connector completely eliminates this issue, as well as the standard wear and tear issues that plugging and unplugging creates over time. And they're as cheap as regular braided USB cables, too. Why not? Here it is connected to the touchscreen monitor. It is far more satisfying to have tactile dials for these knobs than trying to make little circles on the screen with my finger over the touchscreen dials. The micro-suction tape keeps it in place and actually has some grab when trying to pull it off the screen. I've started using a peeling action but I doubt the screen would ever have problems. I might get a 3D printed case someday and maybe even a 90 degree angle connector so the cord goes back behind the monitor naturally instead of downwards, but for now, it's done and working great. Turning the dial with the most basic rotary encoder sketch from that Arduino library results in a "one degree per detent" meaning one turn is one click, and one click is one degree. No matter how fast you turn it, with 20 detents per 360 degrees with these encoders, it would take FOREVER to turn the dial from heading 000 to 180!! I wrote two separate jump speeds to detect how fast the dial is being turned, one jumps 18 degrees per click, and the other 30 per click. Now, it's easy to twist the dial fast to get it spinning fast on screen, while also being able to dial in one degree at a time when needed. All in all, it was a fun project and it's made me think seriously about getting a 3D printer someday to make little plastic cases for things like this. Here's the code if someone wants to use it (or modify it to make it better): Rotary Encoders HSI Course and Heading Knobs.ino for Arduino IDE https://pastebin.com/drUnCfKN /* Simple HSI Knobs Sketch for Falcon BMS / DCS / FSX * for Arduino Micro/Leonardo / Sparkfun Pro Micro or equiv. clones * by SemlerPDX June2019 * VETERANS-GAMING.COM * * Pins: * Rotary Encoder 1 - (OUTA-OUTB-SW) = Arduino Pins (0,1,15) * Rotary Encoder 2 - (OUTA-OUTB-SW) = Arduino Pins (2,3,6) * * Encoder Library * http://www.pjrc.com/teensy/td_libs_Encoder.html * * Joystick Library * by Matthew Heironimus * https://github.com/MHeironimus/ArduinoJoystickLibrary */ #define ENCODER_USE_INTERRUPTS #define ENCODER_OPTIMIZE_INTERRUPTS #include <Encoder.h> #include <Joystick.h> //Tell the Encoder Library which pins have encoders Encoder axisXRotation(0, 1); Encoder axisYRotation(2, 3); //Rotary Encoder Push Button Pins int buttonArray[2] = {15, 6}; //Rotary Encoder Interrupt Pins int EncoderPin0 = 0; int EncoderPin1 = 1; int EncoderPin2 = 2; int EncoderPin3 = 3; //Delay Time between loops int debounceDelay = 260; //Variables to compare current to old values int oldX = 0; int oldY = 0; int RxAxis_Value = 1; int RyAxis_Value = 1; //Intervals for Jump/Warp Speed Rotations int JumpSpeed = 18; int WarpSpeed = 30; //Set generic joystick with id 42 with 2 buttons and 2 axes Joystick_ Joystick(0x42, 0x04, 2, 0, false, false, false, true, true, false, false, false, false, false, false); void setup() { //Set Encoder Pins as Pullups pinMode(EncoderPin0, INPUT_PULLUP); pinMode(EncoderPin1, INPUT_PULLUP); pinMode(EncoderPin2, INPUT_PULLUP); pinMode(EncoderPin3, INPUT_PULLUP); //Loop through buttons and set them as Pullups for(int x = 0; x < sizeof(buttonArray); x++) { pinMode(buttonArray[x], INPUT_PULLUP); } //Set Range of custom Axes Joystick.setRxAxisRange(0, 359); Joystick.setRyAxisRange(0, 359); // Initialize Joystick Library Joystick.begin(false); } void loop() { // Loop through button pin values & set to Joystick for (int x = 0; x < sizeof(buttonArray); x++) { byte currentButtonState = !digitalRead(buttonArray[x]); Joystick.setButton(x, currentButtonState); } // Read "Heading" X Axis Rotation Encoder Knob int newX = axisXRotation.read(); if (newX > oldX) { //Determine speed of increment & set output int difX = newX - oldX; RxAxis_Value = speedVal(difX, RxAxis_Value, 1); Joystick.setRxAxis(RxAxis_Value); axisXRotation.write(newX); oldX = newX; }else if (newX < oldX) { //Determine speed of decrement & set output int difX = oldX - newX; RxAxis_Value = speedVal(difX, RxAxis_Value, 0); Joystick.setRxAxis(RxAxis_Value); axisXRotation.write(newX); oldX = newX; } // Read "Course" Y Axis Rotation Encoder Knob int newY = axisYRotation.read(); if (newY > oldY) { //Determine speed of increment & set output int difY = newY - oldY; RyAxis_Value = speedVal(difY, RyAxis_Value, 1); Joystick.setRyAxis(RyAxis_Value); axisYRotation.write(newY); oldY = newY; }else if (newY < oldY) { //Determine speed of decrement & set output int difY = oldY - newY; RyAxis_Value = speedVal(difY, RyAxis_Value, 0); Joystick.setRyAxis(RyAxis_Value); axisYRotation.write(newY); oldY = newY; } //Send Joystick info through USB Joystick.sendState(); delay(debounceDelay); } //Function to set Rotation value adjusted for the turning speed int speedVal(int dif, int val, int dir){ if (dif >= WarpSpeed) { if (dir == 1) { val = val + WarpSpeed; }else{ val = val - WarpSpeed; } }else if (dif >= JumpSpeed) { if (dir == 1) { val = val + JumpSpeed; }else{ val = val - JumpSpeed; } }else{ if (dir == 1) { val = val + 1; }else{ val = val - 1; } } //Correct Rotation within 360 deg. if (val < 0) { val = val + 360; }else if (val >= 360) { val = val - 360; } return val; } Here's a cost breakdown: Pro Micro (clone of Sparkfun Pro Micro board sold by KeeYees) (3 pack) - $15.99 https://www.amazon.com/gp/product/B07FXCTVQP/ $5.33 per board PCB Prototype Board Kit - $15.99 https://www.amazon.com/gp/product/B07CK3RCKS/ $0.25 (just a guestimate - it's one part out of a huge kit) 360 Degree Rotary Encoders (5 pack w/knob caps) - $8.89 https://www.amazon.com/gp/product/B07DM2YMT4/ $3.56 for 2 dials Microsuction Tape (25cm X 30cm Sheet) - $14.95 https://www.amazon.com/gp/product/B00M7FC1K8/ $0.12 (just a guestimate - used 1.5cm x 6cm strip of a huge sheet) NetDot 5ft Braided Magnetic Tip USB Micro Cable (3 pack) - $13.90 https://www.amazon.com/gp/product/B074TB8XTL/ $4.64 for 1 cord (Not taking into account things like double sided sticky tape, solder, wires, or shrink wrap tubing segments used because they cost less than a few pennies) Total: $13.65 (USD) _________________________________ I spent a fair bit more money than I initially expected to (almost $55!), but much of that went towards components or materials that I'll be able to use for several projects in the future. At about $14 bucks, it is twice what I thought it would be per unit, so that will help me to better gauge other ideas. It seemed like it would be cheap as dirt, using many parts I already owned, but it all adds up - they don't sell less than a sheet of micro-suction tape, and buying control boards in bulk is the only wise way to do it (if you can call 3 units "bulk", that is). In conclusion, it was great to have an idea, play around with some proof of concepts, and then make it into a reality within a few days. Single game controllers today.... one day, a full cockpit of switches! Not sure what my next project will be, but among other ideas, I've considered making a custom control board for Kerbal Space Program, or maybe some kind of wireless gear that can connect to a computer and translate into RF to control some DIY RC cars or whatever with my Xbox controller already attached to my PC. Eventually, I want to get into wireless stuff, and even RC, but I might start with button boards that use USB cables just like this one. If anyone has any questions on this project, feel free to ask. Thanks for reading!
- 42 comments
-
- 5
-
- dcs
- game controller
-
(and 8 more)
Tagged with:
-
Parts List & Links Preparing the Sensor Preparing the Case Preparing the Arduino Final Assembly Uploading the Code Get Help & Support I have written a new voice control profile called 'AVCS SENS' for VoiceAttack specifically dealing with sensors and weather commands. I wanted to use the Shared Memory feature of the AIDA64 Extreme sensor monitoring program to enable my VoiceAttack profile to speak the requested computer sensor value when asked over text-to-speech. Once I had sensor values from AIDA64 Extreme in VoiceAttack, I then added a DHT11 Temperature & Humidity sensor to the Arduino Uno on my prototype breadboard, connected to my PC through USB. Now reading this as well from my VoiceAttack profile, I could do a little math to get a more absolute and objective value from the computer sensors, a CPU temperature in "degrees over ambient", for example, or "delta-T over ambient" as you may hear it called in analysis videos such as this one here talking about case testing methodology used by Gamers Nexus. This is the true means to understand what computer sensors for temperature are reporting at any given time, by first accounting for the temperature of the room. Finally, with this relative sensor data now available, I've been able to write a simple diagnostic algorithm which can identify & flag atypical sensor values, as compared to stored baseline values on file, for voice commands in VoiceAttack. Without an AVCS-DHT1, outdoor weather and sensor report commands are still available, yet indoor weather & sensor diagnostic commands will be unavailable. I wanted to make it possible for anyone using my new AVCS SENS profile for VoiceAttack to either be able build their own AVCS-DHT1 USB external temperature & humidity sensor, or buy one designed & built by me, according to this simple Arduino project build guide, and therefore unlock these additional voice command features for AVCS SENS. My DIY USB Temperature & Humidity Sensor 'AVCS-DHT1' - for use in my AVCS Voice Sensors & Weather Profile parts list below contains links to specific items which I directly purchased myself for this project on Amazon only, but any store will do, and also any equivalent part which performs the same will work (brand names/quantities do not matter!) if you are using a different case than the exact one linked below, or other components, please see the note in the AVCS SENS Wiki page regarding Sensor Calibration Project Required Parts List (all prices listed in USD - price and availability may be different past last publish date of this guide) Arduino Nano (or equivalent clone) - with NO header pins soldered on! (HiLetgo Nano v3.0 5V) (3 pack) - $24.49 https://www.amazon.com/dp/B01DLIJQA2 $8.16 per board USB Cable - USB 2.0 Type A to Mini-B (3ft. or 1 meter, at least) (or equivalent part) (iSeekerKit Nylon Braided 3ft.) (3 pack) - $8.99 https://www.amazon.com/dp/B08LL272SK $3.00 per cable DHT11 Temperature Humidity Sensor Module 3.3V-5V (or DHT22, or equivalent part) (HiLetgo w/Dupont Wires) (5 pack) - $10.29 https://www.amazon.com/dp/B01DKC2GQ0 $2.06 per sensor Plastic Electronics Project Case @ 1.97" x 1.10" x 0.59" (50mm x 28mm x 15mm) (Zulkit ABS Project Boxes) (5 pack) - $7.99 https://www.amazon.com/dp/B07PZ24LFD $1.60 per item Metal Film Fixed Resistor 10K ohm (0.5Watt) - just one will be needed (EDGELEC Pack of Resistors) (100 pack) - $5.99 https://www.amazon.com/dp/B07QJB31M7 $0.06 per resistor Strong Double-Sided Foam Adhesive Tape (or equivalent product) - only need a few inches (Gorilla Brand Heavy Duty Mounting Tape) (1" x 120" roll) - $11.34 https://www.amazon.com/dp/B082TQ3KB5 $0.20 approx. amount used Neodymium Magnet 8mm x 2mm (round, size is important!) - just one will be needed (FINDMAG Box of Magnets) (100 pack) - $9.99 https://www.amazon.com/dp/B09BB1VT4J $0.10 per magnet Total: $15.18 (USD) (for 1 sensor*) - (total if all parts purchased with amounts above: $79.08) *(also required - drill/rotary tool, solder and soldering iron, electrical tape, tweezers, scissors, 'nippers', 'spudger' type tool, and SuperGlue) This project requires the following skills & knowledge: Basic understanding of Arduino (what it is/what it does) Basic experience with electrical soldering Basic skills with drill or Dremel/rotary tool and bits Use of and precautions relating to SuperGlue type adhesive Ability to make precise cuts with scissors within 1-2mm Ability to carefully follow instructions (some are crucial) Entry level experience with VoiceAttack (import profile, etc.) Ability to work w/ tiny parts in a small space in timely manner A positive attitude and willingness to adapt and overcome (not exactly required, but always recommended ) Part 1 - Preparing the Sensor preparing the DHT sensor and stripping the braided wires - image a1 1. Separate the DHT11 (or DHT22) from the breakout board it is mounted on (if not supplied without one). Either snip the wires from the DHT as close to the board as possible with "nippers" (image a1), or de-solder them from the breakout board. If supplied with the Dupont ribbon wires, remove the plastic ends and prepare the wire ends by cutting them even and strip the wires leaving at least 1.5cm bare. We want around 75-100mm (2.95-3.93") of flexible braided wire so we can zig-zag the excess, allowing us to remove the plastic lid with sensor and not risk yanking the soldered wires out. solder wire ends - image a2 2. Twist the wire ends and tint them with solder to make them stiff, yet not so much as to increase their width with too much solder & slag - three of them must fit through the holes on the Arduino. 3. Once the DHT has been separated from the breakout board, with the side with holes facing you and pins down, cut the third pin from the left, or second from the right, as in image a1. gently bending the pins, resistor legs, and wires - image a4 4. Prepare the DHT pins by gently curving them into hooks facing away from the side of the sensor with holes. Gently bend the legs of the 10K ohm resistor (as shown in image a4) so that it will sit in the hooks of the two DHT pins closest together, as seen with the sensor face down (holes down, as in image a5). resistor placement - image a5 5. Bend two of the three wire ends away laterally away from the third wire, into a gentle hook shape, and the third wire opposite those in the same manner. Lay the 10K ohm resistor into the right two wire-hooks of the DHT sensor (face down - image a5). final goal for the resistor, legs, and wires: flat & straight - image a3 NOTE: The Resistor should be offset in a manner where its bulk and width can mostly lay flat along side the wires and not on top of them once completed (image a3). gently crimping the DHT pins around resistor legs & wires - image a6 6. Lay the wire "hooks" into their corresponding DHT wire "hooks" over the resistor, and if able, use a tweezers to gently compress these DHT wire hooks to contain the wires and resistor for soldering, as well as the wire "hooks" themselves. If this is not possible, you may want to secure the DHT to the table with scotch tape, lay the three wires in place in their "hooks", and scotch tape down the wires to the table with a gentle pull, to ensure they remain in place while soldering them firmly in place as one connection. soldering to the DHT - image a7 7. Solder each connection so that the wire, the wire "hook" from the DHT, and the resistor are fully encased, and not touching each other. trimming legs from resistor, and any protruding slag - image a8 8. When cooled, use "nippers" to nip any protruding slag or wire ends, and the trailing legs of the resistor as it exits the solder as in image a8. The wires should travel flat following the rear plane of the sensor, so that later, the front face of the sensor (with holes) can protrude out of a hole we will cut in the case lid. Refer to images a3 and a8 to see the resistor in-line with wires, as an example. wrap wires separately - image a9 9. Finally, wrap each exposed solder point with a separate small piece of electrical tape to ensure each cannot bridge contact with another in the event that something gets bent. Just sandwiching a small rectangle of tape over each one will do, even if each has a tail of tape hanging off. These bits of tape will be covered and held in place permanently once the sensor is mounted into the lid later. SAFETY SAVES LIVES - SAFETY GOGGLES SAVE EYES! BE SMART AND USE APPROPRIATE SAFETY GEAR WHILE WORKING! Part 2 - Preparing the Case drill 12 tiny air holes - image b1 1. Carefully remove the lid from the case - while holding the base in one hand, lid up, with the notch in the lid away from you, use a fingernail in the notch along with pressure from your finger to pry that side of the lid upwards. If using a tool, be careful not to use too much pressure or the soft ABS plastic may deform or scratch if the tool jumps too fast once the lid becomes free. keep notch at bottom - image b2 2. For the lid, we want to create a rectangular hole that will allow the front face of the DHT sensor to protrude. The tapered sides of the blue sensor case widen towards its back which will keep it from protruding farther. The lid is 25.9mm wide & 47.75mm tall. The approximate width of the hole will be at or under 16mm tall and 12.60mm wide. For this to work well, it is best to cut a slightly smaller hole than desired and slowly widen it with hand tools or low speed rotary tool - stopping and testing the fit until just right (as shown in image b6 below). It is not easy to get exact, I've tried. Just accept any slight tilt, it is a DIY after all. port is upside down - image b3 The goal for the USB hole is to make it flush with the bottom of the case as it exits, and as wide as the USB port itself (8mm). The port is 4mm tall, but as you can see in image b3, even I could not quite keep that height with that limit as I drilled and widened the hole. Again, stop and check the fit - first dusting out any bits of plastic from the process, and sliding the Arduino Nano upside down as shown for a test fit. It must slide flat with the case bottom and through the case wall as shown. 3. With the lid removed from the base, use a drill bit between 1mm-2mm at low speed to create 4 holes in the 'top', and 4 holes on each side near the top (as shown in image b1), for 12 total air holes. The passthrough hole for the USB mini-B port will require drilling and widening with hand tools or a rotary tool at a low speed. The port is about 4mm tall & 8mm wide. High speeds may heat and melt the ABS plastic, so if you are working at an area for too long, back off and let it cool down. place one small drop of SuperGlue at the arrow for magnet - image b4 4. Once all the holes are drilled and the rough edges cleaned up as much as possible, wipe the interior clean of plastic dust. Using a strong SuperGlue, place a very small drop inside the case at the top near the four holes you drilled, as shown by the arrow in image b4. Carefully place the tiny magnet over the drop of glue; non-magnetic tip tweezers or even chopsticks can really help - just be sure not to touch the SuperGlue as you position the magnet. test fit the sensor into lid - image b6 5. Finally, cut a strip of the double-sided adhesive foam tape about 25mm wide and 8mm tall - do not remove the backing yet! Once the SuperGlue has dried (give it a few minutes) place the strip of tape over the magnet (image b5, below). fully cover magnet with tape, do not remove backing (yet) - image b5 Part 3 - Preparing the Arduino setting the board to "Arduino Nano" and its COM Port - image c1 1. Open the Arduino IDE v1.8 (latest) (download and install first, if not already done) and make sure it is updated to current release version. Place the Arduino Nano on a hard, non-conductive surface, and connect the USB cable to the device and then to the PC. Refer to device instructions (per brand/model/type) as required, if the device driver is not installed automatically. Under the 'Tools' Menu along the top, select the COM Port of this device, and set the board to Arduino Nano (as shown in image c1), and unless directed by device instructions, leave the Processor as "ATmega328P". opening and uploading the Arduino Basics "Blink" sketch - image c2 2. Under the 'File' Menu along the top, select Examples > Basics > Blink to open this sketch (see image c2). Next, click the Upload button ( ) to send this sketch to the Arduino Nano. Verify that the onboard LED slowly blinks on and off repeatedly to ensure this board is functioning, and that sketches are uploading properly. If you have any problems at this stage, you will want to stop and perform other troubleshooting steps to verify that the Arduino IDE is set up properly to communicate with this board, and that the board itself is not faulty. See Addendum at the bottom of this guide for help. installing or updating the "Adafruit Unified Sensor" library - image c3 3. To get data from the DHT sensor, we will be using an open source DHT Sensor Library by Adafruit, which requires the Adafruit Unified Sensor Library, as well. In the Arduino IDE, under the 'Tools' Menu, select 'Manage Libraries...' (or press CTRL+i) to open this window - it takes a few seconds to open. First, select the Type of "All" (if not already selected), and the Topic of "Sensors". In the search field, type "Adafruit Unified Sensor". The list will be long, scroll down until you find the Adafruit Unified Sensor library (as pictured in image c3) - install it or update with the latest version, if not already. installing or updating the Adafruit "DHT sensor library" - image c4 4. Next, in that same search field, type "DHT sensor library". Again, the list will be long, scroll down until you find the item with the title "DHT sensor library" by Adafruit (as pictured in image c4) - again, install or update it if it is not installed with the latest version. When you are finished, close the Library Manager and disconnect the Arduino from the computer. If desired, use a light grit sandpaper on the edges of the Arduino Nano PCB board to make them smooth. AVCS-DHT1 Wiring Diagram (your resistor color may be different!) - image c5 5. Once you have verified that the Blink sketch is working from earlier steps, and that the Arduino IDE can properly upload to the Arduino Nano board, it's time to solder the wires from the DHT sensor to the Arduino. Follow the wiring diagram (shown in image c5), separating the ribbon cable to individual wires for flexibility, as needed. later, mounting will be upside down, as shown here - image c6 NOTE: As stated before, the Arduino Nano MUST be upside down (shown in image c6) in the end. You may wish to do as I have done, and push the wires through from the other (top) side of the board, soldering them into place on the underside (now facing up, like image c6). Unlike the diagram, the brown wire from these pictures is the black/ground wire, the red wire is the yellow/signal wire, and the orange wire is the red VCC/5V from image c5! Your wires may differ in color as well, if using those supplied with your DHT module as I have done. Do not get them mixed up - follow any wire back to the DHT to identify it properly. When complete, trim any protruding slag, or excess length from the wires as they exit the board, once cooled. Part 4 - Final Assembly gently press down on areas such as those noted with arrows - image d1 1. Cut a piece of the double-sided adhesive foam tape 23mm wide and 45mm tall, with a small notch cut out to allow wires to pass as shown in image d1. Do not remove the backing to expose the second adhesive side, this backing will remain on permanently as an additional barrier between the sensor, the Arduino, and the wires in the case. 2. Place the completed sensor and wires assembly into its slot you cut out in the lid, from the inside. Cover the entire unit with the tape you cut out, allowing the wires to fit through the notch. Use a dull plastic "spudger" type tool (image d1) to gently but thoroughly press down at all contact points, bends, and flat areas where the tape should make full contact with the lid and sensor. Avoid the area of the wires and resistor, and the soldering points - use only a finger or thumb and gentle pressure in the area over wires to ensure a light contact. We don't want to break any of the solder or unintentionally bridge the contacts. Do the same for the tape covering the magnet in the case - press into the bends and flat areas to ensure permanent contact. Do not compress the part on the top of the magnet too much - we need this pile to be between 3-5mm to make contact with the Arduino Nano when it is finally in place. first remove backing from tape, then apply the SuperGlue - image d2 3. Before proceeding, with the protective backing still on the tape covering the magnet (still "un-sticky"), test fit the Arduino Nano into the case one last time - make sure the USB port sits flush with the base of the case as it exits, and the PCB board is flush with the edge of the case with the USB port hole (such as in image d3). Ensure that the back of the Arduino overlapping the magnet touches the tape and the peel covering it - this is the last chance to make it taller with another bit of tape, if you used a different or thinner type of tape not recommended by this guide. It should be a foam type tape with some give, and adding to the height of the magnet enough to make contact with the Arduino (about as tall as the USB port on the other side, 4mm). When ready, first remove the backing peel entirely from the double-sided adhesive covering the magnet - a sharp pair of tweezers can help here, it is NOT EASY and your luck may vary (condolences, I use this stuff all the time because it is so great, but for this one flaw - actually getting the backing off once it's in place can be painful!). Once you're done fighting the Gorilla tape and got the backing peel off, place a small dot of SuperGlue inside the case near the USB port passthrough hole. In the example image d2 there is almost too much, half this much would do - you can use a cotton swab to soak up some of the glue before it dries, but this entire procedure must be done swiftly. Before the SuperGlue dries, very carefully slot the Arduino Nano into the case at an angle, with the USB port first, keeping the back from touching the tape yet - slide the Arduino USB port through the hole and then lower the back end down into position above the tape, keeping the PCB flush with the case wall, and the USB port through the hole as it makes contact with and compresses the SuperGlue. Quickly dab up any SuperGlue that may leak out of the hole and outside the case. apply light pressure on right and strong pressure on left - image d3 4. Referring to image d3, with light & gentle finger pressure, press down on the area noted by the arrow on the right, while also using a more firm finger pressure to press down on the area noted by the arrow on the left (over the tape/magnet). Be sure not to put a lot of pressure on the right where those components are, it is not necessary - the SuperGlue will do its job, we just need to give it light pressure to help spread the SuperGlue and ensure flush contact as we put greater pressure on the left where there are no components and we want full contact with that tape. fully assembled - image d4 5. Before closing the lid, allow up to several minutes for the SuperGlue to dry. Take this time to plan the bends or separations in the ribbon wire (if using one) so that each wire can sit in a sort-of zig-zag fashion once we do close the lid. In image d3, the wires are actually a bit long and will require an extra 'zag' to fit, so I have separated the wires nearly to the first bend. The first bend by the lid and notch in the tape must be acute & firm without crimping! Once the SuperGlue is dry, carefully guide the wires into places they won't impede as you close the lid - start from the far end away from the wires, and lower it into place over the USB port side lastly. Be careful not to force it closed, adjust as needed to ensure a tight fit without jamming the wires into hard crimps or bends which could sever tiny wires in the braid inside the wire jacket. The Official AVCS-DHT1 sticker label - image d5 6. The AVCS-DHT1 Sensor (being magnetic) is designed to stick to a PC case in a vertical orientation somewhere not far from the intake, but far enough from intake fans to not be 'cooled by the wind'. The back of the ABS plastic case on the sensor can potentially mar or scuff softer paint on a PC case, so it is advised to place a piece of black electrical tape or even Scotch Tape along this surface simply to ensure a softer contact with the PC. All AVCS-DHT1 sensors built by me and sold in the VG Store will have this sticker label (shown in image d5), which also serves this purpose as a softer backing to help avoid minor scuffing over time. If using one of these labels, carefully cut around the grey box on the label leaving about a 1-2mm margin as shown. You may consider peeling back and folding a crease in the wax paper backing, then folding back into place over the adhesive surface, before cutting the label to size - this will help more easily remove the backing once you've trimmed off the edges of the label. Unlike the high cost of shipping pre-built sensors around the world, I can offer these cool little AVCS-DHT1 sticker labels to anyone following this DIY Build Guide for a fairly low price in the VG Store including free domestic and international shipping to around 180 countries. It's much cheaper to mail a small envelope than a box, of course. Click Here to open the VG Store in a new browser tab to check out these sticker labels. Part 5 - Uploading the Code AVCS_DHT1_DIY_Sensor_v3 7. At long last, we can upload the Arduino sketch to the device and get some sensor data onto the computer! Start by connecting the AVCS-DHT1 sensor to the computer with the USB cable, and mount it as noted, on the front or side of the computer near the intake but not within range of wind created by intake fans. The area of the panel where the sensor sits should not be near any internal components which get hot under heavy PC use. 8. Open the Arduino IDE program again. Under the 'File' Menu, select 'New' (or press CTRL+N) to create a new sketch called "AVCS_DHT1_DIY_Sensor_v3". Select the entire contents of this new sketch and delete them so you have a blank text area to paste into. Next, Expand Contents of the code block above - copy the entire contents of the code block here from line number 1 through line number 86. You can copy the code block to your clipboard more easily by clicking the "Download Raw" button provided by Pastebin, and select all the text on that page & copy it. Finally, paste the entire code into your sketch in the Arduino IDE (overwriting any contents) and save the sketch (CTRL+S). Now we can upload the sketch from the Arduino IDE program to the Arduino Nano by pressing the ( ) upload button just as we did with the Blink sketch above. When uploading is done, close the Arduino IDE program and proceed with testing at step 9 below. If you see any problems in the errors and information window below the sketch when trying to upload and if the title bar over this information window at the bottom of the sketch does not show the words ( ) when done, stop and get Help or Support from the links in the Addendum at the bottom of this guide. AVCS SENS profile version shown above may differ from latest - image e1 9. Launch the VoiceAttack program and switch to the AVCS Sensors & Weather Profile (if not already running and loaded). When voice commands are available, say, "Open the Sensor Menu". The AVCS SENS Main Menu will pop up. Press the "OPTIONS" button, and then press the "Sensor Options" button. In the Sensor Options screen, press the "Test Arduino DHT11 Sensor" button - there will be a voice reply of either "Test Succeeded" or, of course, "Failed". Upon a successful test, the VoiceAttack Event Log (shown in image e1) will display several text messages, including a sample of the data received such as: AVCS-DHT1 Data: [AVCS,22.75,65.00,72.95,73.00,DHT1] DHT Monitoring in AVCS SENS is a secondary monitor tied to the Sensor and/or Weather Monitor. If either of these are started, DHT Monitoring will try to start. If no DHT sensor is detected, indoor weather & sensor diagnostic commands will not work. If both Sensor & Weather Monitoring are turned off while DHT Monitor is on, the DHT Monitor will also turn off. Congratulations on successfully building an AVCS-DHT1 Sensor! Enjoy the indoor weather & PC sensor diagnostic voice commands! *alternatively, if you were not so successful, please see links below in the addendum for help & support on a variety of topics. I am also happy to provide assistance here if you would like to reply below, or through private message here or on Discord - whatever is preferrable Addendum - Help & Support for this DIY Arduino Project If you need help, post up a reply below and I'll answer as soon as I see it. Otherwise, here are some helpful links pertaining to this project: AVCS Help and Support Links AVCS SENS Profile Download AVCS SENS Wiki Page AVCS Help Channel on Discord AVCS Bug Reports Contact SemlerPDX Arduino Links Arduino IDE Download Arduino Guide Arduino Help Center Arduino Forums Arduino Discord VoiceAttack Links VoiceAttack Tips & How To VoiceAttack Manual VoiceAttack Product Page VoiceAttack Forums VoiceAttack Discord "AVCS SENS", including the Profile Package for VoiceAttack, the AVCS SENS Wiki page, the AVCS-DHT1 Sensor and Sticker Label, and this DIY build guide, comprise creative works by SemlerPDX shared under CC BY-NC-ND 4.0 March/June 2022 AIDA64 is not affiliated with AVCS or this DIY project. Images and text depicting the AID64 program(s), title, logo, or other elements belonging to AIDA64 or FinalWire Ltd. are used only for educational and/or instructional purposes, relating to demonstration & use, in this DIY project guide. AIDA64 is a Registered Trademark of FinalWire Ltd. ©2010-2023 All rights reserved.
-
Version 0.95.0
265 downloads
Profile for VoiceAttack by =VG= SemlerPDX Primary Question-and-Answer Features: Temperature - Humidity - Forecasts - Weather Alerts (coming soon!) -- "How hot is it outside?" (or) "What's the weather gonna be like on Friday?" Sensor Averages - Sensor Reports - Sensor Diagnostics -- "What is the CPU temperature?" (or) "Run a Level 3 Diagnostic" Time of Day - Day of Week - Month - Year - Date -- "Is today the 14th?" (or) "Is it Saturday tomorrow?" Included 'Utility' Command Features: "Clear the Log" === Clear the VoiceAttack Event Log text messages with this voice command "Be quiet" === Halt all currently active text-to-speech or any (long) sensor report/diagnostics readout "Stop all Sensor Commands" === Halt any active VoiceAttack commands currently executing "Check a variable value" === Input the name of any VoiceAttack variable to see its value in the Event Log "Count clipboard commands" === Count all derived commands in dynamic phrases such as "[Example;Examples] [Voice;Voices] [Command;Commands]" --To open the Quick Command Reference Guide, say, "Open the Sensor Command Reference" --To open the user options Profile Menu, say, "Open the Sensor Menu" NOTE: When Weather Monitoring (or Sensor Monitoring) is OFF, these commands will be unavailable. Please review each options page inside the Sensor Menu, including the User Guides pages. Learn more about VoiceAttack here: https://voiceattack.com/ DESCRIPTION: Voice Sensors & Weather is a question and answer profile that replies to our questions about PC sensors, the local weather outside, local weather forecasts, and even indoor weather when using an external temperature sensor connected over USB. This is my second AVCS utility voice command profile alongside the Voice Calculator & Conversions profile for VoiceAttack, and I'm very happy with how this project has turned out after nearly 4 months of work! Local outdoor weather voice commands are made available through connection to the Open Weather API, and this public AVCS SENS project has its own access key for all users of this profile. When Weather Monitoring is on, new weather information is checked periodically based on user settings, and set to text variables which VoiceAttack can return on command through text-to-speech replies. New 7-day weather forecast data is gathered once a day, with options to adjust this all the way down to hourly when users enter their own Open Weather API access key. Computer sensor voice commands are made available when running the AIDA64 Extreme sensor monitoring program, through the Shared Memory option for External Applications under the program preferences. This program is required in order to use any internal PC sensor commands, reports, or diagnostics. AVCS SENS reads individual sensor data directly from active memory every few seconds, without ever logging anything to file. These values are averaged out and read back through text-to-speech replies on command for individual sensors, or as part of a group of all sensors in a report or diagnostic command such as, all sensors, or all CPU sensors, or all Graphics card sensors. Indoor weather voice commands are only available when an external temperature & humidity sensor is connected by USB to the computer. This "AVCS-DHT1" Sensor is an Arduino powered device designed with a DHT11 sensor in a small enclosure that sticks to the side of a PC case magnetically. A DIY Build Guide is available for anyone wanting to make one of these devices for themselves, or users can also buy one designed & built according to that same guide on the VG Store. Another feature unlocked by the AVCS-DHT1 is computer sensor diagnostics. Diagnostics voice commands are unlocked when using both AIDA64 Extreme and an AVCS-DHT1 sensor. With these, all PC temperature sensor values in text-to-speech replies will be said in "degrees over ambient", or a "delta-T over ambient" as you may hear it called in analysis and testing videos. This is the true means to understand what computer sensors for temperature are reporting at any given time, by first accounting for the temperature of the room. Using a simple algorithm, this allows AVCS SENS to identify & flag atypical sensor values as compared to sensor baselines previously established and saved to file. I do plan to continue development of this profile, and appreciate any feedback, suggestions, ideas, or bug reports. I have some goals to add to the currently undocumented Sensor TTS Alerts feature and to explain usage examples in the AVCS SENS Wiki page, and of course, find a more graceful way to handle voltage, amperage, and wattage voice commands (currently not fully functional in the v0.95 Public Beta Test). FINAL NOTE: This profile is in an open Public Beta Test phase, after several weeks of testing, and is expected to work as designed. If any issues arise, I am happy to address them, and will release profile updates as often as able to address anything that pops up now that it's out in the wild. I don't anticipate any problems, but I can only truly evaluate that with help from outside eyes. I'm also open to feedback regarding the AVCS SENS Wiki Page, the DIY Build Guide page, and even the demonstration video for this project. Thank you for helping me to test this profile and put it through its paces - I'm sure this will be a fun and useful addition to my AVCS utility profiles along with AVCS CALC! Cheers! =============== OPTIONAL WAYS TO USE THIS PROFILE =============== OPTION 1: Switch to the AVCS Voice Sensors & Weather Profile and say, "Open the Sensor Menu" to use OPTION 2: Open Profile Options for any of your Profiles, select Include Commands from other profile: "AVCS Voice Sensors & Weather (latest version)" -or- OPTION 2b: Open VoiceAttack Options and select Global profiles, then Include Profile Commands from the profile: "AVCS Voice Sensors & Weather (latest version)" ========================================================= The main sensors and weather monitoring "function" commands are almost entirely made up of Inline Function in C# and VB.net - feel free to review these scripts here: AVCS SENS - Voice Sensors & Weather - Inline Functions in C#/VB.net for VoiceAttack on Pastebin file contents and checksum:- 1 comment
-
- voice control
- voiceattack
-
(and 5 more)
Tagged with:
-
Who's Online