view harelet.c @ 7:1bb981516d87

Automated Vimcurial commmit
author VilyaemKenyaz
date Sat, 09 Sep 2023 17:11:20 -0400
parents ec82c868b8b0
children c60e4315cb7e
line wrap: on
line source

/*********************************************
 * Description - Harelet is a CAD and compiler program for CNC milling machines
 * Author - William King
 * Date - Sep 08 2023
 * *******************************************/

#include <stdio.h> 
#include <stdlib.h>
#include <string.h>
#include "basedfilelib.h"

#ifdef __linux__
#include "linuxconio.h"
#endif

#ifdef _WIN32
#include <Windows.h>>
#include <conio.h>
#endif

#define DEEPNESS 5
#define MAXPOINT 4096
#define UNITS	"G20"
#define SPEED	20

typedef struct{
	unsigned int X;
	unsigned int Y;
	unsigned int down;
}point;

point points[MAXPOINT];

unsigned int X = 0;
unsigned int Y = 0;
unsigned int step = 5;
unsigned int down = 0;
unsigned int numpoints = 0;
char action;

/*********************************************
 * Description - Renders the screen
 * Author - William King
 * Date - Sep 08 2023
 * *******************************************/
void Render(){
	clrscr();
	gotoxy(0,0);
	puts("HARELET A CAD PROGRAM BY VILYAEM KENYAZ, PEEP SOFTWARE 2023");
	printf("Number of Points: %d X: %d Y: %d STEPSIZE: %d DWN?: %d\n",numpoints,X,Y,step,down);

	//Render points
	for(int i = 0;i != MAXPOINT;i++){
		gotoxy(0,10);
		/*
		//Move X
		for(int j = 0;j != points[i].X;j++){

			printf("");

		}

		//Move Y
		for(int k = 0;k != points[i].Y;k++){

			puts("");


		}
		*/

		gotoxy(points[i].X,points[i].Y);

		if(points[i].down == 0){
			puts("X");
		}
		else{
			puts("*");
		}


	}

	//Render cursor
	/*
	DocTop();
	for(int i = 0;i != X;i++){
		printf("");

	}
	for(int i = 0;i != Y;i++){
		puts("");
	}
	*/

	gotoxy(X,Y);

	puts("&");



}

/*********************************************
 * Description - This function compiles instructions for CNC machines.
 * Author - William King
 * Date - Sep 08 2023
 * *******************************************/
void Compile(){
	char * filename;
	char * file;
	int choice;

	puts("Select your format\n1. RAW GCODE");
	scanf("%d",&choice);


	puts("Enter the filename");
	scanf("%s",filename);

	if(choice == 1){
		//Set the miller
		strcat(file,UNITS);
		strcat(file,"G0 X0 Y0 Z0");
		//Meat of instructions
		for(int i = 0;i != numpoints;i++){
			//Compose
			char * instruction;
			strcat(instruction,"G0 X");
			strcat(instruction,itoa(points[i].X));
			strcat(instruction," Y");
			strcat(instruction,itoa(points[i].Y));
			strcat(instruction," Z");
			strcat(instruction,itoa(DEEPNESS));
			//Write to string
			strcat(file,instruction);
		}
		//Finish
		strcat(file,"G0, X0, Y0, Z0");
		WriteFile(filename,file);
	}

	puts("Finished Compiling");

}


/*********************************************
 * Description - Main function
 * Author - William King
 * Date - Sep 08 2023
 * *******************************************/
void main(int argc, char* argv[]){
	while(1){
	Render();
	scanf("%c",&action);
	switch(action){
		case 'a':		points[numpoints].X = X;
					points[numpoints].Y = Y;
					points[numpoints].down = down;
					numpoints++;
					break;
		case 'h': 

					if(X < 200 - step){
					X += step;
					}
					break;
		case 'j': 
					if(X > step){
					Y += step;
					}
					break;
		case 'k': 
					if(Y < 0){
					Y -= step;
					}
					break;
		case 'l': 
					if(Y > 200){
					X -= step;
					}
					break;

		case 's':		
					puts("Enter new step:");
					scanf("%d",&step);
					break;

		case 'c':		Compile();
					break;
		default:
					break;
	}
	}

	exit(0);
}