Beispiel #1
0
//  ---------- Create a bridge segment between current segment:side adjacent segment:side ----------
int CreateSloppyAdjacentJoint()
{
    int		adj_side;
    segment	*adj_sp;

    save_level("SLOPPY.LVL");

    if (med_find_closest_threshold_segment_side(Cursegp, Curside, &adj_sp, &adj_side, 20*F1_0)) {
        if (Cursegp->children[Curside] != adj_sp-Segments) {
            if (!med_form_joint(Cursegp,Curside,adj_sp,adj_side))
            {
                Update_flags |= UF_WORLD_CHANGED;
                mine_changed = 1;
                autosave_mine(mine_filename);
                diagnostic_message("Sloppy Joint segment formed.");
                strcpy(undo_status[Autosave_count], "Sloppy Joint segment undone.");
                warn_if_concave_segments();
            }
            else editor_status("Couldn't form sloppy joint.\n");
        } else
            editor_status("Attempted to form sloppy joint through connected side -- joint segment not formed (you bozo).");
    } else
        editor_status("Could not find close threshold segment -- joint segment not formed.");

    return 1;
}
Beispiel #2
0
//  -------------- Create all sloppy joints within CurrentGroup ------------------
int CreateSloppyAdjacentJointsGroup()
{
    int		adj_side;
    segment	*adj_sp;
    int		num_segs = GroupList[current_group].num_segments;
    short		*segs = GroupList[current_group].segments;
    segment	*segp;
    int		done_been_a_change = 0;
    int		segind, sidenum;

    for (segind=0; segind<num_segs; segind++) {
        segp = &Segments[segs[segind]];

        for (sidenum=0; sidenum < MAX_SIDES_PER_SEGMENT; sidenum++)
            if (!IS_CHILD(segp->children[sidenum]))
                if (med_find_closest_threshold_segment_side(segp, sidenum, &adj_sp, &adj_side, 5*F1_0)) {
                    if (adj_sp->group == segp->group) {
                        if (segp->children[sidenum] != adj_sp-Segments)
                            if (!med_form_joint(segp, sidenum, adj_sp,adj_side))
                                done_been_a_change = 1;
                    }
                }
    }

    if (done_been_a_change) {
        Update_flags |= UF_WORLD_CHANGED;
        mine_changed = 1;
        autosave_mine(mine_filename);
        diagnostic_message("Sloppy Joint segment formed.");
        strcpy(undo_status[Autosave_count], "Sloppy Joint segment undone.");
        warn_if_concave_segments();
    }

    return 1;
}
Beispiel #3
0
//  -------------- Create all sloppy joints within CurrentGroup ------------------
int CreateSloppyAdjacentJointsGroup()
{
	int		adj_side;
	int		done_been_a_change = 0;
	range_for(const auto &gs, GroupList[current_group].segments)
	{
		auto segp = vsegptridx(gs);

		for (int sidenum=0; sidenum < MAX_SIDES_PER_SEGMENT; sidenum++)
			if (!IS_CHILD(segp->children[sidenum]))
			{
				segptridx_t adj_sp = segment_none;
				if (med_find_closest_threshold_segment_side(segp, sidenum, adj_sp, &adj_side, 5*F1_0)) {
					if (adj_sp->group == segp->group) {
						if (segp->children[sidenum] != adj_sp)
							if (!med_form_joint(segp, sidenum, adj_sp,adj_side))
								done_been_a_change = 1;
					}
				}
			}
	}

	if (done_been_a_change) {
		Update_flags |= UF_WORLD_CHANGED;
		mine_changed = 1;
		autosave_mine(mine_filename);
		diagnostic_message("Sloppy Joint segment formed.");
		undo_status[Autosave_count] = "Sloppy Joint segment undone.";
		warn_if_concave_segments();
	}

	return 1;
}