ai:examples:movingscreens:movingscreens
Differences
This shows you the differences between two versions of the page.
Next revision | Previous revision | ||
ai:examples:movingscreens:movingscreens [2018/11/11 13:30] – created icke_siegen | ai:examples:movingscreens:movingscreens [2018/12/05 13:57] (current) – icke_siegen | ||
---|---|---|---|
Line 8: | Line 8: | ||
^ published: | here | | ^ published: | here | | ||
^ tested in version: | Ai v8 | | ^ tested in version: | Ai v8 | | ||
- | ^ download: | | | + | ^ download: | {{ : |
//Hint: click the images to show them larger.// | //Hint: click the images to show them larger.// | ||
Line 20: | Line 20: | ||
The background of the setup is formed from a number of segments, each a flat surface of approx. 1 x 2 meters. Five such segments are hung from the rig, each with 3 Artnet-controlled winches. Per segment there is one winch for the top/left corner, one for the top/right corner, and one for the bottom-center point, this winch being suspended more upstage. With the winches in such a setup it is possible to hoist the segment, and to rotate and/or tilt it (within limits). The winches used in this setup feed their current position back via Artnet - and these data are used by Ai to calculate the current position and rotation of each segment. Likewise, more such segments were standing on the ground, on Artnet-controlled rotators, which also fed their current position back. This way it was possible to map contents onto the whole surface. | The background of the setup is formed from a number of segments, each a flat surface of approx. 1 x 2 meters. Five such segments are hung from the rig, each with 3 Artnet-controlled winches. Per segment there is one winch for the top/left corner, one for the top/right corner, and one for the bottom-center point, this winch being suspended more upstage. With the winches in such a setup it is possible to hoist the segment, and to rotate and/or tilt it (within limits). The winches used in this setup feed their current position back via Artnet - and these data are used by Ai to calculate the current position and rotation of each segment. Likewise, more such segments were standing on the ground, on Artnet-controlled rotators, which also fed their current position back. This way it was possible to map contents onto the whole surface. | ||
- | {{: | + | {{: |
+ | |||
+ | Here, Ai was not only used as visualiser, but was the main mapping machine. The show was controlled from a GrandMA2 command wing, and most of the parts were timecoded to be in sync with the music. | ||
+ | |||
+ | Some of the special aspects of this project: | ||
+ | * it was necessary to mimic the real behaviour of the segments, in order to reproduce it from the position data | ||
+ | * something what was completely new to me: we ran into a gimbal lock, and Mr. Dave Green was kind enough to explain this and provide a solution - see [[# | ||
+ | * the handles of the projectors and of most of the screen fixtures were hidden from the stage construction page, in order to gain overview | ||
+ | * it is not possible to do a proper softedge on surfaces which can dynamically tilt. Hence it was decided to go for a hardedge, and only some segments were displayed per projector | ||
+ | * as the entire background was always mapped as one big canvas, only one screen was exposed to the Ai GUI. The part each segment was to show was set in the UV map - hence, each segment needed to have its designated model. | ||
+ | |||
+ | ===== Used Modules and Patches ===== | ||
+ | |||
+ | * [[ai: | ||
+ | * [[ai: | ||
+ | * [[ai: | ||
+ | * [[ai: | ||
+ | * [[ai: | ||
+ | * [[ai: | ||
+ | * [[ai: | ||
+ | * [[ai: | ||
+ | * [[ai: | ||
+ | * [[ai: | ||
+ | * [[ai: | ||
+ | |||
+ | ===== Stage Patch ===== | ||
+ | |||
+ | Again, the whole stage patch can be devided in some sections: | ||
+ | * in the middle there are the main inputs and outputs | ||
+ | * the upper part holds the upper (hung) segments - the screens, inputs, and calculations | ||
+ | * the lower part holds the segments which were standing on the ground | ||
+ | * at the bottom there are the projector definitions | ||
+ | |||
+ | ==== Middle: the main inputs and outputs ==== | ||
+ | |||
+ | {{ : | ||
+ | |||
+ | * there are a few [[ai: | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * the little cluster of a [[ai: | ||
+ | * the '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * the '' | ||
+ | |||
+ | ==== Upper part: the hung segments ==== | ||
+ | |||
+ | {{ : | ||
+ | |||
+ | For each of the 5 hung segments there are some patches and modules in order to calculate positions and rotation data, and to display the screen segment: | ||
+ | |||
+ | * top-left, there are some [[ai: | ||
+ | * '' | ||
+ | * '' | ||
+ | * two [[ai: | ||
+ | * [[ai: | ||
+ | * '' | ||
+ | * finally, bottom-left is the screen fixture for this very segment: | ||
+ | * only the first one is left with its original name '' | ||
+ | * make sure to load the correct model into each screen fixture (drag and drop the 3ds file onto the fixture) | ||
+ | * '' | ||
+ | * '' | ||
+ | * the green '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | |||
+ | === Winde 1-3: getting the absolute height data === | ||
+ | |||
+ | As described above the subpatch '' | ||
+ | |||
+ | {{: | ||
+ | |||
+ | This should be easy to understand - simply read it left-to-right: | ||
+ | |||
+ | * the (exposed to the parent patch) [[ai: | ||
+ | * the [[ai: | ||
+ | * the '' | ||
+ | * of course, for debugging, some [[ai: | ||
+ | * the [[ai: | ||
+ | * the result is then returned via the patch io | ||
+ | * the [[ai: | ||
+ | |||
+ | === Calculate === | ||
+ | |||
+ | '' | ||
+ | |||
+ | **Note that this is not exact - honestly I had wished to have someone with a degree in physics to help me with this. However it was close enough to reality to be used on a tour for more than a year.** | ||
+ | |||
+ | {{: | ||
+ | |||
+ | Let's try to explain the logic: | ||
+ | |||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | * '' | ||
+ | |||
+ | === EulerToQuaternion === | ||
+ | |||
+ | When creating this project I ran into a strange problem: x, y, and z rotation are no independent from each other. I described it like this: | ||
+ | |||
+ | > in AI, the x and y rotation of a screen fixture refer to the world’s x and y axis. However, z rotation refers to the screen’s z axis. This leads to the situation – with x_rot = -90 – that y_rot and z_rot do exactly the same, but the screen cannot be tilted sideways (what z_rotation does). | ||
+ | |||
+ | Dave Green was kind enough to give a thorough explanation of this: | ||
+ | |||
+ | > You have discovered one of the draw backs of the Euler angle system we use in to rotate screens in Ai. Gimbal Lock. There is a short video explaining the problem here: https:// | ||
+ | > | ||
+ | >So you are probably thinking what can I do to resolve this problem? | ||
+ | > | ||
+ | >Another option is to use the alternate skin for the Fixture in the stage patch and then connect to the x,y,z,w Quat ports. | ||
+ | |||
+ | And while I was still struggling to find my way through all this Ciaran was so kind to create a patch which is now included as system patch: | ||
+ | |||
+ | >As Dave has said you encounter this problem based on the way Euler angles are defined in Euclidean Space. To get around this we can either use a 4x4 rotation matrix or quaternions. Without getting into the maths too much I have created a patch that should convert your Euler Angles into Quaternions, | ||
+ | |||
+ | |||
+ | {{: | ||
+ | |||
+ | (This concludes the top part - the calculations for the hung models) | ||
+ | |||
+ | ==== Lower part: Mediaspinners, | ||
+ | |||
+ | {{: | ||
+ | |||
+ | This part is pretty much straight-forward: | ||
+ | |||
+ | This is done in a little subpatch: MediaSpinner ArtNet | ||
+ | |||
+ | === MediaSpinner ArtNet === | ||
+ | |||
+ | {{: | ||
+ | |||
+ | This subpatch simply allows to set the DMX addresses per mediaspinner - each one takes two DMX channels as 16bit. From the given start address per spinner, the next channel is computed. Then the '' | ||
+ | |||
+ | ==== Bottom: the projector outputs ==== | ||
+ | |||
+ | {{: | ||
+ | |||
+ | Finally, at the very bottom of the stagepatch, the projectors are defined. Note that again we didn't use softedge, but assigned each screen to a specific projector - see [[ai: |
ai/examples/movingscreens/movingscreens.1541943011.txt.gz · Last modified: 2018/11/11 13:30 (external edit)