- Offset b2[3];
- Offset b1[2];
- Offset b0;
- for (int i = 0; i < 3; i++)
- b2[i] = control_[i] + t * (control_[i+1] - control_[i]);
- for (int i = 0; i < 2; i++)
- b1[i] = b2[i] + t * (b2[i+1] - b2[i]);
- b0 = b1[0] + t * (b1[1] - b1[0]);
- left_part.control_[0] = control_[0];
- left_part.control_[1] = b2[0];
- left_part.control_[2] = b1[0];
- left_part.control_[3] = b0;
- right_part.control_[0] = b0;
- right_part.control_[1] = b1[1];
- right_part.control_[2] = b2[2];
- right_part.control_[3] = control_[3];
+ Offset p[CONTROL_COUNT][CONTROL_COUNT];
+
+ for (int i = 0; i < CONTROL_COUNT ; i++)
+ p[i][CONTROL_COUNT - 1 ] = control_[i];
+ for (int j = CONTROL_COUNT - 2; j >= 0 ; j--)
+ for (int i = 0; i < CONTROL_COUNT -1; i++)
+ p[i][j] = p[i][j+1] + t * (p[i+1][j+1] - p[i][j+1]);
+ for (int i = 0; i < CONTROL_COUNT; i++)
+ {
+ left_part->control_[i]=p[0][CONTROL_COUNT - 1 - i];
+ right_part->control_[i]=p[i][i];
+ }