We're excited and proud to launch Thingiverse Apps. Learn More about what this means to you.
Updated to v1.33 11/8/12 4:13PM EDT. Vane support by JoeyC.
Updated to v1.32 6/9/12 4:13PM EDT. (+v-grooves +flats)
Updated to v1.23 4/23/12 1:52AM EDT. (240 downloads)
Updated to v1.22 4/21/12 6:38PM EDT. (72 downloads)
Updated to v1.21 4/18/12 1:16AM EDT. (187 downloads)
Updated to v1.2 4/17/12 11:56PM EDT.
Updated to v1.1 4/16/12 7:16PM EDT.
This is very highly customizable wheel in the way of an OpenSCAD file with 46 parameters that provides a limitless set of combinations and wheel designs. I affectionately refer to it as "One Wheel To Rule Them All."
It can be wide, narrow, big, little, fat hub, skinny hub, no hub, through-hole, servo arm mounted, chamfered, multi-tire, modeled tread, optical encoder-slotted, and more. It even accommodates stretched o-ring tires. It just can't be square, because my sources tell me that won't roll well. The code is extensively documented, and traces out helpful information about the geometry of the wheel/tire, as well as encoder slot metrics (e.g. each rising edge is 42.42mm/1.67in in travel).
It includes twelve standard tread patterns (all configurable in often surprising ways), eight core spoke patterns (also highly customizable), configurable support for o-rings, bands, and optical encoder timing slots (directional and non-directional), and a lot more. Plus, Iâ€™m still adding features as I think of them.
The images show most of the core building blocks, plus just a few random variations. Some of the settings produce unique and creative designs that don't even really match the descriptions. As an example, see the few spiral designs pictured separately.
To put it a different way, the tread and spoke designs are not limited to what you see. For example, you can easily stretch the length, width and height of each knob, and their relative positions to create new variations.
This design combines all my previous wheel designs and adds a lot of new features. For an easier-to-read version of the instructions, see my blog at http://www.thefrankes.com/wp/?p=2674.
For an easier-to-read and up-to-date version of the instructions, see my blog at http://www.thefrankes.com/wp/?p=2674.
Here it is on github: https://github.com/alexfranke/Highly-Configurable-Wheel
GET THE HIGHEST VERSION NUMBER! You can now find the older versions (for reference) in the git repository -- I'll be removing them from here so people don't get confused and download the wrong one.
In the 1.33 update: JoeyC added some nice features here to support vanes. Thanks!
In the 1.32 update: Added features suggested by JuliaDee: option for v-grooves instead of just, and flatted shaft option (with shaftFlatDiameter parameter). Check comments under Tread Parameters for how to use v-groove. Fixed a bug that cause outer nut trap to not render properly. Fixed a bug that didn't include shaft flats when rendered without a hub.
In the 1.23 update: Fixed a bug that places the trapped nuts incorrectly, without considering shaft size. Added a parameter to offset the placement of these nuts. (Thanks, AUGuru, for both of these!) (240 downloads)
In the 1.22 update: Added credits section to instructions. Fixed some argument/reference issues. Better knob foundation calculation/rendering. Fixed a number of bugs in knob sizing, including the bug indetified by TakeItAndRun, where the knobs sometimes extend into the interior of the wheel. (72 downloads)
In the 1.21 update: Fixed bug that prevented timing holes from rendering properly with spoke inset. Edited comments a bit and cleaned up some code. Combined a few parameters. (187 downloads)
In the 1.2 update: Line style uses spokeWidth. Supports an inner circle using innerCircleDiameter. Cleaned up some unnecessary code. Added spokeInset to allow seperate sized of rim and rest of wheel. Added captive nut option in hub. Added convexity of spoke area (inner and outer).
In the 1.1 update: Hub now supports standard hobby servo mounting arms/horns. Renders flat.
It's important to note that you can configure this wheel to such an extend that it may not be printable at home with extruded plastic printers. In these cases, services such as Shapeways could come in handy.
***Remember to see the website for the most up to date instructions.
Often wheels are built around the tires. In this section, specify the properties of the tires you're using, and this will define the diameter of the wheel. If you're using o-rings, the tireCSDiameter should be the cross-section diameter of the o-ring, or if you're using some other flat tire material (such as rubber bands), jsut specify the its thickness. If you're not using any tire at all, set the tireCSDiameter to zero.
The rim sits at at the outside of the spokes and supports the tires or added treads. Installed tires (such as o-rings, rubber bands, etc) are set into grooves carved out of therim, while trads are added onto it. Keep this in mind when you're using tires -- as an example, the rim height should not be smaller than the radius of o-ring tires.
The rim also supports rotary encoder timing holes for wheel feedback. Use the padding parameters to adjust the location of those holes. See the compiler output for helpful information about the distance indicated by each timing hole. Directional timing holes will produce a second set of holes that are 90 degrees out of phase with the first. This allows you to stack sensors at the same location over the wheel instead of trying to position them along the circumference. Directional timing holes essentially double the resolution. You can also double resolution by looking for both rising and falling edges.
In this section, specify the properties of the tire tread you want to render. If you're using a wheel (e.g. o-ring, rubber bands, etc), then use either the "o-rings" or "slots" settings, which will cut a groove (or grooves) in the wheel rim to fit the tires. The othertreat styles will render a tread pattern protruding out from the tire surface by the amount you specify in third part of "knobSize".
Imagine the tire is mounted on a robot and facing straight at you. The "knobSize" parameter defines the size and shape of knobs in an [x,y,z] format, where x goes across the rim, y goes up and down along the perimeter of the wheel, and z protrudes out from the wheel toward you.
The "staggerOffset" parameter allows you to stagger knobs across the tire by an amount you specify. Set this to zero if you want all the knobs lined up along the perimeter and aligned with the edges of the rim.
"numberOfKnobs" specifies how many knobs there are across the tire, and "lineThickness" specifies how thick the lines are from "drawn" tire styles, such as "x", "cross", and "zigX". You can use these pameters together in creative ways -- for example to extend a single tread profile across the width of the tire, or to create a contiguous zig-zag.
Finally, "radialTreadSets" defines how many sets of treads are rendered around the wheel. Each set contains two rows in order to create the staggered effect.
Tread styles are:
This section is used to define the spoke style of the wheel. Some of the properties are only applicable to certain wheel types, and these properties can be used together in creative ways to create a wide range of tire designs.
The "proportion" property affects how some spokes are rendered. The first number is the proportion of the design from the center of the wheel to the inside of the rim, and the second number is the proportion of the width inside of the wheel. For example, to create spokes that are roughly in the shape of a "U", you can use a "circle" style, and set the proportion to [1.5, 1.0], for cirle spokes that are 150% as long as the distance from the center to the inside of the rim, 100% as wide.
The spoke styles are:
These properties define the hub -- or how the wheel connects to the motor. The default values for the captive nut are precise for a M3 nut and will make the nut a very tight (if not impossible) fit. I prefer this because it allows you to "melt" the nut into place with a soldering iron. However, if you don't have a solder iron or prefer a looser fit, then just adjust the nut diameter and thickness. (M3 hardware is, by default, set to 3mm screw diameter, 5.4mm nut diameter, and 2.3mm nut thickness.) Similarly, the holes for the motor shaft and grub screw are also precise. This allows the holes to be drilled out for a more precise fit. Again, you can adjust these to suit your needs.
The hubZOffset can be used to "sink" the hub into the wheel, and it defaults to half the wheel thickness. For example, when the hubHeight is 10 and the hubZOffset is -2, then the hub will protrude 8mm from the wheel, but the shaft hole will be 10mm deep. The set screw will still be positioned in the middle of the exposed vertical height, and the fillet/chamfer will also be rendered in the correct position. This property is also useful if you want to poke a hole entirely through the wheel. (e.g. If the wheel is 6mm thick, set the hub height to 16 and the hubZOffset to -6, and you'll get a hub that protrudes 10mm from the wheel surface with a hole that extends all the way through the wheel.)
To mount a servo motor, set includeHub to false, set shaftDiameter so that the hole will accommodate the servo horn screw and any bit that protrudes from the top of the servo horn. Then set the servoHoleDiameter to the size of your mounting hardware, and set servoHoleDistance1 and servoHoleDistance2 to the total distance between mounting holes on your servo (not the distance from the center). These sets of mounting holes will be rendered at 90 degree angles from one another. If you only want one set of holes, set one of the values to zero. Adjust the angle of all the holes to avoid openings in your wheel design if necessary using servoArmRotation.
Highly Configurable Wheel (One Wheel To Rule Them All) by CodeCreations is licensed under the Attribution - Non-Commercial - Share Alike license.
So what's this mean?
We're sure CodeCreations would love to see what you've printed - take a photo and share it on Thingiverse as a Make.
To post a Make simply visit this Thing again and click I Made One to start uploading your photo. You can also download the Thingiverse Mobile app (available via Google Play and Apple App Store) to take a photo and upload your Make right from the app!