9

我有以下记录定义

  E3Vector3T = packed record
  public
      x: E3FloatT;
      y: E3FloatT;
      z: E3FloatT;

      function length: E3FloatT;
      function normalize: E3Vector3T;
      function crossProduct( const aVector: E3Vector3T ): E3Vector3T;

      class operator add( const aVector1, aVector2: E3Vector3T ): E3Vector3T;
      class operator subtract( const aVector1, aVector2: E3Vector3T ): E3Vector3T;
      class operator negative( const aVector: E3Vector3T ): E3Vector3T;
      class operator multiply( const aVector: E3Vector3T; const aScalar: E3FloatT ): E3Vector3T;
      class operator divide( const aVector: E3Vector3T; const aScalar: E3FloatT ): E3Vector3T;
  end;

我想做的是引入一个变体记录部分,以便能够单独访问三个元素,也可以作为一个数组访问这三个元素,即

  E3Vector3T = packed record
  public
      case boolean of
          true: (
              x: E3FloatT;
              y: E3FloatT;
              z: E3FloatT;
          );
          false: (
              elements: packed array[0..2] of E3FloatT;
          );

      function length: E3FloatT;
      ..
  end;

这不会编译(函数需要函数长度的结果类型)。有什么明显的我做错了,还是不支持?在这种情况下,对于以数组形式访问各个字段的优雅而高效的方式有什么建议吗?

ps E3FloatT 是 Single 的简单类型别名。

4

2 回答 2

9

也许这是编译器的疏忽,但是当方法在变体部分之前声明时,它确实会编译。这似乎是一个合理的解决方案。

E3Vector3T = packed record
  public
      function length: E3FloatT;
      ..

      case boolean of
          true: (
              x: E3FloatT;
              y: E3FloatT;
              z: E3FloatT;
          );
          false: (
              elements: packed array[0..2] of E3FloatT;
          );
  end;
于 2010-03-09T21:24:31.553 回答
6

将函数声明移到顶部,如下所示:

  E3Vector3T = packed record
  public
      function length: E3FloatT;
      case boolean of
          true: (
              x: E3FloatT;
              y: E3FloatT;
              z: E3FloatT;
          );
          false: (
              elements: packed array[0..2] of E3FloatT;
          );

  end;

这在 Delphi 2010 中编译。

于 2010-03-09T21:18:54.250 回答