Blame view

src/MSRegionSurveilance/helper.cpp 1.9 KB
8805b950   Liu Meng   物品遗留效果优化
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
  #include "svibe.h"
  #include <stdlib.h>
  
  void RegionSurveillance::RandInit()
  {
  	flag = 0;
  	i_rand = 0;
  
  	int tempX[8] = {2, 2, 1, 0, 0, 0, 1, 2};
  	int tempY[8] = {1, 0, 0, 0, 1, 2, 2, 2};
  	for (int tmpi = 0; tmpi < 8; tmpi++)
  	{
  		g_XNeighborTable[tmpi] = tempX[tmpi];
  		g_YNeighborTable[tmpi] = tempY[tmpi];
  	}
  
  	if (flag == 0)
  	{
  		int32_t i = 0;
  		g_randTable = (uint32_t *) malloc(0x10000 * sizeof(uint32_t));
  		
  		for (i = 0; i < 0x10000; i++)
  		{
  			g_randTable[i] = (uint32_t)(rand());
  		}		
  	}
  }
  
  uint32_t RegionSurveillance::GetRand()
  {
  	//static uint32_t i = 0;
  	//uint32_t i_rand = 0;
  	return g_randTable[0xFFFF & i_rand++];
  }
  
  void RegionSurveillance::FreeRand()
  {
  	free(g_randTable);
  }
  
  // static int32_t *g_XTable;
  // static int32_t *g_YTable;
  // static int32_t g_XNeighborTable[8] = {2, 2, 1, 0, 0, 0, 1, 2};
  // static int32_t g_YNeighborTable[8] = {1, 0, 0, 0, 1, 2, 2, 2};
  
  void RegionSurveillance::RandNeighborInit(int32_t width, int32_t height)
  {
  	//static int32_t flag = 0;
  	int32_t i;
  	if (flag == 0)
  	{
  		flag = 1;
  		g_XTable = (int32_t *)malloc((width + 2) * sizeof(int32_t));
  		for (i = 0; i < width; i++)
  		{
  			g_XTable[i + 1] = i;
  		}
  		g_XTable[0] = 0;
  		g_XTable[width + 1] = width - 1;
  
  		g_YTable = (int32_t *)malloc((height + 2) * sizeof(int32_t));
  		for (i = 0; i < height; i++)
  		{
  			g_YTable[i + 1] = i;
  		}
  		g_XTable[0] = 0;                                              //1
  		g_XTable[height + 1] = height - 1;
  	}
  }
  
  void RegionSurveillance::GetRandNeighborXY(int32_t x, int32_t y, int32_t *_x, int32_t *_y)
  {
  	uint32_t r = GetRand() & 0x07;
  	*_x = g_XTable[x + g_XNeighborTable[r]];
  	*_y = g_XTable[y + g_YNeighborTable[r]];
  }
  
  void RegionSurveillance::GetNeighborXY(int32_t x, int32_t y, int32_t *_x, int32_t *_y, int32_t flag)
  {
  	*_x = g_XTable[x + g_XNeighborTable[flag]];
  	*_y = g_XTable[y + g_YNeighborTable[flag]];
  }
  
  void RegionSurveillance::FreeRandNeighbor()
  {
  	free(g_XTable);
  	free(g_YTable);
  }