开发者

Collada loading with libxml2

开发者 https://www.devze.com 2023-01-10 14:05 出处:网络
I want to load collada with libxml2. I get the COLLOADA node, okay, then I try to get the children tag - FAIL, the children tag name i开发者_运维技巧s \"text\".

I want to load collada with libxml2. I get the COLLOADA node, okay, then I try to get the children tag - FAIL, the children tag name i开发者_运维技巧s "text". Why? How can i get the child of COLLADA node?

xmlNode* geometries = xmlDocGetRootElement(doc)->children;

//at THIS point the geometries->name == "text"  WHY?
//IS not it supposed to be "asset"?

while(!xmlStrcmp(geometries->name, (const xmlChar*)"library_geometries")) 
geometries = geometries->next;


xmlNode* mesh = geometries->children;
for(uint i = 0; i < idx; i++)
mesh = mesh->next;

Where am I wrong?


Take a look at this method from this example in the libxml2 website:

static void
print_element_names(xmlNode * a_node)
{
    xmlNode *cur_node = NULL;

    for (cur_node = a_node; cur_node; cur_node = cur_node->next) {
        if (cur_node->type == XML_ELEMENT_NODE) {
            printf("node type: Element, name: %s\n", cur_node->name);
        }
    }

    print_element_names(cur_node->children);
}

Notice that this code checks if a node is of type XML_ELEMENT_NODE before printing its name. The "text" node that you are reading is the text between the opening and closing tags:

<myTag>This is the text between the tags</myTag>


Okay, problem solved. At every ->children and ->next I had to put another ->next (i don't mean it recursively:)). Btw., I don't know why, but it works that way.

0

精彩评论

暂无评论...
验证码 换一张
取 消