示例#1
0
    void generateChildrenRecursive(SegmentDataVine _parent)
    {
        if (_parent.depth > 5)
        {
            return;
        }

        float childNumberRoll = Random.value;
        float probSum         = 0;
        int   childrenCount   = 0;

        for (int i = 0; i < branchChances.Length; i++)
        {
            probSum += branchChances[i];
            if (childNumberRoll <= probSum)
            {
                childrenCount = i;
                break;
            }
        }
        for (int i = 0; i < childrenCount; i++)
        {
            SegmentDataVine child = generateChildSegment(_parent);
            _parent.children.Add(child);
            generateChildrenRecursive(child);
        }
    }
示例#2
0
    SegmentDataVine generateChildSegment(SegmentDataVine _parent)
    {
        Vector3 child_dir = Random.insideUnitCircle * vineSpreadRadius;

        child_dir.z = child_dir.y;
        float segment_length = Random.Range(minSegmentLength, maxSegmentLength);

        child_dir.y = segment_length;

        Vector3 segment_start = _parent.start + _parent.dir * _parent.length;

        Vector3 drag = child_dir + segment_start;

        drag.y = 0;
        drag   = goalCenter - drag;
        drag  *= dragStrength;

        child_dir += drag;

        SegmentDataVine child_segment = new SegmentDataVine();

        child_segment.start     = segment_start;
        child_segment.dir       = child_dir.normalized;
        child_segment.length    = child_dir.magnitude;
        child_segment.children  = new List <SegmentDataVine>();
        child_segment.depth     = _parent.depth + 1;
        child_segment.timeStart = _parent.timeEnd;
        child_segment.timeEnd   = child_segment.timeStart + child_segment.length;
        return(child_segment);
    }
示例#3
0
    void drawCylindersRecursive(SegmentDataVine _parent)
    {
        _parent.visual = GameObject.Instantiate(segmentPrefab);
        _parent.visual.transform.rotation = Quaternion.FromToRotation(Vector3.up, _parent.dir);

        _parent.visual.transform.position = _parent.start + _parent.dir * (_parent.length / 2);
        float xz_scale = 1.0f / (Mathf.Pow(_parent.depth + 1, scaleFallofPower));

        _parent.visual.transform.localScale = new Vector3(segmentXZScale * xz_scale, _parent.length / 2, segmentXZScale * xz_scale);

        float h, s, v;

        Color.RGBToHSV(_parent.visual.GetComponent <Renderer>().material.color, out h, out s, out v);
        s += Random.Range(-0.5f, 0.0f);
        _parent.visual.GetComponent <Renderer>().material.color = Color.HSVToRGB(h, s, v);
        foreach (SegmentDataVine child in _parent.children)
        {
            drawCylindersRecursive(child);
        }
    }
示例#4
0
    void updateCylindersRecursive(SegmentDataVine segment)
    {
        Vector3 segmentScale    = segment.visual.transform.localScale;
        Vector3 segmentPosition = segment.start;

        if (time < segment.timeStart)
        {
            segmentScale.y = 0;
        }
        else if (time > segment.timeEnd)
        {
            segmentScale.y   = segment.length / 2; //Cylinders have length 2
            segmentPosition += segment.dir * segment.length / 2;
        }
        else
        {
            float scalar = (time - segment.timeStart) / (segment.timeEnd - segment.timeStart);
            scalar           = -1.0f / 2.0f * (Mathf.Cos(Mathf.PI * scalar) - 1.0f);
            segmentScale.y   = scalar * segment.length / 2;
            segmentPosition += segment.dir * segment.length * scalar * 0.5f;
        }

        segment.visual.transform.localScale = segmentScale;
        segment.visual.transform.position   = segmentPosition;

        if (segmentScale.y == 0)
        {
            segment.visual.gameObject.SetActive(false);
        }
        else
        {
            segment.visual.gameObject.SetActive(true);
        }

        foreach (SegmentDataVine child in segment.children)
        {
            updateCylindersRecursive(child);
        }
    }
示例#5
0
    // Use this for initialization
    void Start()
    {
        vineSpreadRadius = Random.Range(vineSpreadRadiusMid - vineSpreadRadiusRange / 2, vineSpreadRadiusMid + vineSpreadRadiusRange / 2);
        maxSegmentLength = Random.Range(maxSegmentLengthMid - maxSegmentLengthMid / 2, maxSegmentLengthMid + maxSegmentLengthMid / 2);

        SegmentDataVine seed_segment = new SegmentDataVine();

        seed_segment.start     = transform.position;
        seed_segment.dir       = new Vector3(0, 1, 0);
        seed_segment.length    = 0.0f;
        seed_segment.depth     = -1;
        seed_segment.timeStart = 0;
        seed_segment.timeEnd   = 0;

        goalCenter   = transform.position;
        goalCenter.y = 0;

        goalCenter  += transform.rotation * goalOffset;
        root_segment = generateChildSegment(seed_segment);

        generateChildrenRecursive(root_segment);

        drawCylindersRecursive(root_segment);
    }