关于数组元素(ArrayPlug)的增减使用,逻辑索引和物理索引,MArrayDataBuilder

关于数组元素(ArrayPlug)的增减使用,逻辑索引和物理索引,MArrayDataBuilder

我们知道,Maya中接口(Plug)可以包含多个元素,另外每个元素也都可以再包含多个元素,形成一个多层数组接口。Maya SDK专门提供了 MArrayDataHandle 类用于处于数组接口(Array Plug)。但是我们看到,该类只能遍历读取数组元素,但是没有提供增加或者删除数组元素的方法,那如果要想对数组元素进行增减,这个该如何操作呢? 

大家可能都知道 MArrayDataBuilder 这个类可以用于处理数组元素,但是这个Attribute 必须在初始化的时候用 MFnAttribute::setUsesArrayDataBuilder(true) 来指定。默认状态是无法使用MArrayDataBuilder来处理数组的。

另外,该MArrayDataHandle 也必须从有效的data block中获得,如果是直接从接口获得的话,比如用 MPlug::getValue() 或者 MPlug::asMDataHandle()读取获得的话,也无法使用MArrayDataBuilder。

那知道了通过MArrayDataBuilder 可以增减数组元素后,那如何才能正确的增加和删除数组元素呢?这里就涉及到操作 Maya 数组时使用的逻辑索引(Logic index)和物理索引(Physic Index)了。我们知道,Maya允许开发者通过两种不同的方式来操作数组元素,逻辑索引是指元素的逻辑位置,可以是非连续的,标明了某个特定的元素。物理索引的话是指元素的物理位置,是连续的,从【0:elementCount-1】,并且代表的数据有可能会变化。

当需要添加新元素到数组中的时候,如果不清楚当前哪些逻辑索引已经被使用,那么一般推荐使用addLast() 或者addLastArray()函数,如果想要指定该元素的逻辑位置的话,那也可以使用addElement() 或者addLastArray().

同样,在删除的时候,removeElement (unsigned int index) 可用于删除指定逻辑位置的元素。但如果我们要删除数组里面的所有元素,但是元素逻辑索引又是非连续的,那怎么处理呢?

如果有MArrayDataBuilder::removeElementByPhysicIndex( unsigned int position ) 这种方法,那我们可以遍历整个数组,然后依次删除,但是遗憾的是,MArrayDataBuilder并没有提供用于删除指定物理位置元素的方法,那我们就必须找到每一个物理位置对应的逻辑位置,然后再用removeElement (unsigned int index)来删除,具体示例代码如下:

    MArrayDataBuilder outLightningBuilder =outLightningHandle.builder () ;
    uint numElements =outLightningBuilder.elementCount () ;
    for ( uint i =numElements – 1 ; i >= 0 ; –i )

    {

        outLightningHandle.jumpToArrayElement (i) ;
        uint index =outLightningHandle.elementIndex () ;
        outLightningBuilder.removeElement (index) ;
    }

    1. 使用outLightningHandle.jumpToArrayElement (i) 来指定当前元素的物理位置
    2. uint index =outLightningHandle.elementIndex () ; 用于获得该物理索引对应的逻辑索引
    3. outLightningBuilder.removeElement (index) ; 用于删除该元素

另外,要注意的一点是,我们这里删除是从数组的最后一个元素开始删起,这样是为了提高删除的性能。因为我们知道该数组是动态调整的,并可以通过MArrayDataBuilder::growArray (unsigned int amount) 和MArrayDataBuilder::setGrowSize (unsigned int size) 来调整数组增加的大小。举例如果我们从其实位置0开始删除的话,当删除了size个元素后,那么数组可能会做一个move操作,把后面的元素移到前面来减少数组长度来提高空间利用率,这样就会导致额外性能开销。

 

转载于:https://www.cnblogs.com/johnonsoftware/p/3564545.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/109908.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • fastjson JSONArray和JSONObject 转对象数组和对象「建议收藏」

    fastjson JSONArray和JSONObject 转对象数组和对象「建议收藏」fastjsonJSONArray和JSONObject转对象数组和对象

  • Xftp的下载、安装、使用

    Xftp的下载、安装、使用Xftp的下载

    2022年10月20日
  • 20考研 | 2020考研全程规划,19上岸复旦学长。各科各阶段复习规划。

    20考研 | 2020考研全程规划,19上岸复旦学长。各科各阶段复习规划。下面我在分享一下我之前写过的一篇文章高能干货预警文章目前30142字,这可能是最负责的一篇文章了。文章很长,建议拿好笔记慢慢看。本文会解决你在考研各科在不同时期不同阶段遇到的所有问题,方法具体到草稿纸怎么使用,课本具体怎么使用,相信我,读完你一定会有巨大收获。我总结了我一年以来遇到的所有问题,使用的所有方法。既然最终目的是在考研这场「考试」中获得高分,那么所有的时间和精力,都应该围绕…

  • 分苹果算法「建议收藏」

    分苹果算法「建议收藏」题目内容:把M个同样的苹果放在N个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分法?M,N为自然数。说明:如有7个苹果,2个盘子,则(5,1,1)和(1,5,1)和(1,1,5)都是同一种分法。输入描述第一行一个整数表示数据的组数(多组数据),对于每组数据第一行是苹果个数M(1≤m≤100),第二行是盘子个数N(1≤n≤

    2022年10月12日
  • One Piece1-541(ed2k)[通俗易懂]

    One Piece1-541(ed2k)[通俗易懂]1-143http://www.VeryCD.com/topics/143292/144-228http://www.VeryCD.com/topics/17082/229-325http://www.VeryCD.com/topics/39594/326-384http://www.VeryCD.com/topics/198051/385-458ht

    2022年10月19日
  • 浅谈偏序问题_离散偏序关系

    浅谈偏序问题_离散偏序关系浅谈偏序问题所谓偏序问题就是多约束条件的元素统计问题。看起来好像很难理解的样子?比如一维偏序,就是有一种约束条件。其实这个例子比较难举。举个排序的例子吧。现在给出有一个乱序数列,请将其按从大

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号