using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class Exponential : MonoBehaviour
{
    Mesh mesh;

    public int minX;
    public int maxX;

    public float factor;
    public float c;
    // Start is called before the first frame update
    void Start()
    {
        mesh = new Mesh
        {
            name = "Exponential"
        };
    }

    // Update is called once per frame
    void Update()
    {
        
    }
    public void DrawExponential()
    {
        mesh.Clear();

        float step = 0.01f;
        Vector3[] vectors = new Vector3[100 * (maxX - minX) + 1];
        int k = 0;
        for (float i = minX; i <= maxX; i = i + step)
        {
            float y = Mathf.Pow(c, i);
            y *= factor;
            vectors[k] = new Vector3(i, y, 0);
            k++;
        }
        vectors[100 * (maxX - minX)] = new Vector3(maxX, Mathf.Pow(c, maxX) * factor, 0);
        mesh.vertices = vectors;

        int[] triangle = new int[100 * (maxX - minX) * 2];
        for (int i = 0; i < vectors.Length - 1; ++i)
        {
            triangle[2 * i] = i;
            triangle[2 * i + 1] = i + 1;
        }

        mesh.SetIndices(triangle, MeshTopology.Lines, 0);

        GetComponent<MeshFilter>().mesh = mesh;
    }

    public void DrawExponential3D()
    {
        mesh.Clear();

        float step = 0.01f;
        Vector3[] vectors = new Vector3[200 * (maxX - minX) + 2];
        int k = 0;
        for (float i = minX; i <= maxX; i = i + step)
        {
            float y = Mathf.Pow(c, i);
            y *= factor;
            vectors[k] = new Vector3(i, y, -5);
            k++;
            vectors[k] = new Vector3(i, y, 5);
            k++;
        }
        vectors[200 * (maxX - minX)] = new Vector3(maxX, Mathf.Pow(c, maxX) * factor, -5);
        vectors[200 * (maxX - minX) + 1] = new Vector3(maxX, Mathf.Pow(c, maxX) * factor, 5);
        mesh.vertices = vectors;

        Vector2[] uvs = new Vector2[vectors.Length];
        for (int i = 0; i < uvs.Length; i++)
        {
            uvs[i] = new Vector2(0, vectors[i].y / 100);
        }
        mesh.uv = uvs;

        int[] triangle = new int[100 * (maxX - minX) * 6];
        for (int i = 0; i < 100 * (maxX - minX); ++i)
        {
            triangle[6 * i] = 2 * i;
            triangle[6 * i + 1] = 2 * i + 1;
            triangle[6 * i + 2] = 2 * i + 2;
            triangle[6 * i + 3] = 2 * i + 1;
            triangle[6 * i + 4] = 2 * i + 3;
            triangle[6 * i + 5] = 2 * i + 2;
        }

        mesh.SetIndices(triangle, MeshTopology.Triangles, 0);

        GetComponent<MeshFilter>().mesh = mesh;
    }

    public void MeshClear()
    {
        mesh.Clear();
        GetComponent<MeshFilter>().mesh = mesh;
    }
}