Draw the first line

Correct line girth calculation. (sin <-> -sin)
This commit is contained in:
Marcel Plch 2024-10-13 23:54:16 +02:00
parent 1f4565c0a5
commit c83039098c
Signed by: dormouse
GPG key ID: 2CA77596BC4BDFFE
2 changed files with 34 additions and 7 deletions

View file

@ -124,6 +124,7 @@ cx_glinit(GLFWwindow **window) {
int int
cx_glrun(GLFWwindow *window) { cx_glrun(GLFWwindow *window) {
Model *model;
ModelRegistry *mr; ModelRegistry *mr;
Model *neural_network_model; Model *neural_network_model;
GLuint VertexArrayID; GLuint VertexArrayID;
@ -140,7 +141,7 @@ cx_glrun(GLFWwindow *window) {
for (int i = 0; i < 64; i++) { for (int i = 0; i < 64; i++) {
// Load model to render from file // Load model to render from file
//Model *model = model_load("../3d_assets/triangle.obj"); //Model *model = model_load("../3d_assets/triangle.obj");
Model *model = model_circle(0, (GLfloat)1/64); model = model_circle(0, (GLfloat)1/64);
GLfloat *translation_matrix = matrix_new(); GLfloat *translation_matrix = matrix_new();
GLfloat *aspectRatio_matrix = matrix_new(); GLfloat *aspectRatio_matrix = matrix_new();
aspectRatio_matrix[0] = (GLfloat)9/16; aspectRatio_matrix[0] = (GLfloat)9/16;
@ -158,6 +159,8 @@ cx_glrun(GLFWwindow *window) {
modelRegistry_register(mr, model); modelRegistry_register(mr, model);
} }
} }
model = model_line(-0.5, 0, 0.5, 0, 0.015);
modelRegistry_register(mr, model);
// Remainder from cursor experiments, might be useful later // Remainder from cursor experiments, might be useful later

View file

@ -83,10 +83,15 @@ model_applyTransformations(Model *self) {
// Temporary storage of transformation results // Temporary storage of transformation results
GLfloat *temp_buffer[2] = {NULL}; GLfloat *temp_buffer[2] = {NULL};
// BANANA, ROH-TAH-TEH // BANANA, ROH-TAH-TEH
temp_buffer[1] = malloc(self->bufsize * 4 * sizeof(GLfloat)); temp_buffer[1] = malloc(self->bufsize * 4 * sizeof(GLfloat));
memcpy(temp_buffer[1], self->object, self->bufsize * 4 * sizeof(GLfloat)); memcpy(temp_buffer[1], self->object, self->bufsize * 4 * sizeof(GLfloat));
if (!self->transformation_count) {
return temp_buffer[1];
}
int i = 0; int i = 0;
do { do {
temp_buffer[i%2] = matrix_transform(temp_buffer[(i+1)%2], temp_buffer[i%2] = matrix_transform(temp_buffer[(i+1)%2],
@ -187,16 +192,17 @@ model_line(float x1, float y1, float x2, float y2, float girth) {
y_diff = y2 - y1; y_diff = y2 - y1;
line_length = sqrt((x_diff*x_diff) + (y_diff*y_diff)); line_length = sqrt((x_diff*x_diff) + (y_diff*y_diff));
printf("%f, ", girth); float normal_x = (cos(M_PI/2) * x_diff
printf("%f,\n", -girth); -(sin(M_PI/2) * y_diff))
float normal_x = (cos(M_PI/4) * x_diff
+sin(M_PI/4) * y_diff)
/ line_length * girth / 2; / line_length * girth / 2;
float normal_y = (-sin(M_PI/4) * x_diff
+cos(M_PI/4) * y_diff) float normal_y = (sin(M_PI/2) * x_diff
+(cos(M_PI/2) * y_diff))
/ line_length * girth / 2; / line_length * girth / 2;
printf("%f, ", normal_x);
printf("%f,\n", normal_y);
self = model_new(6); self = model_new(6);
@ -206,21 +212,39 @@ model_line(float x1, float y1, float x2, float y2, float girth) {
self->object[0] = x1 + normal_x; self->object[0] = x1 + normal_x;
self->object[1] = y1 + normal_y; self->object[1] = y1 + normal_y;
self->object[3] = 1;
printf("%f, ", self->object[0]);
printf("%f,\n", self->object[1]);
self->object[4] = x1 - normal_x; self->object[4] = x1 - normal_x;
self->object[5] = y1 - normal_y; self->object[5] = y1 - normal_y;
self->object[7] = 1;
printf("%f, ", self->object[4]);
printf("%f,\n", self->object[5]);
self->object[8] = x2 + normal_x; self->object[8] = x2 + normal_x;
self->object[9] = y2 + normal_y; self->object[9] = y2 + normal_y;
self->object[11] = 1;
printf("%f, ", self->object[8]);
printf("%f,\n", self->object[9]);
self->object[12] = x1 - normal_x; self->object[12] = x1 - normal_x;
self->object[13] = y1 - normal_y; self->object[13] = y1 - normal_y;
self->object[15] = 1;
printf("%f, ", self->object[12]);
printf("%f,\n", self->object[13]);
self->object[16] = x2 + normal_x; self->object[16] = x2 + normal_x;
self->object[17] = y2 + normal_y; self->object[17] = y2 + normal_y;
self->object[19] = 1;
printf("%f, ", self->object[16]);
printf("%f,\n", self->object[17]);
self->object[20] = x2 - normal_x; self->object[20] = x2 - normal_x;
self->object[21] = y2 - normal_y; self->object[21] = y2 - normal_y;
self->object[23] = 1;
printf("%f, ", self->object[20]);
printf("%f,\n", self->object[21]);
return self; return self;
} }