mirror of
https://github.com/demostf/demo.js
synced 2026-06-04 00:54:14 +02:00
save viewangles
This commit is contained in:
parent
42fdddb4b0
commit
fe115329a7
7 changed files with 38 additions and 10 deletions
13
src/Data/Header.ts
Normal file
13
src/Data/Header.ts
Normal 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;
|
||||||
|
}
|
||||||
|
|
@ -8,4 +8,5 @@ export interface Player {
|
||||||
maxHealth: number;
|
maxHealth: number;
|
||||||
classId: number;
|
classId: number;
|
||||||
team: number;
|
team: number;
|
||||||
|
viewAngle: number;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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) {
|
||||||
|
|
|
||||||
|
|
@ -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) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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(),
|
||||||
|
|
|
||||||
|
|
@ -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;
|
||||||
|
|
|
||||||
|
|
@ -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';
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue