]> icculus.org git repositories - btb/d2x.git/blob - main/editor/medsel.c
use the orientation parameter of g3_draw_bitmap
[btb/d2x.git] / main / editor / medsel.c
1 /*
2 THE COMPUTER CODE CONTAINED HEREIN IS THE SOLE PROPERTY OF PARALLAX
3 SOFTWARE CORPORATION ("PARALLAX").  PARALLAX, IN DISTRIBUTING THE CODE TO
4 END-USERS, AND SUBJECT TO ALL OF THE TERMS AND CONDITIONS HEREIN, GRANTS A
5 ROYALTY-FREE, PERPETUAL LICENSE TO SUCH END-USERS FOR USE BY SUCH END-USERS
6 IN USING, DISPLAYING,  AND CREATING DERIVATIVE WORKS THEREOF, SO LONG AS
7 SUCH USE, DISPLAY OR CREATION IS FOR NON-COMMERCIAL, ROYALTY OR REVENUE
8 FREE PURPOSES.  IN NO EVENT SHALL THE END-USER USE THE COMPUTER CODE
9 CONTAINED HEREIN FOR REVENUE-BEARING PURPOSES.  THE END-USER UNDERSTANDS
10 AND AGREES TO THE TERMS HEREIN AND ACCEPTS THE SAME BY USE OF THIS FILE.
11 COPYRIGHT 1993-1998 PARALLAX SOFTWARE CORPORATION.  ALL RIGHTS RESERVED.
12 */
13
14 /*
15  *
16  * Routines stripped from med.c for segment selection
17  *
18  */
19
20 #ifdef HAVE_CONFIG_H
21 #include "conf.h"
22 #endif
23
24 #include <stdio.h>
25 #include <stdlib.h>
26 #include <stdarg.h>
27 #include <string.h>
28 #ifdef __MSDOS__
29 #include <process.h>
30 #endif
31
32 #include "gr.h"
33 #include "ui.h"
34 #include "key.h"
35 #include "mono.h"
36 #include "dxxerror.h"
37 #include "u_mem.h"
38 #include "inferno.h"
39 #include "editor.h"
40
41
42 typedef struct sort_element {
43         short segnum;
44         fix dist;
45 } sort_element;
46
47 //compare the distance of two segments.  slow, since it computes the
48 //distance each time
49 int segdist_cmp(sort_element *s0,sort_element *s1)
50 {
51         return (s0->dist==s1->dist)?0:((s0->dist<s1->dist)?-1:1);
52
53 }
54
55
56 //find the distance between a segment and a point
57 fix compute_dist(segment *seg,vms_vector *pos)
58 {
59         vms_vector delta;
60
61         compute_segment_center(&delta,seg);
62         vm_vec_sub2(&delta,pos);
63
64         return vm_vec_mag(&delta);
65
66 }
67
68 //sort a list of segments, in order of closeness to pos
69 void sort_seg_list(int n_segs,short *segnumlist,vms_vector *pos)
70 {
71         int i;
72         sort_element *sortlist;
73
74         sortlist = d_calloc(n_segs, sizeof(*sortlist));
75
76         for (i=0;i<n_segs;i++) {
77                 sortlist[i].segnum = segnumlist[i];
78                 sortlist[i].dist = compute_dist(&Segments[segnumlist[i]],pos);
79         }
80
81         qsort(sortlist,n_segs,sizeof(*sortlist),(int (*)(const void *, const void *))segdist_cmp);
82
83         for (i=0;i<n_segs;i++)
84                 segnumlist[i] = sortlist[i].segnum;
85
86         d_free(sortlist);
87 }
88
89 int SortSelectedList(void)
90 {
91         sort_seg_list(N_selected_segs,Selected_segs,&ConsoleObject->pos);
92         editor_status("%i element selected list sorted.",N_selected_segs);
93
94         return 1;
95 }
96
97 int SelectNextFoundSeg(void)
98 {
99         if (++Found_seg_index >= N_found_segs)
100                 Found_seg_index = 0;
101
102         Cursegp = &Segments[Found_segs[Found_seg_index]];
103         med_create_new_segment_from_cursegp();
104
105         Update_flags |= UF_WORLD_CHANGED;
106
107         if (Lock_view_to_cursegp)
108                 set_view_target_from_segment(Cursegp);
109
110         editor_status("Curseg assigned to next found segment.");
111
112         return 1;
113 }
114
115 int SelectPreviousFoundSeg(void)
116 {
117         if (Found_seg_index > 0)
118                 Found_seg_index--;
119         else
120                 Found_seg_index = N_found_segs-1;
121
122         Cursegp = &Segments[Found_segs[Found_seg_index]];
123         med_create_new_segment_from_cursegp();
124
125         Update_flags |= UF_WORLD_CHANGED;
126
127         if (Lock_view_to_cursegp)
128                 set_view_target_from_segment(Cursegp);
129
130         editor_status("Curseg assigned to previous found segment.");
131
132         return 1;
133 }
134