本文整理匯總了Golang中github.com/tgascoigne/xdr2obj/resource.Container.Parse方法的典型用法代碼示例。如果您正苦於以下問題:Golang Container.Parse方法的具體用法?Golang Container.Parse怎麽用?Golang Container.Parse使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/tgascoigne/xdr2obj/resource.Container
的用法示例。
在下文中一共展示了Container.Parse方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: Unpack
func (buf *IndexBuffer) Unpack(res *resource.Container) error {
buf.Stride = 3 * 2 // 3*uint16 /* is this stored anywhere? */
res.Parse(&buf.IndexHeader)
buf.Index = make([]*types.Tri, buf.Count/3)
for i := range buf.Index {
buf.Index[i] = new(types.Tri)
}
if err := res.Detour(buf.Buffer, func() error {
buffer := make([]byte, buf.Stride)
reader := bytes.NewReader(buffer)
for _, idx := range buf.Index {
/* Read the index into our local buffer */
if size, err := res.Read(buffer); size != buf.Stride || err != nil {
return err
}
/* Parse out the info we can */
if err := binary.Read(reader, binary.BigEndian, idx); err != nil {
return err
}
reader.Seek(0, 0)
}
return nil
}); err != nil {
return err
}
return nil
}
示例2: Unpack
func (model *Model) Unpack(res *resource.Container) error {
res.Parse(&model.Header)
geomCollection := &model.Header.GeometryCollection
model.Geometry = make([]*Geometry, geomCollection.Count)
for i := range model.Geometry {
model.Geometry[i] = new(Geometry)
}
err := geomCollection.For(res, func(i int) error {
geometry := model.Geometry[i]
if err := geometry.Unpack(res); err != nil {
return err
}
if model.Header.ShaderMappings.Valid() {
if err := res.PeekElem(model.Header.ShaderMappings, i, &geometry.Shader); err != nil {
return err
}
} else {
geometry.Shader = ShaderNone
}
return nil
})
if err != nil {
return err
}
return nil
}
示例3: Unpack
func (param *Parameter) Unpack(res *resource.Container) error {
res.Parse(¶m.ParameterHeader)
if !param.Offset.Valid() {
return nil
}
switch param.Type {
case ParamDiffuseBitmap, ParamNormalBitmap:
bitmap := new(BitmapParameter)
if err := res.Detour(param.Offset, func() error {
res.Parse(bitmap)
param.parameter = bitmap
return nil
}); err != nil {
return err
}
default:
/* unsupported parameter. don't bother giving an error for now */
param.parameter = nil
}
return nil
}
示例4: Unpack
func (texture *Texture) Unpack(res *resource.Container) error {
res.Parse(&texture.Header)
texture.Bitmaps = make(Bitmaps, texture.Header.Bitmaps.Capacity)
if err := texture.Bitmaps.Unpack(res, &texture.Header.Bitmaps); err != nil {
return err
}
return nil
}
示例5: unpackVertices
func (vol *Volume) unpackVertices(res *resource.Container) error {
for i := 0; i < int(vol.VertexCount); i++ {
iVec := new(types.Vec3i)
res.Parse(iVec)
x := (float32(iVec[0]) * vol.ScaleFactor[0]) + vol.Offset[0]
y := (float32(iVec[1]) * vol.ScaleFactor[1]) + vol.Offset[1]
z := (float32(iVec[2]) * vol.ScaleFactor[2]) + vol.Offset[2]
v := mathgl.Vec4f{x, y, z, 1.0}
vol.AddVert4f(v)
}
return nil
}
示例6: Unpack
func (vol *Volume) Unpack(res *resource.Container) error {
res.Parse(&vol.VolumeHeader)
vol.Mesh = export.NewMesh()
res.Detour(vol.VerticesAddr, func() error {
return vol.unpackVertices(res)
})
res.Detour(vol.IndicesAddr, func() error {
return vol.unpackFaces(res)
})
return nil
}
示例7: Get
func (bmp *BitmapParameter) Get(res *resource.Container) (string, error) {
if !bmp.Path.Valid() {
return "", nil
}
var path string
if err := res.Detour(bmp.Path, func() error {
res.Parse(&path)
return nil
}); err != nil {
return "", err
}
return path, nil
}
示例8: Unpack
func (nodes *Nodes) Unpack(res *resource.Container) error {
res.Parse(&nodes.NodesHeader)
var err error
nodes.Volumes = make([]*Volume, nodes.Capacity)
volCollection := resource.PointerCollection{
Addr: nodes.BoundsTable,
Count: nodes.Count,
Capacity: nodes.Capacity,
}
volInfoCollection := resource.Collection{
Addr: nodes.VolumeInfo,
Count: nodes.Count,
Capacity: nodes.Capacity,
}
err = volInfoCollection.For(res, func(i int) error {
nodes.Volumes[i] = new(Volume)
if err := nodes.Volumes[i].VolumeInfo.Unpack(res); err != nil {
return err
}
return nil
})
if err != nil {
return err
}
err = volCollection.For(res, func(i int) error {
return nodes.Volumes[i].Unpack(res)
})
if err != nil {
return err
}
nodes.Model = export.NewModel()
for _, vol := range nodes.Volumes {
nodes.Model.AddMesh(vol.Mesh)
}
return nil
}
示例9: unpackFaces
func (vol *Volume) unpackFaces(res *resource.Container) error {
fixIndex := func(c uint16) uint16 {
c &= 0x7FFF
return c
}
for i := 0; i < int(vol.IndexCount); i++ {
var polygonType, junk uint16
res.Parse(&junk)
res.Parse(&polygonType)
idxValues := make([]uint16, 6)
res.Parse(idxValues)
debug := func(junk, polyType uint16, idxValues []uint16) {
fmt.Printf("%.4x ", junk)
fmt.Printf("%.4x ", polyType)
for _, i := range idxValues {
fmt.Printf("%.4x ", i)
}
fmt.Printf("\n")
}
polygonType &= 0xF
if polygonType == 0x4 {
// debug(junk, polygonType, idxValues)
} else if polygonType == 0x3 || polygonType == 0xB {
/* cube, 4 points specified */
a := fixIndex(idxValues[0])
b := fixIndex(idxValues[1])
c := fixIndex(idxValues[2])
d := fixIndex(idxValues[3])
buildCube(vol.Mesh, a, b, c, d)
} else if polygonType == 0x2 {
/* seems to be two points */
a := fixIndex(junk)
b := fixIndex(idxValues[2])
traceVerts(vol.Mesh, a, b)
} else if polygonType == 0x1 {
// debug(junk, polygonType, idxValues)
} else if polygonType == 0x0 || polygonType == 0x8 { /* it's probably a triangle */
a := fixIndex(idxValues[0])
b := fixIndex(idxValues[1])
c := fixIndex(idxValues[2])
vol.AddFace(types.Tri{
A: a,
B: b,
C: c,
})
} else {
debug(junk, polygonType, idxValues)
}
}
return nil
}
示例10: Unpack
func (drawable *Drawable) Unpack(res *resource.Container) error {
res.Parse(&drawable.Header)
drawable.Model = export.NewModel()
/* unpack */
if drawable.Header.ShaderTable.Valid() {
if err := res.Detour(drawable.Header.ShaderTable, func() error {
return drawable.Shaders.Unpack(res)
}); err != nil {
return err
}
}
if err := res.Detour(drawable.Header.ModelCollection, func() error {
return drawable.Models.Unpack(res)
}); err != nil {
return err
}
if drawable.Header.Title.Valid() {
if err := res.Detour(drawable.Header.Title, func() error {
res.Parse(&drawable.Title)
drawable.Title = drawable.Title[:strings.LastIndex(drawable.Title, ".")]
return nil
}); err != nil {
return err
}
} else {
drawable.Title = fmt.Sprintf("unnamed_%v", NextUnnamedIndex)
NextUnnamedIndex++
}
/* Load everything into our exportable */
drawable.Model.Name = drawable.Title
for _, shader := range drawable.Shaders.Shaders {
material := export.NewMaterial()
if shader.DiffusePath != "" {
material.DiffBitmap = fmt.Sprintf("%v.dds", shader.DiffusePath)
}
drawable.Model.AddMaterial(material)
}
for _, model := range drawable.Models.Models {
for _, geom := range model.Geometry {
mesh := export.NewMesh()
mesh.Material = int(geom.Shader)
for _, vert := range geom.Vertices.Vertex {
/* Even if a feature isn't supported, the nil value should be fine */
newVert := export.Vertex{
Pos: mathgl.Vec4f{
vert.WorldCoord[0],
vert.WorldCoord[1],
vert.WorldCoord[2],
1.0,
},
UV: mathgl.Vec2f{
vert.UV0.U.Value(),
(-vert.UV0.V.Value()) + 1,
},
Colour: vert.Colour,
}
mesh.AddVert(newVert)
}
mesh.Format = geom.Vertices.Format
for _, face := range geom.Indices.Index {
mesh.AddFace(*face)
}
drawable.Model.AddMesh(mesh)
}
}
return nil
}