Files
@ r606:8ecd7d248197
Branch filter:
Location: cpp/openttd-patchpack/source/sprite.c - annotation
r606:8ecd7d248197
2.1 KiB
text/x-c
(svn r1030) Some toolbar icons are arranged differently:
- Landscaping buttons have to be accessed from the landscaping toolbar
- Landscaping toolbar can be opened from all other toolbars
- The order of buttons in the docks toolbar now matches the other toolbars
- Landscaping toolbar has new keyboard shortcuts
- Landscaping buttons have to be accessed from the landscaping toolbar
- Landscaping toolbar can be opened from all other toolbars
- The order of buttons in the docks toolbar now matches the other toolbars
- Landscaping toolbar has new keyboard shortcuts
r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r414:3caabc7691a6 r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f r445:8bbc3f73289f | #include "stdafx.h"
#include <stdarg.h>
#include "ttd.h"
#include "sprite.h"
struct SpriteGroup *EvalDeterministicSpriteGroup(struct DeterministicSpriteGroup *dsg, int value)
{
int i;
value >>= dsg->shift_num; // This should bring us to the byte range.
value &= dsg->and_mask;
if (dsg->operation != DSG_OP_NONE)
value += (signed char) dsg->add_val;
switch (dsg->operation) {
case DSG_OP_DIV:
value /= (signed char) dsg->divmod_val;
break;
case DSG_OP_MOD:
value %= (signed char) dsg->divmod_val;
break;
case DSG_OP_NONE:
break;
}
for (i = 0; i < dsg->num_ranges; i++) {
struct DeterministicSpriteGroupRange *range = &dsg->ranges[i];
if (range->low <= value && value <= range->high)
return &range->group;
}
return dsg->default_group;
}
int GetDeterministicSpriteValue(byte var)
{
switch (var) {
case 0x00:
return _date;
case 0x01:
return _cur_year;
case 0x02:
return _cur_month;
case 0x03:
return _opt.landscape;
case 0x09:
return _date_fract;
case 0x0A:
return _tick_counter;
case 0x0C:
/* If we got here, it means there was no callback or
* callbacks aren't supported on our callpath. */
return 0;
default:
return -1;
}
}
struct SpriteGroup *
EvalRandomizedSpriteGroup(struct RandomizedSpriteGroup *rsg, byte random_bits)
{
byte mask;
byte index;
/* Noone likes mangling with bits, but you don't get around it here.
* Sorry. --pasky */
// rsg->num_groups is always power of 2
mask = (rsg->num_groups - 1) << rsg->lowest_randbit;
index = (random_bits & mask) >> rsg->lowest_randbit;
assert(index < rsg->num_groups);
return &rsg->groups[index];
}
byte RandomizedSpriteGroupTriggeredBits(struct RandomizedSpriteGroup *rsg, byte triggers,
byte *waiting_triggers)
{
byte match = rsg->triggers & (*waiting_triggers | triggers);
bool res;
if (rsg->cmp_mode == RSG_CMP_ANY) {
res = (match != 0);
} else { /* RSG_CMP_ALL */
res = (match == rsg->triggers);
}
if (!res) {
*waiting_triggers |= triggers;
return 0;
}
*waiting_triggers &= ~match;
return (rsg->num_groups - 1) << rsg->lowest_randbit;
}
|