dxx-rebirth/similar/editor/medsel.cpp

129 lines
3 KiB
C++
Raw Normal View History

2006-03-20 16:43:15 +00:00
/*
THE COMPUTER CODE CONTAINED HEREIN IS THE SOLE PROPERTY OF PARALLAX
SOFTWARE CORPORATION ("PARALLAX"). PARALLAX, IN DISTRIBUTING THE CODE TO
END-USERS, AND SUBJECT TO ALL OF THE TERMS AND CONDITIONS HEREIN, GRANTS A
ROYALTY-FREE, PERPETUAL LICENSE TO SUCH END-USERS FOR USE BY SUCH END-USERS
IN USING, DISPLAYING, AND CREATING DERIVATIVE WORKS THEREOF, SO LONG AS
SUCH USE, DISPLAY OR CREATION IS FOR NON-COMMERCIAL, ROYALTY OR REVENUE
FREE PURPOSES. IN NO EVENT SHALL THE END-USER USE THE COMPUTER CODE
CONTAINED HEREIN FOR REVENUE-BEARING PURPOSES. THE END-USER UNDERSTANDS
AND AGREES TO THE TERMS HEREIN AND ACCEPTS THE SAME BY USE OF THIS FILE.
2006-03-20 16:43:15 +00:00
COPYRIGHT 1993-1998 PARALLAX SOFTWARE CORPORATION. ALL RIGHTS RESERVED.
*/
2006-03-20 16:43:15 +00:00
/*
*
* Routines stripped from med.c for segment selection
2006-03-20 16:43:15 +00:00
*
*/
#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>
#include <string.h>
#include "gr.h"
#include "ui.h"
#include "key.h"
#include "dxxerror.h"
2006-03-20 16:43:15 +00:00
#include "u_mem.h"
#include "inferno.h"
#include "editor.h"
2013-03-16 03:10:55 +00:00
#include "editor/esegment.h"
2013-09-24 01:59:09 +00:00
#include "editor/medmisc.h"
2006-03-20 16:43:15 +00:00
#include "segment.h"
#include "object.h"
#include "medsel.h"
#include "kdefs.h"
2006-03-20 16:43:15 +00:00
typedef struct sort_element {
short segnum;
fix dist;
} sort_element;
//compare the distance of two segments. slow, since it computes the
//distance each time
2013-10-27 22:00:14 +00:00
static int segdist_cmp(sort_element *s0,sort_element *s1)
2006-03-20 16:43:15 +00:00
{
return (s0->dist==s1->dist)?0:((s0->dist<s1->dist)?-1:1);
}
//find the distance between a segment and a point
2013-10-27 22:00:14 +00:00
static fix compute_dist(segment *seg,vms_vector *pos)
2006-03-20 16:43:15 +00:00
{
vms_vector delta;
compute_segment_center(&delta,seg);
vm_vec_sub2(&delta,pos);
return vm_vec_mag(&delta);
}
//sort a list of segments, in order of closeness to pos
void sort_seg_list(int n_segs,short *segnumlist,vms_vector *pos)
{
int i;
RAIIdmem<sort_element> sortlist;
2006-03-20 16:43:15 +00:00
CALLOC(sortlist, sort_element, n_segs);
2006-03-20 16:43:15 +00:00
for (i=0;i<n_segs;i++) {
sortlist[i].segnum = segnumlist[i];
sortlist[i].dist = compute_dist(&Segments[segnumlist[i]],pos);
}
qsort(sortlist,n_segs,sizeof(*sortlist),(int (*)(const void *, const void *))segdist_cmp);
for (i=0;i<n_segs;i++)
segnumlist[i] = sortlist[i].segnum;
}
int SortSelectedList(void)
{
sort_seg_list(N_selected_segs,Selected_segs,&ConsoleObject->pos);
editor_status_fmt("%i element selected list sorted.",N_selected_segs);
2006-03-20 16:43:15 +00:00
return 1;
}
int SelectNextFoundSeg(void)
{
if (++Found_seg_index >= N_found_segs)
Found_seg_index = 0;
Cursegp = &Segments[Found_segs[Found_seg_index]];
med_create_new_segment_from_cursegp();
Update_flags |= UF_WORLD_CHANGED;
if (Lock_view_to_cursegp)
set_view_target_from_segment(Cursegp);
editor_status("Curseg assigned to next found segment.");
return 1;
}
int SelectPreviousFoundSeg(void)
{
if (Found_seg_index > 0)
Found_seg_index--;
else
Found_seg_index = N_found_segs-1;
Cursegp = &Segments[Found_segs[Found_seg_index]];
med_create_new_segment_from_cursegp();
Update_flags |= UF_WORLD_CHANGED;
if (Lock_view_to_cursegp)
set_view_target_from_segment(Cursegp);
editor_status("Curseg assigned to previous found segment.");
return 1;
}