• <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>

            天行健 君子當自強而不息

            Using the .X File Format(1)

            Your 3D meshes need a place to liverather, you need a place to store your 3D mesh data (not to mention all that other data your game project requires). What's a developer to do−develop his own file format or go with a third−party format? With so many popular formats out there, it's an easy choice to make, but what about the restrictions some formats impose? Why can't you just use somebody else's file format and configure it to work the way you want?

            That somebody else is none other than Microsoft, and the format to use is .X! Now uncross those eyes, mister−those .X files are really easy to use once you understand them, and this chapter will teach you what you need to know.

             

            Working with .X Templates and Data Objects

            If you haven't already, I invite you to take a look at one of those mysterious .X files that comes packaged with the DirectX SDK (located in the \Samples\Multimedia\Media directory of your DirectX install). Go on, I dare you. More than likely, you'll be greeted with something like this:

            xof 0302txt 0032
            template Header {
            <3D82AB43−62DA−11cf−AB39−0020AF71E433>
            DWORD major;
            DWORD minor;
            DWORD flags;
            }
            template Frame {
            <3D82AB46−62DA−11cf−AB39−0020AF71E433>
            [FrameTransformMatrix]
            [Mesh]
            }
            Header {
            1;
            0;
            1;
            }
            Frame Scene_Root {
            FrameTransformMatrix {
            1.000000, 0.000000, 0.000000, 0.000000,
            0.000000, 1.000000, 0.000000, 0.000000,
            0.000000, 0.000000, 1.000000, 0.000000,
            0.000000, 0.000000, 0.000000, 1.000000;;
            }
            	Frame Pyramid_Frame {
            FrameTransformMatrix {
            1.000000, 0.000000, 0.000000, 0.000000,
            0.000000, 1.000000, 0.000000, 0.000000,
            0.000000, 0.000000, 1.000000, 0.000000,
            0.000000, 0.000000, 0.000000, 1.000000;;
            }
            		Mesh PyramidMesh {
            5;
            0.00000;10.00000;0.00000;,
            −10.00000;0.00000;10.00000;,
            10.00000;0.00000;10.00000;,
            −10.00000;0.00000;−10.00000;,
            10.00000;0.00000;−10.00000;;
            6;
            3;0,1,2;,
            3;0,2,3;,
            3;0,3,4;,
            3;0,4,1;,
            3;2,1,4;,
            3;2,4,3;;
            			MeshMaterialList {
            1;
            6;
            0,0,0,0,0,0;;
            				Material Material0 {
            1.000000; 1.000000; 1.000000; 1.000000;;
            0.000000;
            0.050000; 0.050000; 0.050000;;
            0.000000; 0.000000; 0.000000;;
            }
            }
            }
            }
            }

            Scary looking, isn't it? Actually, you can break down every .X file into a small handful of easy−to−manage components, which makes the files easy to understand and process. Let me explain what I mean. Every .X file starts with a small header, which in the preceding example looks like this:

            xof 0302txt 0032

            This small blurb of text informs programs that load the file that it is indeed an .X file. (The xof portion signifies an .X file.) It also informs programs that the file uses the DirectX .X file version 3.2 templates (represented by the 0302 text). Following the version number is txt, which signifies that all of the following .X data is stored in a text format as opposed to a binary format. The line of text ends with 0032, which defines the number of bits reserved for floating−point values (0032 for 32−bit or 0064 for 64−bit).

            Note Binary, a second .X file storage format, is useful for compacting data into a format that is unreadable by humans. I won't discuss the binary format; however, the techniques used to process .X files in this chapter still apply to binary .X files, so don't worry about missing out on any good stuff!

            After the file header there are a slew of data chunks, referred to as templates and data objects. You can tell the difference between a template and a data object because all templates begin with the word template. As you can see from the .X file code, templates look much like a C structure definition. Data objects are instances of those templates.

            You use templates to define the information that data objects contain in the .X file. (A template defines the layout of a data object.) Each template can contain any type of data defined by a small set of data types, and any combination of data types can be used inside a template. A data object is merely an instance of a template. You can think of a template much like a C++ class−they both define the data that an instance of the object can contain.

            Taking another look at the example .X file, you can see that the first template you'll encounter is Header, which is the template's class name. The Header template contains three DWORD values (as well as a large number called a GUID, which is enclosed in angle brackets), which you set when you create a data object from the template. Creating data objects is much like instancing a class or structure. In the previous .X file code, the instancing of the Header template looks like this:

            Header {
              1; // major
              0; // minor
              1; // flags
            }

            Notice that you must define every variable contained in the Header template in your data object, and in the same order. You might be wondering about that large number (the template's GUID) defined in the template, however. What does that have to do with instancing your template? Nothing, actually, because DirectX uses that large number to identify templates as they are loaded. I'll get back to the template GUID (Globally Unique Identification Number) in a moment.

            Tip Much like C/C++, you can also use the handy // operator to signify comments in your .X file.

            The next template you'll see in the .X file is Frame. This is a special template−it doesn't define any data types, but it does reference other template classes. The other template classes, enclosed in square brackets, are named FrameTransformMatrix and Mesh. Using this manner of referencing other templates from within a template, you can create a hierarchy of data objects.

            Also, by declaring additional templates within another template, you are creating a set of template restrictions, which enable you to create templates that only allow specific data objects to be embedded within another data object. In this case, only the data objects of the type FrameTransformMatrix and Mesh can be embedded in a Frame data object. You'll read more about template restrictions later in this chapter. For now, move on to examining the rest of the .X file.

            Following the template definitions (which should also be at the beginning of the .X file) are the data objects. These are declared much like C data structures would be−you instance the structure by its template class name, followed by the data object's instance name. The instance name is optional, however, so don't worry if you come across some data objects that are missing it.

            In the .X file you're examining, the first data object has an instance name of Scene_Root. The Scene_Root object is of the template class type Frame. You've already seen the Frame template defined. Looking back to that template definition, you can see that there is no data to store, but there are two optional data objects you can embed in Frame−FrameTransformMatrix and Mesh.

            Just by a matter of luck, both a FrameTransformMatrix and a Mesh data object are embedded in Scene_Root. Missing from the .X file, however, are the template definitions for FrameTransformMatrix and Mesh. How are you supposed to know what data those objects contain? Well, an .X file doesn't have to define every template with the file itself−you can define those template definitions inside your program!

            You'll get to see how to define these templates within your programs later in this chapter. For now, let's get back to the example. A data object of the template class type FrameTransformMatrix is embedded in the Scene_Root data object. This data object contains floating−point values that represent a transformation matrix. After that data object there is another data object of the template class type Mesh, which contains information about a mesh.

            Okay, enough of this example−I'm sure you're getting the gist of it. As you can see, templates are completely user−defined, meaning that you can create any type of template to contain any type of data. Want to contain raw sound data in an .X file? How about storing heartbeat−sensor readings? Using .X, you can store sound data, heartbeat readings, and any other type of data you want!


            posted on 2008-04-16 18:37 lovedday 閱讀(740) 評論(1)  編輯 收藏 引用

            評論

            # re: Using the .X File Format(1) 2010-11-16 23:38 可耕地

            抄書嗎?  回復  更多評論   

            公告

            導航

            統計

            常用鏈接

            隨筆分類(178)

            3D游戲編程相關鏈接

            搜索

            最新評論

            超级碰碰碰碰97久久久久| 久久免费精品视频| 亚洲午夜久久久影院| 人妻精品久久无码区| 麻豆精品久久精品色综合| 成人国内精品久久久久影院VR| 国产亚洲精久久久久久无码AV| 精品无码久久久久久午夜| 青青国产成人久久91网| 日本精品一区二区久久久| 久久久久女人精品毛片| 久久久久久久久久久免费精品| 伊人久久综合精品无码AV专区| 久久香蕉国产线看观看乱码| 欧美一区二区久久精品| 91久久成人免费| 色天使久久综合网天天| 国产日韩久久免费影院| 久久青青草原亚洲av无码app | 国产精品久久婷婷六月丁香| 人妻少妇久久中文字幕一区二区| 久久综合久久鬼色| 久久精品草草草| 久久66热人妻偷产精品9| 亚洲国产日韩欧美综合久久| 国产叼嘿久久精品久久| 色综合色天天久久婷婷基地| 无码日韩人妻精品久久蜜桃 | 中文成人无码精品久久久不卡| 1000部精品久久久久久久久| 大伊人青草狠狠久久| 久久久久精品国产亚洲AV无码| 亚洲精品NV久久久久久久久久| 久久国产一片免费观看| 久久国产精品免费一区| 精品无码久久久久久久久久| 国产成人香蕉久久久久| 久久99热这里只有精品国产| 久久精品国产WWW456C0M| 欧美午夜精品久久久久久浪潮| 九九热久久免费视频|