summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaweł Redman <pawel.redman@gmail.com>2016-04-06 20:42:46 +0200
committerPaweł Redman <pawel.redman@gmail.com>2016-04-06 20:42:46 +0200
commitcbdc7e6b9ca345c472fbe9ecef391f89d1aed4c7 (patch)
treeeeedbc6172326482779b0b6f8c9aea1314585e99
parentd2a866934a9cef292908c0456366cfbc59abea9d (diff)
Fix CSG.
-rw-r--r--src/console.c38
-rw-r--r--src/physics.c54
2 files changed, 53 insertions, 39 deletions
diff --git a/src/console.c b/src/console.c
index 9c7cebb..4edaf2e 100644
--- a/src/console.c
+++ b/src/console.c
@@ -163,7 +163,43 @@ char *cmd_csg_clear(char *arg)
char *cmd_csg_push(char *arg)
{
- itc_chan_push(&con_sim->ctl, PHY_CMD_CSG_PUSH, NULL);
+ char *shape_str;
+ phy_csg_shape shape;
+ phy_csg_step *step;
+
+ shape_str = con_var_get("csg_shape");
+
+ shape = CSG_SPHERE;
+
+ if (shape_str) {
+ if (!strcmp(shape_str, "cylinder-z"))
+ shape = CSG_CYLINDER_Z;
+ }
+
+ step = malloc(sizeof(phy_csg_step));
+ assert(step);
+
+ step->shape = shape;
+ step->value = con_var_get_float("csg_v");
+
+ switch (shape) {
+ case CSG_SPHERE:
+ step->x[0] = con_var_get_float("csg_x");
+ step->x[1] = con_var_get_float("csg_y");
+ step->x[2] = con_var_get_float("csg_z");
+ step->d[0] = con_var_get_float("csg_r");
+ break;
+
+ case CSG_CYLINDER_Z:
+ step->x[0] = con_var_get_float("csg_x");
+ step->x[1] = con_var_get_float("csg_y");
+ step->x[2] = con_var_get_float("csg_z");
+ step->d[0] = con_var_get_float("csg_r");
+ step->d[1] = con_var_get_float("csg_h");
+ break;
+ }
+
+ itc_chan_push(&con_sim->ctl, PHY_CMD_CSG_PUSH, step);
return "Wykonano operację na przenikalności elektrycznej";
}
diff --git a/src/physics.c b/src/physics.c
index 38f9c88..a6735a1 100644
--- a/src/physics.c
+++ b/src/physics.c
@@ -306,6 +306,8 @@ void phy_sim_destroy_fields(phy_sim *sim)
free(sim->aux);
sim->aux = NULL;
+ phy_sim_csg_clear(sim);
+
sim->valid = false;
}
@@ -544,46 +546,10 @@ void phy_sim_step(phy_sim *sim) {
SDL_mutexV(sim->rotate_lock);
}
-void phy_sim_csg_push(phy_sim *sim)
+void phy_sim_csg_push(phy_sim *sim, phy_csg_step *step)
{
- char *shape_str;
- phy_csg_shape shape;
- phy_csg_step *step;
-
- shape_str = con_var_get("csg_shape");
-
- shape = CSG_SPHERE;
-
- if (shape_str) {
- if (!strcmp(shape_str, "cylinder-z"))
- shape = CSG_CYLINDER_Z;
- }
-
- step = malloc(sizeof(phy_csg_step));
- assert(step);
-
step->next = sim->csg_stack;
sim->csg_stack = step;
-
- step->shape = shape;
- step->value = con_var_get_float("csg_v");
-
- switch (shape) {
- case CSG_SPHERE:
- step->x[0] = con_var_get_float("csg_x");
- step->x[1] = con_var_get_float("csg_y");
- step->x[2] = con_var_get_float("csg_z");
- step->d[0] = con_var_get_float("csg_r");
- break;
-
- case CSG_CYLINDER_Z:
- step->x[0] = con_var_get_float("csg_x");
- step->x[1] = con_var_get_float("csg_y");
- step->x[2] = con_var_get_float("csg_z");
- step->d[0] = con_var_get_float("csg_r");
- step->d[1] = con_var_get_float("csg_h");
- break;
- }
}
void phy_sim_csg_clear(phy_sim *sim)
@@ -594,6 +560,8 @@ void phy_sim_csg_clear(phy_sim *sim)
next = step->next;
free(step);
}
+
+ sim->csg_stack = NULL;
}
void phy_sim_debug(phy_sim *sim, size_t *coords)
@@ -601,6 +569,7 @@ void phy_sim_debug(phy_sim *sim, size_t *coords)
phy_field_info *fi = &sim->field_info;
phy_field_aux_point *aux;
float *E, *H, Emag, Hmag;
+ phy_csg_step *step;
aux = sim->aux + coords[2] * fi->zstr1 + coords[1] * fi->ystr1 +
coords[0] * fi->xstr1;
@@ -634,6 +603,15 @@ void phy_sim_debug(phy_sim *sim, size_t *coords)
aux->uec_H[1][0], aux->uec_H[1][1], aux->uec_H[1][2], aux->uec_H[1][3],
aux->uec_H[2][0], aux->uec_H[2][1], aux->uec_H[2][2], aux->uec_H[2][3]);
printf("Emag = %E, Hmag = %E, Z = %E\n", Emag, Hmag, Emag/Hmag);
+
+ printf("CSG:\n");
+ for (step = sim->csg_stack; step; step = step->next) {
+ printf("\ttype=%i, value=%f, x=[%f %f %f], d=[%f %f %f]\n",
+ step->shape, step->value,
+ step->x[0], step->x[1], step->x[2],
+ step->d[0], step->d[1], step->d[2]);
+ }
+
printf("=======================\n");
}
@@ -677,7 +655,7 @@ void phy_run_command(phy_sim *sim, int number, void *data)
break;
case PHY_CMD_CSG_PUSH:
- phy_sim_csg_push(sim);
+ phy_sim_csg_push(sim, data);
break;
case PHY_CMD_CSG_CLEAR: