• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            天行健 君子當(dāng)自強(qiáng)而不息

            Using the .X File Format(3)

            Embedding Data Objects and Template Restrictions

            Data referencing has one caveat−the template restrictions set in place must allow you to use a reference. That might not make sense at first, but you can't use a data reference without the proper restrictions. An .X file represents an entire hierarchy of data objects, which can only be siblings or children of other objects. Thus, data objects embedded in other objects need the proper restrictions to be referenced or instanced. For example, consider the following three template declarations:

            template ClosedTemplate {
              <4C9D055B−C64D−4bfe−A7D9−981F507E45FF>
              DWORD ClosedData;
            }

            template OpenTemplate {
              <4C9D055B−C64D−4bff−A7D9−981F507E45FF>
              DWORD OpenData;
              [...]
            }

            template RestrictedTemplate {
              <4C9D055B−C64D−4c00−A7D9−981F507E45FF>
              DWORD RestrictedData;
              [ClosedTemplate]
              [OpenTemplate]
            }

            They are pretty standard template declarations, except for the lines that contain square brackets. The information inside those square brackets is important. The first template, ClosedTemplate, doesn't have square brackets, so it is considered a closed template. You can only instance and define the ClosedData value inside ClosedTemplate.

            The OpenTemplate, however, contains the [] line, which signifies that it is an open template. An open template allows any data object to be embedded in place of the [] line. For example, you can instance OpenTemplate, define the OpenData variable, and then embed an instance of ClosedTemplate within the OpenTemplate.

            RestrictedTemplate has two lines of bracket text. Restricting templates only allow data objects of those template types listed; in this case, those templates are ClosedTemplate and OpenTemplate. Attempts to embed any other data object other than the two listed will fail (causing the parse to fail).

            Whew−you might have to reread this section a few times to fully understand the ability to embed and restrict templates within other templates. Once you have a firm grasp on embedding and restricting, it's time to move on and learn about DirectX's pre−defined standard templates, which are packaged with the DirectX SDK.

             

            Working with the DirectX Standard Templates

            Now that you've worked your way through templates and data objects, you can move up a step and see what you can do with them in your project. If you've taken the time to play around with the DirectX SDK, you'll notice that .X is widely used for containing mesh information. To that end, Microsoft has packaged DirectX with a number of templates, which I call the DirectX standard templates. These templates are used to contain all mesh−related data.

            The standard templates are useful because they define almost every aspect of 3D meshes, so take a moment to study them here.

            The standard templates, shown in Table 3.2, each have a matching GUID macro that you use to determine which data object is which in your program. These macros are defined (using DEFINE_GUID) inside a special file named rmxfguid.h. The standard templates' GUID macros are easy to remember because you just prefix the template's name with D3DRM_TID. For instance, the Animation template is defined by the macro D3DRM_TIDAnimation.

             

            Animation

            Contains animations referencing a previous frame. It should contain one reference to a frame and at least one set of AnimationKey templates. It also can contain an AnimationOptions data object.

            template Animation
            {
            < 3D82AB4F-62DA-11cf-AB39-0020AF71E433 >
            [...]
            }

            Where:

            • [ ... ] - Any .x file template can be used here. This makes the architecture extensible.

            AnimationKey

            Defines a set of animation keys. A matrix key is useful for sets of animation data that need to be represented as transformation matrices.

            template AnimationKey
            {
            < 10DD46A8-775B-11CF-8F52-0040333594A3 >
            DWORD keyType;
            DWORD nKeys;
            array TimedFloatKeys keys[nKeys];
            }

            Where:

            • keyType - Specifies whether the keys are rotation, scale, position, or matrix keys (using the integers 0, 1, 2, or 3, respectively).
            • nKeys - Number of keys.
            • keys - An array of keys. See TimedFloatKeys.

            AnimationOptions

            Enables you to set animation options.

            template AnimationOptions
            {
            < E2BF56C0-840F-11cf-8F52-0040333594A3 >
            DWORD openclosed;
            DWORD positionquality;
            }

            Where:

            • openclosed - Use 0 for a closed animation, or 1 for an open animation. By default, an animation is closed.
            • positionquality - Set the position quality for any position keys specified. Use 0 for spline positions or 1 for linear positions.

            AnimationSet

            Contains one or more Animation objects. Each animation within an animation set has the same time at any given point. Increasing the animation set's time increases the time for all the animations it contains.

            template AnimationSet
            {
            < 3D82AB50-62DA-11cf-AB39-0020AF71E433 >
            [ Animation < 3D82AB4F-62DA-11cf-AB39-0020AF71E433 > ]
            }

            Where:

            • [ Animation < 3D82AB4F-62DA-11cf-AB39-0020AF71E433 > ] - Optional animation template.

            Boolean

            Defines a simple Boolean type.

            template Boolean
            {
            < 537da6a0-ca37-11d0-941c-0080c80cfa7b >
            DWORD truefalse;
            }

            Where:

            • truefalse - True for a Boolean, false otherwise.

            Boolean2d

            Defines a set of two Boolean values used in the MeshFaceWraps template to define the texture topology of an individual face.

            template Boolean2d
            {
            < 4885AE63-78E8-11cf-8F52-0040333594A3 >
            Boolean u;
            Boolean v;
            }

            Where:

            • u - Boolean value. See Boolean.
            • v - Boolean value. See Boolean.

            ColorRGB

            Defines the basic RGB color object.

            template ColorRGB
            {
            < D3E16E81-7835-11cf-8F52-0040333594A3 >
            float red;
            float green;
            float blue;
            }

            ColorRGBA

            Defines a color object with an alpha component. This is used for the face color in the material template definition.

            template ColorRGBA
            {
            < 35FF44E0-6C7C-11cf-8F52-0040333594A3 >
            float red;
            float green;
            float blue;
            float alpha;
            }

            Coords2d

            Defines a two dimensional vector used to define a mesh's (u, v) texture coordinates.

            template Coords2d
            {
            < F6F23F44-7686-11cf-8F52-0040333594A3 >
            float u;
            float v;
            }
            • u - u coordinate value.
            • v - v coordinate value.

            FloatKeys

            Defines an array of floating-point numbers (floats) and the number of floats in that array. This is used for defining sets of animation keys.

            template FloatKeys
            {
            < 10DD46A9-775B-11cf-8F52-0040333594A3 >
            DWORD nValues;
            array float values[nValues];
            }
            • nValues - Number of floats.
            • values[nValues] - Array of float values.

            FrameTransformMatrix

            Defines a local transform for a frame (and all its child objects).

            template FrameTransformMatrix
            {
            < F6F23F41-7686-11cf-8F52-0040333594A3 >
            Matrix4x4 frameMatrix;
            }

            Where:

            • frameMatrix - A Matrix4x4 template.

            Frame

            Defines a coordinate frame, or "frame of reference." The Frame template is open and can contain any object. The D3DX mesh-loading functions recognize Mesh, FrameTransformMatrix, and Frame template instances as child objects when loading a Frame instance.

            template Frame
            {
            < 3D82AB46-62DA-11CF-AB39-0020AF71E433 >
            [...]
            }

            The frame template recognizes child Frame and Mesh nodes inside a frame and can recognize user-defined templates through a callback function.


            posted on 2008-04-16 19:56 lovedday 閱讀(427) 評論(0)  編輯 收藏 引用


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            公告

            導(dǎo)航

            統(tǒng)計

            常用鏈接

            隨筆分類(178)

            3D游戲編程相關(guān)鏈接

            搜索

            最新評論

            久久精品中文字幕久久| 色综合久久中文字幕无码| 一本一本久久aa综合精品 | 久久这里只有精品18| 久久99久久99精品免视看动漫| 色99久久久久高潮综合影院| 欧洲性大片xxxxx久久久| 久久久久久午夜精品| 97久久久精品综合88久久| 无码人妻少妇久久中文字幕| 伊人久久大香线蕉av不卡| 狠狠色婷婷综合天天久久丁香 | 国内精品综合久久久40p| 99久久er这里只有精品18| 精品久久久久久无码人妻蜜桃| 狠狠色丁香婷婷久久综合五月| 狠狠88综合久久久久综合网| 国产成人AV综合久久| 青青青国产成人久久111网站| 久久久久国产| 久久综合丝袜日本网| 久久久久亚洲AV无码观看| 合区精品久久久中文字幕一区| 99久久精品免费看国产一区二区三区 | 欧美激情精品久久久久| 亚洲国产另类久久久精品黑人| 精品人妻伦一二三区久久| 国产精品久久久久影院色| 无码伊人66久久大杳蕉网站谷歌 | 精品久久久久中文字幕一区| 久久精品亚洲一区二区三区浴池 | 91麻豆精品国产91久久久久久| 久久天天躁狠狠躁夜夜躁2O2O| 久久强奷乱码老熟女| 国产99久久久国产精品小说| 国产高清国内精品福利99久久| 97久久精品人妻人人搡人人玩| 欧美va久久久噜噜噜久久| 国内精品伊人久久久久777| 精品国产日韩久久亚洲| 狠狠色婷婷久久一区二区|