123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202 |
- /*************************************************************************
- * Copyright © 2018-2023 Liwen All rights reserved.
- *------------------------------------------------------------------------
- * File : OsgbLoader.cs
- * Description : load osgb format tile interface
- *------------------------------------------------------------------------
- * Author : Liwen
- * Version : 6.0.0
- * Date : 1/5/2019
- * Description : Initial development version.
- *************************************************************************/
- using System.Collections;
- using System.Collections.Generic;
- using UnityEngine;
- using System.Runtime.InteropServices;
- using System;
- namespace AIPagedLod
- {
- public class OsgbLoader
- {
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetCC")]
- public static extern bool GetOsgbFileCenter(string file, ref float center);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "OpenXXFile")]
- public static extern IntPtr OpenOsgbFile(string file);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "OpenXXFileEx")]
- public static extern IntPtr OpenOsgbFileEx(string file);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "CloseXXFile")]
- public static extern void CloseOsgbFile(IntPtr ptr);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetMCC")]
- public static extern int GetMeshCount(IntPtr ptr);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetVCC")]
- public static extern int GetVertexCount(IntPtr ptr, int index);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetVP")]
- public static extern IntPtr GetVertexPointer(IntPtr ptr, int meshIndex, int vertexIndex);
- public static Vector3 GetVertex(IntPtr ptr)
- {
- float[] array = new float[3];
- Marshal.Copy(ptr, array, 0, 3);
- return new Vector3(-array[0], array[1], array[2]);
- }
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetVS")]
- private static extern void GetVertexs(IntPtr ptr, int meshIndex, ref float vertexs);
- public static Vector3[] GetVertexs(IntPtr ptr, int meshIndex, bool isDaJiangData)
- {
- int vertexCount = GetVertexCount(ptr, meshIndex);
- Vector3[] results = new Vector3[vertexCount];
- if (vertexCount > 0)
- {
- float[] vertexs = new float[vertexCount * 3];
- GetVertexs(ptr, meshIndex, ref vertexs[0]);
- int index = 0;
- int scaleValue = isDaJiangData ? 100000 : 1;
- for (int i = 0; i < vertexs.Length; i = i + 3)
- {
- results[index] = new Vector3(vertexs[i] * scaleValue, vertexs[i + 2], vertexs[i + 1] * scaleValue);
- //results[index] = new Vector3(vertexs[i] * scaleValue, -vertexs[i + 1] * scaleValue, vertexs[i + 2]);
- index++;
- }
- }
- return results;
- }
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetTCC")]
- public static extern int GetTriangleCount(IntPtr ptr, int meshIndex);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetTP")]
- public static extern IntPtr GetTrianglePointer(IntPtr ptr, int meshIndex);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetTS")]
- public static extern void GetTriangles(IntPtr ptr, int meshIndex,ref int triangles );
- public static int[] GetTriangles(IntPtr ptr, int meshIndex, bool isDaJiangData)
- {
- int count = GetTriangleCount(ptr, meshIndex);
- int[] array = new int[count];
- if (count > 0)
- {
- GetTriangles(ptr, meshIndex, ref array[0]);
- if (!isDaJiangData)
- {
- for (int i = 1; i < array.Length; i = i + 3)
- {
- int t = array[i];
- array[i] = array[i + 1];
- array[i + 1] = t;
- }
- }
- }
- return array;
- }
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetISize")]
- public static extern int GetImageSize(IntPtr ptr, int meshIndex);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetIP")]
- public static extern IntPtr GetImagePointer(IntPtr ptr, int meshIndex);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetResolutionS")]
- public static extern int GetImageResolutionS(IntPtr ptr, int meshIndex);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetResolutionT")]
- public static extern int GetImageResolutionT(IntPtr ptr, int meshIndex);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetImageFormat")]
- public static extern int GetImageFormat(IntPtr ptr, int meshIndex);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetID")]
- private static extern void GetImageData(IntPtr ptr, int meshIndex,ref byte iamgeData);
- public static byte[] GetImageData(IntPtr ptr, int meshIndex)
- {
- int imageSize = GetImageSize(ptr,meshIndex);
- byte[] imageData = new byte[imageSize];
- if (imageSize > 0)
- {
- GetImageData(ptr, meshIndex, ref imageData[0]);
- }
- return imageData;
- }
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetTCCC")]
- public static extern int GetTexCoordCount(IntPtr ptr, int index);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetTCP")]
- public static extern IntPtr GetTexCoordPointer(IntPtr ptr, int meshIndex, int texCoordIndex);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetTCS")]
- private static extern void GetTexCoords(IntPtr ptr, int meshIndex, ref float texCoords);
- public static Vector2[] GetTexCoords(IntPtr ptr, int meshIndex)
- {
- int vertexCount = GetTexCoordCount(ptr, meshIndex);
- Vector2[] results = new Vector2[vertexCount];
- if (vertexCount > 0)
- {
- float[] texCoords = new float[vertexCount * 2];
- GetTexCoords(ptr, meshIndex, ref texCoords[0]);
- int index = 0;
- for (int i = 0; i < texCoords.Length; i = i + 2)
- {
- results[index] = new Vector3(texCoords[i], texCoords[i + 1]);
- index++;
- }
- }
- return results;
- }
- public static Vector2 GetTexCoord(IntPtr ptr)
- {
- var array = new float[2];
- Marshal.Copy(ptr, array, 0, 2);
- return new Vector2(array[0], array[1]);
- }
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetCFCC")]
- public static extern int GetChildFileCount(IntPtr ptr);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetCF")]
- public static extern void GetChildFile(IntPtr ptr,int index, ref byte outputFile);
- public static string GetChildTileFile(IntPtr ptr, int index)
- {
- byte[] byteOutput = new byte[256];
- GetChildFile(ptr, index,ref byteOutput[0]);
- return System.Text.Encoding.ASCII.GetString(byteOutput, 0, byteOutput.Length);
- }
- //从内存中读取结点信息
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "OpenFromBuf")]
- public static extern IntPtr OpenOsgbFileFromBuffer(ref byte dataBuf,int lenth);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetBR")]
- public static extern float GetBoundRadius(IntPtr ptr);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetRL")]
- public static extern void GetRangeList(IntPtr ptr, int childIndex, ref float rangeValues);
- [DllImport("osgdb_reader", CharSet = CharSet.Ansi, EntryPoint = "GetBoundsBox")]
- public static extern void GetBoundsBox(IntPtr ptr, ref float center, ref float min, ref float max);
- }
- }
|