1
0
Fork 0
mirror of https://github.com/demostf/demo.js synced 2026-06-04 00:54:14 +02:00

save viewangles

This commit is contained in:
Robin Appelman 2017-02-21 19:44:30 +01:00
commit fe115329a7
7 changed files with 38 additions and 10 deletions

13
src/Data/Header.ts Normal file
View file

@ -0,0 +1,13 @@
export interface Header {
type: string;
version: number;
protocol: number;
server: string;
nick: string;
map: string;
game: string;
duration: number;
ticks: number;
frames: number;
sigon: number;
}

View file

@ -8,4 +8,5 @@ export interface Player {
maxHealth: number; maxHealth: number;
classId: number; classId: number;
team: number; team: number;
viewAngle: number;
} }

View file

@ -5,13 +5,17 @@ import {StreamParser} from './StreamParser';
export class Demo { export class Demo {
stream: BitStream; stream: BitStream;
parser: Parser|null;
constructor(arrayBuffer: ArrayBuffer) { constructor(arrayBuffer: ArrayBuffer) {
this.stream = new BitStream(arrayBuffer); this.stream = new BitStream(arrayBuffer);
} }
getParser() { getParser() {
return new Parser(this.stream); if (!this.parser) {
this.parser = new Parser(this.stream);
}
return this.parser;
} }
static fromNodeBuffer(nodeBuffer) { static fromNodeBuffer(nodeBuffer) {

View file

@ -37,7 +37,8 @@ function handleEntity(entity: PacketEntity, match: Match) {
maxHealth: 0, maxHealth: 0,
health: 0, health: 0,
classId: 0, classId: 0,
team: 0 team: 0,
viewAngle: 0
}; };
if (!match.playerMap[entity.entityIndex]) { if (!match.playerMap[entity.entityIndex]) {
match.playerMap[entity.entityIndex] = player; match.playerMap[entity.entityIndex] = player;
@ -46,7 +47,6 @@ function handleEntity(entity: PacketEntity, match: Match) {
for (const prop of entity.props) { for (const prop of entity.props) {
const propName = prop.definition.ownerTableName + '.' + prop.definition.name; const propName = prop.definition.ownerTableName + '.' + prop.definition.name;
// console.log(propName, prop.value);
switch (propName) { switch (propName) {
case 'DT_BasePlayer.m_iHealth': case 'DT_BasePlayer.m_iHealth':
player.health = <number>prop.value; player.health = <number>prop.value;
@ -68,8 +68,15 @@ function handleEntity(entity: PacketEntity, match: Match) {
case 'DT_TFNonLocalPlayerExclusive.m_vecOrigin[2]': case 'DT_TFNonLocalPlayerExclusive.m_vecOrigin[2]':
player.position.z = <number>prop.value; player.position.z = <number>prop.value;
break; break;
case 'DT_TFNonLocalPlayerExclusive.m_angEyeAngles[1]':
player.viewAngle = <number>prop.value;
break;
case 'DT_TFLocalPlayerExclusive.m_angEyeAngles[1]':
player.viewAngle = <number>prop.value;
break;
} }
} }
} catch (e) { } catch (e) {
} }

View file

@ -7,6 +7,7 @@ import {BitStream} from 'bit-buffer';
import {EventEmitter} from 'events'; import {EventEmitter} from 'events';
import {Match} from './Data/Match'; import {Match} from './Data/Match';
import {Parser as MessageParser} from './Parser/Message/Parser'; import {Parser as MessageParser} from './Parser/Message/Parser';
import {Header} from "./Data/Header";
export class Parser extends EventEmitter { export class Parser extends EventEmitter {
stream: BitStream; stream: BitStream;
@ -23,7 +24,7 @@ export class Parser extends EventEmitter {
return this.parseHeader(this.stream); return this.parseHeader(this.stream);
} }
parseHeader(stream) { parseHeader(stream): Header {
return { return {
'type': stream.readASCIIString(8), 'type': stream.readASCIIString(8),
'version': stream.readInt32(), 'version': stream.readInt32(),
@ -87,7 +88,7 @@ export class Parser extends EventEmitter {
} }
} }
readMessage(stream:BitStream, match:Match): MessageParser|boolean { readMessage(stream: BitStream, match: Match): MessageParser|boolean {
if (stream.bitsLeft < 8) { if (stream.bitsLeft < 8) {
return false; return false;
} }

View file

@ -38,10 +38,10 @@ function readEnterPVS(stream: BitStream, entityId: number, match: Match): Packet
staticBaseLine.index = 0; staticBaseLine.index = 0;
applyEntityUpdate(entity, sendTable, staticBaseLine); applyEntityUpdate(entity, sendTable, staticBaseLine);
match.baseLineCache[serverClass.id] = entity.clone(); match.baseLineCache[serverClass.id] = entity.clone();
if (staticBaseLine.bitsLeft > 7) { // if (staticBaseLine.bitsLeft > 7) {
// console.log(staticBaseLine.length, staticBaseLine.index); // console.log(staticBaseLine.length, staticBaseLine.index);
throw new Error('Unexpected data left at the end of staticBaseline, ' + staticBaseLine.bitsLeft + ' bits left'); // throw new Error('Unexpected data left at the end of staticBaseline, ' + staticBaseLine.bitsLeft + ' bits left');
} // }
} }
entity.serialNumber = serial; entity.serialNumber = serial;
return entity; return entity;

View file

@ -11,3 +11,5 @@ export {SendProp} from './Data/SendProp';
export {Vector} from './Data/Vector'; export {Vector} from './Data/Vector';
export {World} from './Data/World'; export {World} from './Data/World';
export {UserInfo} from './Data/UserInfo'; export {UserInfo} from './Data/UserInfo';
export {Header} from './Data/Header';
export {Packet} from './Data/Packet';