mirror of
https://github.com/mapbase-source/source-sdk-2013.git
synced 2025-01-26 13:47:56 +03:00
Merge branch 'feature/mp/develop' into feature/mp/secobmod-test-1
# Conflicts: # mp/src/game/server/ai_basenpc.cpp # mp/src/game/shared/hl2mp/weapon_ar2.cpp # mp/src/game/shared/hl2mp/weapon_ar2.h # mp/src/game/shared/hl2mp/weapon_slam.cpp # mp/src/game/shared/hl2mp/weapon_stunstick.cpp
This commit is contained in:
commit
f9f476efe5
25
.github/CONTRIBUTING.md
vendored
25
.github/CONTRIBUTING.md
vendored
@ -23,17 +23,40 @@ All contributions must follow the following rules:
|
|||||||
is usually not fit for Mapbase.
|
is usually not fit for Mapbase.
|
||||||
|
|
||||||
* All content in a contribution must be either already legally open-source or done with the
|
* All content in a contribution must be either already legally open-source or done with the
|
||||||
full permission of the content's original creator(s).
|
full permission of the content's original creator(s). If a license is involved, the contributor
|
||||||
|
should ensure Mapbase conforms to its terms.
|
||||||
|
* **NOTE:** Due to concerns with mods which do not wish to be open-source, content using GPL licenses (or any
|
||||||
|
license with similar open-source requirements) are currently not allowed to be distributed with Mapbase.
|
||||||
|
Contributions which can draw from them without actually distributing the licensed content may be excepted
|
||||||
|
from this rule.
|
||||||
|
|
||||||
* Contributions must not break existing maps/content or interfere with them in a negative or non-objective way.
|
* Contributions must not break existing maps/content or interfere with them in a negative or non-objective way.
|
||||||
|
|
||||||
* Code contributions are not obliged to follow Mapbase's preprocessor conventions (e.g. #ifdef MAPBASE),
|
* Code contributions are not obliged to follow Mapbase's preprocessor conventions (e.g. #ifdef MAPBASE),
|
||||||
although following them is usually acceptable.
|
although following them is usually acceptable.
|
||||||
|
|
||||||
|
* Code contributions which modify or add onto existing code should generally match its syntax and shouldn't
|
||||||
|
change the spacing unless necessary.
|
||||||
|
|
||||||
* If you are contributing a file you created yourself specifically for Mapbase, you are required to
|
* If you are contributing a file you created yourself specifically for Mapbase, you are required to
|
||||||
use the custom "Mapbase - Source 2013" header used in other Mapbase files as of Mapbase v5.0.
|
use the custom "Mapbase - Source 2013" header used in other Mapbase files as of Mapbase v5.0.
|
||||||
You are encouraged to append an "Author(s)" part to that header in your file in order to clarify who wrote it.
|
You are encouraged to append an "Author(s)" part to that header in your file in order to clarify who wrote it.
|
||||||
|
|
||||||
|
* Do not modify the README to add attribution for your contribution. That is handled by Mapbase's maintainers.
|
||||||
|
|
||||||
|
Contributions which do not follow these guidelines cannot be accepted into Mapbase. Attempting to contribute content
|
||||||
|
which seriously violates the rules above can lead to being blocked from contributing, especially if done repeatedly.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
Mapbase uses GitHub Actions to help manage issues and pull requests. Some of these workflows build the code of incoming
|
||||||
|
contributions to make sure they compile properly. The code is compiled separately for Visual Studio 2022 and GCC/G++ 9 (Linux)
|
||||||
|
and on both Debug and Release configurations.
|
||||||
|
|
||||||
|
If these workflows fail, don't freak out! Accidents can happen frequently due to compiler syntax differences and conflicts
|
||||||
|
from other contributions. You can look at a failed workflow's log by clicking "Details", which will include the build's output
|
||||||
|
in the "Build" step(s). Any errors must be resolved by you and/or by code reviewers before a pull request can be merged.
|
||||||
|
|
||||||
If your contribution is accepted, you may be listed in Mapbase's credits and the README's external content list:
|
If your contribution is accepted, you may be listed in Mapbase's credits and the README's external content list:
|
||||||
https://github.com/mapbase-source/source-sdk-2013/wiki/Mapbase-Credits#Contributors
|
https://github.com/mapbase-source/source-sdk-2013/wiki/Mapbase-Credits#Contributors
|
||||||
https://github.com/mapbase-source/source-sdk-2013/blob/master/README
|
https://github.com/mapbase-source/source-sdk-2013/blob/master/README
|
||||||
|
35
.github/labeler.yml
vendored
Normal file
35
.github/labeler.yml
vendored
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
#
|
||||||
|
# MAPBASE REPO AUTOMATION
|
||||||
|
#
|
||||||
|
# Automatically labels pull requests according to changed file paths.
|
||||||
|
# See mapbase_pr.yml for more information.
|
||||||
|
#
|
||||||
|
Repo:
|
||||||
|
- '*'
|
||||||
|
- '.github/**'
|
||||||
|
|
||||||
|
Project Generation:
|
||||||
|
- '**/src/vpc_scripts/**'
|
||||||
|
- '**/src/devtools/**'
|
||||||
|
- '**/src/create*'
|
||||||
|
|
||||||
|
Entities:
|
||||||
|
- '**/src/game/**/**logic**'
|
||||||
|
- '**/src/game/**/**point**'
|
||||||
|
|
||||||
|
Shaders:
|
||||||
|
- '**/src/materialsystem/**'
|
||||||
|
|
||||||
|
VScript:
|
||||||
|
- '**vscript**'
|
||||||
|
|
||||||
|
Tools:
|
||||||
|
- '**utils**'
|
||||||
|
|
||||||
|
NPCs:
|
||||||
|
- '**npc_**'
|
||||||
|
- '**ai_**'
|
||||||
|
|
||||||
|
VGUI:
|
||||||
|
- '**hud_**'
|
||||||
|
- '**vgui_**'
|
70
.github/workflows/mapbase_build-base-dispatch.yml
vendored
Normal file
70
.github/workflows/mapbase_build-base-dispatch.yml
vendored
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
#
|
||||||
|
# MAPBASE SOURCE 2013 CI
|
||||||
|
#
|
||||||
|
# This can be used to manually build the codebase.
|
||||||
|
#
|
||||||
|
# See mapbase_build-base.yml for more information on how this works.
|
||||||
|
|
||||||
|
name: Build Projects (Manual)
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
inputs:
|
||||||
|
configuration:
|
||||||
|
description: 'Which configuration to build with'
|
||||||
|
default: 'Release'
|
||||||
|
required: true
|
||||||
|
type: choice
|
||||||
|
options:
|
||||||
|
- Release
|
||||||
|
- Debug
|
||||||
|
branch:
|
||||||
|
description: 'Which Source 2013 engine branch to compile for'
|
||||||
|
default: 'sp'
|
||||||
|
required: true
|
||||||
|
type: choice
|
||||||
|
options:
|
||||||
|
- sp
|
||||||
|
- mp
|
||||||
|
game:
|
||||||
|
description: 'Name of the game to build (if relevant)'
|
||||||
|
default: 'episodic'
|
||||||
|
required: false
|
||||||
|
type: choice
|
||||||
|
options:
|
||||||
|
- episodic
|
||||||
|
- hl2
|
||||||
|
project-group:
|
||||||
|
description: 'Which group of projects to compile'
|
||||||
|
required: true
|
||||||
|
type: choice
|
||||||
|
options:
|
||||||
|
- all
|
||||||
|
- game
|
||||||
|
- shaders
|
||||||
|
- maptools
|
||||||
|
solution-name:
|
||||||
|
description: 'Name of the solution/makefile'
|
||||||
|
required: true
|
||||||
|
type: choice
|
||||||
|
options:
|
||||||
|
- everything
|
||||||
|
- games
|
||||||
|
- shaders
|
||||||
|
- maptools
|
||||||
|
build-on-linux:
|
||||||
|
description: 'Build on Ubuntu/Linux?'
|
||||||
|
default: true
|
||||||
|
required: false
|
||||||
|
type: boolean
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build_manual:
|
||||||
|
uses: ./.github/workflows/mapbase_build-base.yml
|
||||||
|
with:
|
||||||
|
configuration: '${{ github.event.inputs.configuration }}'
|
||||||
|
branch: '${{ github.event.inputs.branch }}'
|
||||||
|
game: '${{ github.event.inputs.game }}'
|
||||||
|
project-group: '${{ github.event.inputs.project-group }}'
|
||||||
|
solution-name: '${{ github.event.inputs.solution-name }}'
|
||||||
|
build-on-linux: "${{ github.event.inputs.build-on-linux == 'true' }}"
|
269
.github/workflows/mapbase_build-base.yml
vendored
Normal file
269
.github/workflows/mapbase_build-base.yml
vendored
Normal file
@ -0,0 +1,269 @@
|
|||||||
|
#
|
||||||
|
# MAPBASE SOURCE 2013 CI
|
||||||
|
#
|
||||||
|
# This workflow script automatically builds the Source SDK 2013 codebase on Windows and Linux using GitHub Actions.
|
||||||
|
#
|
||||||
|
# This is useful in a number of ways:
|
||||||
|
#
|
||||||
|
# 1. It ensures pull requests compile correctly on multiple platforms and provides binaries that can be used to test them.
|
||||||
|
# 2. It can be used to compile code for releases without having to pull and prepare a local development environment.
|
||||||
|
# 3. It opens potential for scripts that can employ more principles of CI/CD. (e.g. automatically publishing a release)
|
||||||
|
#
|
||||||
|
# This is based on a workflow originally created by z33ky.
|
||||||
|
|
||||||
|
name: Build Projects
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_call:
|
||||||
|
inputs:
|
||||||
|
configuration:
|
||||||
|
description: 'Which configuration to build with'
|
||||||
|
default: 'Release'
|
||||||
|
required: true
|
||||||
|
type: string
|
||||||
|
branch:
|
||||||
|
description: 'Which Source 2013 engine branch to compile for'
|
||||||
|
default: 'sp'
|
||||||
|
required: true
|
||||||
|
type: string
|
||||||
|
game:
|
||||||
|
description: 'The name of the game to build (if relevant)'
|
||||||
|
default: 'episodic'
|
||||||
|
required: false
|
||||||
|
type: string
|
||||||
|
project-group:
|
||||||
|
description: 'Which group of projects to compile'
|
||||||
|
required: true
|
||||||
|
type: string
|
||||||
|
solution-name:
|
||||||
|
description: 'The name of the solution/makefile'
|
||||||
|
required: true
|
||||||
|
type: string
|
||||||
|
build-on-linux:
|
||||||
|
description: 'Build on Ubuntu/Linux?'
|
||||||
|
default: true
|
||||||
|
required: false
|
||||||
|
type: boolean
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build_windows:
|
||||||
|
name: Windows (VS2022)
|
||||||
|
runs-on: windows-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Add MSBuild to PATH
|
||||||
|
uses: microsoft/setup-msbuild@v1.1
|
||||||
|
|
||||||
|
- name: Enable VS2022
|
||||||
|
working-directory: '${{inputs.branch}}/src/vpc_scripts'
|
||||||
|
shell: bash
|
||||||
|
run: sed -i 's/^\($Conditional[ ]\+VS2022[ ]\+\).*/\1"1"/' newer_vs_toolsets.vpc
|
||||||
|
|
||||||
|
- name: Pick game
|
||||||
|
if: inputs.project-group == 'game' || inputs.project-group == 'shaders'
|
||||||
|
working-directory: '${{inputs.branch}}/src'
|
||||||
|
shell: bash
|
||||||
|
run: sed -i 's/\/hl2 \/episodic/\/${{inputs.game}}/' create${{inputs.project-group}}projects.bat
|
||||||
|
|
||||||
|
- name: Create project files
|
||||||
|
working-directory: '${{inputs.branch}}/src'
|
||||||
|
shell: cmd
|
||||||
|
# https://github.com/ValveSoftware/source-sdk-2013/issues/72
|
||||||
|
run: |
|
||||||
|
reg add "HKLM\SOFTWARE\WOW6432Node\Microsoft\VisualStudio\10.0\Projects\{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}" /v DefaultProjectExtension /t REG_SZ /d vcproj /f
|
||||||
|
create${{inputs.project-group}}projects.bat
|
||||||
|
|
||||||
|
# --------------------------------------------------------------------
|
||||||
|
|
||||||
|
# "I'm invoking msbuild for each project individually, which looks a bit odd considering there is a solution file which should be able to invoke the builds in their proper order automatically, but passing the solution to msbuild doesn't seem to work."
|
||||||
|
# https://github.com/mapbase-source/source-sdk-2013/pull/162
|
||||||
|
|
||||||
|
- name: Build mathlib
|
||||||
|
#if: steps.filter.outputs.game == 'true'
|
||||||
|
working-directory: '${{inputs.branch}}/src'
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} mathlib\mathlib.vcxproj
|
||||||
|
|
||||||
|
- name: Build Base Libraries
|
||||||
|
if: inputs.project-group == 'all' || inputs.project-group == 'game' || inputs.project-group == 'maptools'
|
||||||
|
working-directory: '${{inputs.branch}}/src'
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} raytrace\raytrace.vcxproj
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} tier1\tier1.vcxproj
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} vgui2\vgui_controls\vgui_controls.vcxproj
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} vscript\vscript.vcxproj
|
||||||
|
|
||||||
|
- name: Build Map Tools
|
||||||
|
if: inputs.project-group == 'all' || inputs.project-group == 'maptools'
|
||||||
|
working-directory: '${{inputs.branch}}/src'
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} fgdlib\fgdlib.vcxproj
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} utils\vbsp\vbsp.vcxproj
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} utils\vvis\vvis_dll.vcxproj
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} utils\vvis_launcher\vvis_launcher.vcxproj
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} utils\vrad\vrad_dll.vcxproj
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} utils\vrad_launcher\vrad_launcher.vcxproj
|
||||||
|
|
||||||
|
- name: Build Shaders
|
||||||
|
if: inputs.project-group == 'shaders'
|
||||||
|
working-directory: '${{inputs.branch}}/src'
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} materialsystem\stdshaders\game_shader_dx9_${{inputs.game}}.vcxproj
|
||||||
|
|
||||||
|
- name: Build Game
|
||||||
|
if: inputs.project-group == 'game'
|
||||||
|
working-directory: '${{inputs.branch}}/src'
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} responserules\runtime\responserules.vcxproj
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} game\client\client_${{inputs.game}}.vcxproj
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} game\server\server_${{inputs.game}}.vcxproj
|
||||||
|
|
||||||
|
# TODO: Hook to game naming?
|
||||||
|
- name: Build everything
|
||||||
|
if: inputs.project-group == 'all'
|
||||||
|
working-directory: '${{inputs.branch}}/src'
|
||||||
|
shell: cmd
|
||||||
|
run: |
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} responserules\runtime\responserules.vcxproj
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} materialsystem\stdshaders\game_shader_dx9_episodic.vcxproj
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} materialsystem\stdshaders\game_shader_dx9_hl2.vcxproj
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} game\client\client_episodic.vcxproj
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} game\client\client_hl2.vcxproj
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} game\server\server_episodic.vcxproj
|
||||||
|
msbuild -m -p:Configuration=${{inputs.configuration}} game\server\server_hl2.vcxproj
|
||||||
|
|
||||||
|
# --------------------------------------------------------------------
|
||||||
|
|
||||||
|
- name: Publish Windows game DLLs
|
||||||
|
if: inputs.project-group == 'game'
|
||||||
|
uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: 'Windows Game DLLs (server & client.dll) [${{ inputs.configuration }}]'
|
||||||
|
path: |
|
||||||
|
${{inputs.branch}}/game/mod_${{inputs.game}}/bin/client.dll
|
||||||
|
${{inputs.branch}}/game/mod_${{inputs.game}}/bin/server.dll
|
||||||
|
if-no-files-found: error
|
||||||
|
|
||||||
|
- name: Publish Windows shader DLL
|
||||||
|
if: inputs.project-group == 'shaders'
|
||||||
|
uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: 'Windows Shader DLL (game_shader_dx9.dll) [${{ inputs.configuration }}]'
|
||||||
|
path: |
|
||||||
|
${{inputs.branch}}/game/mod_${{inputs.game}}/bin/game_shader_dx9.dll
|
||||||
|
if-no-files-found: error
|
||||||
|
|
||||||
|
- name: Publish Windows map tools
|
||||||
|
if: inputs.project-group == 'maptools'
|
||||||
|
uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: 'Windows Map Tools [${{ inputs.configuration }}]'
|
||||||
|
path: |
|
||||||
|
${{inputs.branch}}/game/bin/vbsp.exe
|
||||||
|
${{inputs.branch}}/game/bin/vvis.exe
|
||||||
|
${{inputs.branch}}/game/bin/vvis_dll.dll
|
||||||
|
${{inputs.branch}}/game/bin/vrad.exe
|
||||||
|
${{inputs.branch}}/game/bin/vrad_dll.dll
|
||||||
|
if-no-files-found: error
|
||||||
|
|
||||||
|
- name: Publish everything (Windows)
|
||||||
|
if: inputs.project-group == 'all'
|
||||||
|
uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: 'Everything (Windows) [${{ inputs.configuration }}]'
|
||||||
|
path: |
|
||||||
|
${{inputs.branch}}/game/bin
|
||||||
|
${{inputs.branch}}/game/mod_*/bin
|
||||||
|
if-no-files-found: error
|
||||||
|
|
||||||
|
build_ubuntu:
|
||||||
|
if: inputs.build-on-linux == true && inputs.project-group != 'maptools' # No Linux map tools for now
|
||||||
|
name: Ubuntu (GCC/G++)
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
env:
|
||||||
|
config: ${{ inputs.configuration }}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Install GCC/G++ multilib
|
||||||
|
run: sudo apt-get install gcc-multilib g++-multilib
|
||||||
|
|
||||||
|
- name: Pick game
|
||||||
|
if: inputs.project-group == 'game' || inputs.project-group == 'shaders'
|
||||||
|
working-directory: '${{inputs.branch}}/src'
|
||||||
|
shell: bash
|
||||||
|
run: sed -i 's/\/hl2 \/episodic/\/${{inputs.game}}/' create${{inputs.project-group}}projects
|
||||||
|
|
||||||
|
- name: Set configuration
|
||||||
|
working-directory: '${{inputs.branch}}/src'
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
config=${{inputs.configuration}}
|
||||||
|
export CFG=${config,,}
|
||||||
|
echo "config=${CFG}" >> $GITHUB_ENV
|
||||||
|
|
||||||
|
- name: Create project files
|
||||||
|
working-directory: '${{inputs.branch}}/src'
|
||||||
|
run: ./create${{inputs.project-group}}projects
|
||||||
|
|
||||||
|
# --------------------------------------------------------------------
|
||||||
|
|
||||||
|
- name: Build
|
||||||
|
working-directory: '${{inputs.branch}}/src'
|
||||||
|
run: make CFG=${{env.config}} -f ${{inputs.solution-name}}.mak
|
||||||
|
|
||||||
|
# --------------------------------------------------------------------
|
||||||
|
|
||||||
|
- name: Publish Linux game SOs
|
||||||
|
if: inputs.project-group == 'game'
|
||||||
|
uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: 'Linux Game SOs (server & client.so) [${{ inputs.configuration }}]'
|
||||||
|
path: |
|
||||||
|
${{inputs.branch}}/game/mod_${{inputs.game}}/bin/client.so
|
||||||
|
${{inputs.branch}}/game/mod_${{inputs.game}}/bin/server.so
|
||||||
|
if-no-files-found: error
|
||||||
|
|
||||||
|
- name: Publish Linux shader SO
|
||||||
|
if: inputs.project-group == 'shaders'
|
||||||
|
uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: 'Linux Shader SO (game_shader_dx9.so) [${{ inputs.configuration }}]'
|
||||||
|
path: |
|
||||||
|
${{inputs.branch}}/game/mod_${{inputs.game}}/bin/game_shader_dx9.so
|
||||||
|
if-no-files-found: error
|
||||||
|
|
||||||
|
#- name: Publish Linux map tools
|
||||||
|
# if: inputs.project-group == 'maptools'
|
||||||
|
# uses: actions/upload-artifact@v3
|
||||||
|
# with:
|
||||||
|
# name: 'Linux Map Tools [${{ inputs.configuration }}]'
|
||||||
|
# path: |
|
||||||
|
# ${{inputs.branch}}/game/bin/vbsp
|
||||||
|
# ${{inputs.branch}}/game/bin/vvis
|
||||||
|
# ${{inputs.branch}}/game/bin/vvis_dll.so
|
||||||
|
# ${{inputs.branch}}/game/bin/vrad
|
||||||
|
# ${{inputs.branch}}/game/bin/vrad_dll.so
|
||||||
|
# if-no-files-found: error
|
||||||
|
|
||||||
|
# For now, don't publish the .dbg files even though we publish .pdb files on Windows
|
||||||
|
# (they're too big)
|
||||||
|
- name: Publish everything (Linux)
|
||||||
|
if: inputs.project-group == 'all'
|
||||||
|
uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: 'Everything (Linux) [${{ inputs.configuration }}]'
|
||||||
|
path: |
|
||||||
|
${{inputs.branch}}/game/bin/*.so
|
||||||
|
!${{inputs.branch}}/game/bin/*_srv.so
|
||||||
|
${{inputs.branch}}/game/mod_*/bin/*.so
|
||||||
|
!${{inputs.branch}}/game/mod_*/bin/*_srv.so
|
||||||
|
if-no-files-found: error
|
31
.github/workflows/mapbase_build-master.yml
vendored
Normal file
31
.github/workflows/mapbase_build-master.yml
vendored
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
#
|
||||||
|
# MAPBASE SOURCE 2013 CI
|
||||||
|
#
|
||||||
|
# Builds all projects when a pull request to the master branch is opened.
|
||||||
|
# If you're using a fork of Mapbase, feel free to configure this to meet your repository's needs.
|
||||||
|
#
|
||||||
|
# The "mapbase_build-sp" set of workflows can build specific projects depending on what files are changed.
|
||||||
|
# They are designed around a "develop" branch, but can be configured to target "master" and replace this
|
||||||
|
# instead (or target a similar branch with a different name)
|
||||||
|
#
|
||||||
|
# See mapbase_build-base.yml for more information on how this works.
|
||||||
|
|
||||||
|
name: Build All Projects #(SP Release)
|
||||||
|
|
||||||
|
on:
|
||||||
|
pull_request:
|
||||||
|
branches:
|
||||||
|
- master
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
everything:
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
configuration: [Release, Debug]
|
||||||
|
uses: ./.github/workflows/mapbase_build-base.yml
|
||||||
|
with:
|
||||||
|
configuration: ${{ matrix.configuration }}
|
||||||
|
branch: 'sp'
|
||||||
|
project-group: 'all'
|
||||||
|
solution-name: 'everything'
|
||||||
|
build-on-linux: true # Disable this if you don't want to compile for Linux
|
37
.github/workflows/mapbase_build-sp-games.yml
vendored
Normal file
37
.github/workflows/mapbase_build-sp-games.yml
vendored
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
#
|
||||||
|
# MAPBASE SOURCE 2013 CI
|
||||||
|
#
|
||||||
|
# Builds game projects every time a pull request which modifies the game code is opened.
|
||||||
|
# If you're using a fork of Mapbase, feel free to configure this to meet your repository's needs.
|
||||||
|
#
|
||||||
|
# See mapbase_build-base.yml for more information on how this works.
|
||||||
|
|
||||||
|
name: Build Game Projects #(SP Release)
|
||||||
|
|
||||||
|
on:
|
||||||
|
pull_request:
|
||||||
|
branches:
|
||||||
|
- develop
|
||||||
|
paths:
|
||||||
|
- '.github/workflows/mapbase_build-sp-rel-games.yml'
|
||||||
|
- 'sp/src/vpc_scripts/**'
|
||||||
|
- 'sp/src/game/**'
|
||||||
|
- 'sp/src/mathlib/**'
|
||||||
|
- 'sp/src/responserules/runtime/**'
|
||||||
|
- 'sp/src/tier1/**'
|
||||||
|
- 'sp/src/vgui2/vgui_controls/**'
|
||||||
|
- 'sp/src/vscript/**'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
games:
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
configuration: [Release, Debug]
|
||||||
|
uses: ./.github/workflows/mapbase_build-base.yml
|
||||||
|
with:
|
||||||
|
configuration: ${{ matrix.configuration }}
|
||||||
|
branch: 'sp'
|
||||||
|
game: 'episodic' # Change this if your mod is not using HL2/Episodic game projects
|
||||||
|
project-group: 'game'
|
||||||
|
solution-name: 'games'
|
||||||
|
build-on-linux: true # Disable this if you don't want to compile for Linux
|
38
.github/workflows/mapbase_build-sp-maptools.yml
vendored
Normal file
38
.github/workflows/mapbase_build-sp-maptools.yml
vendored
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
#
|
||||||
|
# MAPBASE SOURCE 2013 CI
|
||||||
|
#
|
||||||
|
# Builds map tool projects every time a pull request which modifies the map tool code is opened.
|
||||||
|
# If you're using a fork of Mapbase, feel free to configure this to meet your repository's needs.
|
||||||
|
#
|
||||||
|
# See mapbase_build-base.yml for more information on how this works.
|
||||||
|
|
||||||
|
name: Build Map Tool Projects #(SP Release)
|
||||||
|
|
||||||
|
on:
|
||||||
|
pull_request:
|
||||||
|
branches:
|
||||||
|
- develop
|
||||||
|
paths:
|
||||||
|
- '.github/workflows/mapbase_build-sp-rel-maptools.yml'
|
||||||
|
- 'sp/src/vpc_scripts/**'
|
||||||
|
- 'sp/src/utils/vbsp/**'
|
||||||
|
- 'sp/src/utils/vvis/**'
|
||||||
|
- 'sp/src/utils/vvis_launcher/**'
|
||||||
|
- 'sp/src/utils/vrad/**'
|
||||||
|
- 'sp/src/utils/vrad_launcher/**'
|
||||||
|
- 'sp/src/mathlib/**'
|
||||||
|
- 'sp/src/tier1/**'
|
||||||
|
- 'sp/src/vgui2/vgui_controls/**'
|
||||||
|
- 'sp/src/vscript/**'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
maptools:
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
configuration: [Release, Debug]
|
||||||
|
uses: ./.github/workflows/mapbase_build-base.yml
|
||||||
|
with:
|
||||||
|
configuration: ${{ matrix.configuration }}
|
||||||
|
branch: 'sp'
|
||||||
|
project-group: 'maptools'
|
||||||
|
solution-name: 'maptools'
|
33
.github/workflows/mapbase_build-sp-shaders.yml
vendored
Normal file
33
.github/workflows/mapbase_build-sp-shaders.yml
vendored
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
#
|
||||||
|
# MAPBASE SOURCE 2013 CI
|
||||||
|
#
|
||||||
|
# Builds shader projects every time a pull request which modifies the shader code is opened.
|
||||||
|
# If you're using a fork of Mapbase, feel free to configure this to meet your repository's needs.
|
||||||
|
#
|
||||||
|
# See mapbase_build-base.yml for more information on how this works.
|
||||||
|
|
||||||
|
name: Build Shader Projects #(SP Release)
|
||||||
|
|
||||||
|
on:
|
||||||
|
pull_request:
|
||||||
|
branches:
|
||||||
|
- develop
|
||||||
|
paths:
|
||||||
|
- '.github/workflows/mapbase_build-sp-rel-shaders.yml'
|
||||||
|
- 'sp/src/vpc_scripts/**'
|
||||||
|
- 'sp/src/materialsystem/**'
|
||||||
|
- 'sp/src/mathlib/**'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
shaders:
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
configuration: [Release, Debug]
|
||||||
|
uses: ./.github/workflows/mapbase_build-base.yml
|
||||||
|
with:
|
||||||
|
configuration: ${{ matrix.configuration }}
|
||||||
|
branch: 'sp'
|
||||||
|
game: 'episodic' # Change this if your mod is not using HL2/Episodic game projects
|
||||||
|
project-group: 'shaders'
|
||||||
|
solution-name: 'shaders'
|
||||||
|
build-on-linux: true # Disable this if you don't want to compile for Linux
|
23
.github/workflows/mapbase_pr.yml
vendored
Normal file
23
.github/workflows/mapbase_pr.yml
vendored
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
#
|
||||||
|
# MAPBASE REPO AUTOMATION
|
||||||
|
#
|
||||||
|
# Automatically labels pull requests according to changed file paths.
|
||||||
|
#
|
||||||
|
# https://github.com/actions/labeler
|
||||||
|
|
||||||
|
name: Pull Request Automation
|
||||||
|
on: [pull_request]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
label:
|
||||||
|
|
||||||
|
if: github.repository_owner == 'mapbase-source'
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
permissions:
|
||||||
|
contents: read
|
||||||
|
pull-requests: write
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/labeler@v4
|
||||||
|
with:
|
||||||
|
repo-token: "${{ secrets.GITHUB_TOKEN }}"
|
119
README
119
README
@ -1,10 +1,10 @@
|
|||||||
//===================================================================================================================================================
|
//=========================================================================================================================
|
||||||
|
|
||||||
Mapbase - Source 2013
|
Mapbase v7.1 - Source 2013
|
||||||
https://github.com/mapbase-source/source-sdk-2013
|
https://github.com/mapbase-source/source-sdk-2013
|
||||||
https://www.moddb.com/mods/mapbase
|
https://www.moddb.com/mods/mapbase
|
||||||
|
|
||||||
//===================================================================================================================================================
|
//=========================================================================================================================
|
||||||
|
|
||||||
This repository contains code from Mapbase, a modification of the Source 2013 SDK which serves as a combined package
|
This repository contains code from Mapbase, a modification of the Source 2013 SDK which serves as a combined package
|
||||||
of general-purpose improvements, fixes, and utility features for mods.
|
of general-purpose improvements, fixes, and utility features for mods.
|
||||||
@ -20,15 +20,19 @@ Mapbase's main content in this repository may include:
|
|||||||
- View rendering changes for drawing 3D skyboxes and RT-based entities
|
- View rendering changes for drawing 3D skyboxes and RT-based entities
|
||||||
- Countless other fixes and improvements
|
- Countless other fixes and improvements
|
||||||
|
|
||||||
//===================================================================================================================================================
|
For more information, view this page:
|
||||||
|
https://github.com/mapbase-source/source-sdk-2013/wiki/Introduction-to-Mapbase
|
||||||
|
|
||||||
Mapbase is an open-source project and its contents can be distributed and used at the discretion of its users. However, this project represents many parts of
|
//=========================================================================================================================
|
||||||
the Source modding community packaged into a whole, so credit is taken very seriously.
|
|
||||||
|
Mapbase is an open-source project and its contents can be distributed and used at the discretion of its users. However, this project contains content from
|
||||||
|
a vast number of different sources which have their own licensing or attribution requirements. We try to handle most of that ourselves, but users who plan on
|
||||||
|
distributing Mapbase content are expected to comply with certain rules.
|
||||||
|
|
||||||
Up-to-date information about Mapbase content usage and credit are addressed in this article on Mapbase's wiki:
|
Up-to-date information about Mapbase content usage and credit are addressed in this article on Mapbase's wiki:
|
||||||
https://github.com/mapbase-source/source-sdk-2013/wiki/Using-Mapbase-Content
|
https://github.com/mapbase-source/source-sdk-2013/wiki/Using-Mapbase-Content
|
||||||
|
|
||||||
//===================================================================================================================================================
|
//=========================================================================================================================
|
||||||
|
|
||||||
>>>>>>>> EXTERNAL CONTENT USED IN MAPBASE <<<<<<<<
|
>>>>>>>> EXTERNAL CONTENT USED IN MAPBASE <<<<<<<<
|
||||||
|
|
||||||
@ -37,27 +41,35 @@ and repositories (especially ones which are specifically published as free sourc
|
|||||||
or complicated code changes accessible and easy to use for level designers and other kinds of Source modders who would otherwise have no idea how to implement them.
|
or complicated code changes accessible and easy to use for level designers and other kinds of Source modders who would otherwise have no idea how to implement them.
|
||||||
|
|
||||||
*** DISCLAIMER: Mapbase has a strict no-leak-content policy and only allows content created directly by contributors or content originating from open-source repositories.
|
*** DISCLAIMER: Mapbase has a strict no-leak-content policy and only allows content created directly by contributors or content originating from open-source repositories.
|
||||||
If you believe any content in Mapbase originates from any leak or unauthorized source (from Valve or otherwise), please contact Blixibon immediately.
|
If you believe any content in Mapbase originates from any leak or unauthorized source (Valve or otherwise), please contact Blixibon immediately.
|
||||||
Mapbase is intended to be usable by everyone, including licensed Source projects and Steam mods. ***
|
Mapbase is intended to be usable by everyone, including licensed Source projects and Steam mods. ***
|
||||||
|
|
||||||
The Alien Swarm SDK was used to backport features and code from newer branches of Source into a Source 2013/Half-Life 2 environment.
|
Mapbase uses content from the following non-Source SDK 2013 Valve games or SDKs:
|
||||||
Mapbase also implements some of Tony Sergi's code changes from the Source 2007 SDK codebase. Both SDKs are publicly distributed by Valve and are available on Steam.
|
|
||||||
|
|
||||||
Some of the features backported from the Alien Swarm SDK (e.g. game instructor, particle rain) require assets from later versions of Source in order to work properly.
|
-- Alien Swarm SDK (Used to backport features and code from newer branches of Source into a Source 2013/Half-Life 2 environment)
|
||||||
The required assets have been backported from Alien Swarm and Left 4 Dead for the release build. They are not available in the code repository.
|
-- Source SDK 2007 Code (Used to implement some of Tony Sergi's code changes)
|
||||||
|
|
||||||
Here's a list of Mapbase's other known external code sources:
|
-- Alien Swarm (Used to port assets from the aforementioned SDK code features, e.g. game instructor icons)
|
||||||
|
-- Left 4 Dead (Used to port certain animations as well as assets from the aforementioned SDK code features, e.g. particle rain)
|
||||||
|
-- Half-Life: Source (Used to port friction tool textures)
|
||||||
|
|
||||||
|
Valve allows assets from these titles to be distributed for modding purposes. Note that ported assets are only used in the release build, not the code repository.
|
||||||
|
|
||||||
|
Mapbase may also contain new third-party software distributed under specific licensing. Please see the bottom of thirdpartylegalnotices.txt for more information.
|
||||||
|
|
||||||
|
Here's a list of Mapbase's other external code sources:
|
||||||
|
|
||||||
- https://github.com/95Navigator/insolence-2013 (Initial custom shader code and projected texture improvements; also used to implement ASW SDK particle precipitation code)
|
- https://github.com/95Navigator/insolence-2013 (Initial custom shader code and projected texture improvements; also used to implement ASW SDK particle precipitation code)
|
||||||
- https://github.com/Biohazard90/g-string_2013 (Custom shadow filters, included indirectly via Insolence repo)
|
-- https://github.com/Biohazard90/g-string_2013 (Custom shadow filters, included indirectly via Insolence repo)
|
||||||
- https://github.com/KyleGospo/City-17-Episode-One-Source (Brush phong and projected texture changes, included indirectly via Insolence repo)
|
-- https://github.com/KyleGospo/City-17-Episode-One-Source (Brush phong and projected texture changes, included indirectly via Insolence repo)
|
||||||
- https://github.com/DownFall-Team/DownFall (Multiple skybox code and fix for ent_fire delay not using floats; Also used as a guide to port certain Alien Swarm SDK changes to Source 2013,
|
- https://github.com/DownFall-Team/DownFall (Multiple skybox code and fix for ent_fire delay not using floats; Also used as a guide to port certain Alien Swarm SDK changes to Source 2013,
|
||||||
including radial fog, rope code, and treesway)
|
including radial fog, rope code, and treesway)
|
||||||
- https://github.com/momentum-mod/game (Used as a guide to port postprocess_controller and env_dof_controller to Source 2013)
|
- https://github.com/momentum-mod/game (Used as a guide to port postprocess_controller and env_dof_controller to Source 2013 from the Alien Swarm SDK)
|
||||||
- https://github.com/DeathByNukes/source-sdk-2013 (VBSP manifest fixes)
|
- https://github.com/DeathByNukes/source-sdk-2013 (VBSP manifest fixes)
|
||||||
- https://github.com/entropy-zero/source-sdk-2013 (skill_changed game event)
|
- https://github.com/entropy-zero/source-sdk-2013 (skill_changed game event)
|
||||||
|
- https://github.com/Nbc66/source-sdk-2013-ce/tree/v142 (Base for VS2019 toolset support)
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------------------------------------
|
//-------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
Valve Developer Community (VDC) sources:
|
Valve Developer Community (VDC) sources:
|
||||||
|
|
||||||
@ -83,25 +95,69 @@ interchangeable arms; this may change in the future)
|
|||||||
- https://developer.valvesoftware.com/wiki/Npc_clawscanner#Strider_Scout_Issue (npc_clawscanner strider scout fix)
|
- https://developer.valvesoftware.com/wiki/Npc_clawscanner#Strider_Scout_Issue (npc_clawscanner strider scout fix)
|
||||||
- https://developer.valvesoftware.com/wiki/Ambient_generic:_stop_and_toggle_fix (Fixes for stopping/toggling ambient_generic)
|
- https://developer.valvesoftware.com/wiki/Ambient_generic:_stop_and_toggle_fix (Fixes for stopping/toggling ambient_generic)
|
||||||
- https://developer.valvesoftware.com/wiki/Func_clip_vphysics ("Start Disabled" keyvalue fix)
|
- https://developer.valvesoftware.com/wiki/Func_clip_vphysics ("Start Disabled" keyvalue fix)
|
||||||
|
- https://developer.valvesoftware.com/wiki/Importing_CSS_Weapons_Into_HL2 (CS:S viewmodel chirality)
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------------------------------------
|
//-------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
Direct contributions:
|
Direct contributions:
|
||||||
|
|
||||||
|
- https://github.com/mapbase-source/source-sdk-2013/pull/3 ("playvideo" command playback fix from Avanate)
|
||||||
- https://github.com/mapbase-source/source-sdk-2013/pull/5 (Custom VScript implementation by ReDucTor; was placed into feature branch before being merged in a subsequent PR)
|
- https://github.com/mapbase-source/source-sdk-2013/pull/5 (Custom VScript implementation by ReDucTor; was placed into feature branch before being merged in a subsequent PR)
|
||||||
- https://github.com/mapbase-source/source-sdk-2013/pull/3 ("playvideo" command playback fix from Avantate)
|
|
||||||
- https://github.com/mapbase-source/source-sdk-2013/pull/21 (Various GCC/Linux fixes from z33ky)
|
|
||||||
- https://github.com/mapbase-source/source-sdk-2013/pull/47 (VScript utility/consistency changes from samisalreadytaken)
|
|
||||||
- https://github.com/mapbase-source/source-sdk-2013/pull/59 (New VScript functions and singletons from samisalreadytaken based on API documentation in later Source/Source 2 games)
|
|
||||||
- https://github.com/mapbase-source/source-sdk-2013/pull/60 (Adjustment by RoyaleNoir to one of Saul's VDC changes)
|
- https://github.com/mapbase-source/source-sdk-2013/pull/60 (Adjustment by RoyaleNoir to one of Saul's VDC changes)
|
||||||
|
- https://github.com/mapbase-source/source-sdk-2013/pull/84 (CS:S viewmodel chirality from 1upD)
|
||||||
|
- https://github.com/mapbase-source/source-sdk-2013/pull/116 (vgui_movie_display mute keyvalue from Alivebyte/rzkid)
|
||||||
|
- https://github.com/mapbase-source/source-sdk-2013/pull/140 (logic_substring entity and icon created by moofemp)
|
||||||
|
- https://github.com/mapbase-source/source-sdk-2013/pull/143 (Propper features for VBSP from Matty-64)
|
||||||
|
- https://github.com/mapbase-source/source-sdk-2013/pull/174 (Fix for multiply defined symbols in later toolsets from und)
|
||||||
|
- https://github.com/mapbase-source/source-sdk-2013/issues/201 (env_projectedtexture shadow filter keyvalue from celisej567)
|
||||||
|
- https://github.com/mapbase-source/source-sdk-2013/pull/193 (RTB:R info_particle_system_coordinate by arbabf and Iridium77)
|
||||||
|
- https://github.com/mapbase-source/source-sdk-2013/pull/193 (Infinite prop_interactable cooldown by arbabf)
|
||||||
- Demo autorecord code provided by Klems
|
- Demo autorecord code provided by Klems
|
||||||
- cc_emit crash fix provided by 1upD
|
- cc_emit crash fix provided by 1upD
|
||||||
- Custom HL2 ammo crate models created by Rara (Textures created by Blixibon; This is asset-based and, aside from the SLAM crate, not reflected in the code)
|
- Custom HL2 ammo crate models created by Rykah (Textures created by Blixibon; This is asset-based and, aside from the SLAM crate, not reflected in the code)
|
||||||
- Combine lock hardware on door01_left.mdl created by Kralich (This is asset-based and not reflected in the code)
|
- Combine lock hardware on door01_left.mdl created by Kralich (This is asset-based and not reflected in the code)
|
||||||
- npc_vehicledriver fixes provided by CrAzY
|
- npc_vehicledriver fixes provided by CrAzY
|
||||||
- npc_combine cover behavior patches provided by iohnnyboy
|
- npc_combine cover behavior patches provided by iohnnyboy
|
||||||
|
- logic_playmovie icon created by URAKOLOUY5 (This is asset-based and not reflected in the code)
|
||||||
|
- Dropship APC save/load fix provided by Cvoxulary
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------------------------------------
|
== Contributions from samisalreadytaken:
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/47 (VScript utility/consistency changes)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/59 (New VScript functions and singletons based on API documentation in later Source/Source 2 games)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/80 (More VScript changes, including support for extremely flexible client/server messaging)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/105 (VScript fixes and optimizations, Vector class extensions, custom convars/commands)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/114 (VScript fixes and extensions)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/122 (Minor VScript-related adjustments)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/148 (Minor fixup)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/167 (Security fixes)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/168 (Squirrel update)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/169 (VScript VGUI)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/171 (VScript documentation sorting)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/173 (VScript fixes and optimizations)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/192 (VScript hook manager and fixes)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/206 (Fix CScriptNetMsgHelper::WriteEntity())
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/213 (VScript HUD visibility control, optimizations for 3D skybox angles/fake worldportals)
|
||||||
|
|
||||||
|
== Contributions from z33ky:
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/21 (Various GCC/Linux compilation fixes)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/95 (Additional GCC/Linux compilation fixes)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/117 (Additional GCC/Linux compilation fixes)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/124 (Memory error fixes)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/130 (Memory error fixes)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/131 (env_projectedtexture target shadows fix)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/132 (Console error fix)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/152 (Additional GCC/Linux compilation fixes)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/159 (Additional GCC/Linux compilation fixes)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/162 (VS2019 exception specification fix)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/170 (HL2 non-Episodic build fix)
|
||||||
|
|
||||||
|
== Contributions from Petercov:
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/182 (NPCs load dynamic interactions from all animation MDLs)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/184 (Projected texture horizontal FOV shadow fix)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/185 (Fix enemyfinders becoming visible when they wake)
|
||||||
|
=-- https://github.com/mapbase-source/source-sdk-2013/pull/186 (Fix for brightly glowing teeth)
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
Other sources:
|
Other sources:
|
||||||
|
|
||||||
@ -112,22 +168,31 @@ Other sources:
|
|||||||
-- https://github.com/ValveSoftware/source-sdk-2013/pull/401 (func_rot_button "Starts locked" flag fix)
|
-- https://github.com/ValveSoftware/source-sdk-2013/pull/401 (func_rot_button "Starts locked" flag fix)
|
||||||
-- https://github.com/ValveSoftware/source-sdk-2013/pull/391 (VBSP func_detail smoothing group fix)
|
-- https://github.com/ValveSoftware/source-sdk-2013/pull/391 (VBSP func_detail smoothing group fix)
|
||||||
-- https://github.com/ValveSoftware/source-sdk-2013/pull/362 (npc_manhack npc_maker fix; Adjusted for formatting and save/restore in Mapbase)
|
-- https://github.com/ValveSoftware/source-sdk-2013/pull/362 (npc_manhack npc_maker fix; Adjusted for formatting and save/restore in Mapbase)
|
||||||
|
-- https://github.com/Petercov/Source-PlusPlus/commit/ecdf50c48cd31dec4dbdb7fea2d0780e7f0dd8ec (used as a guide for porting the Alien Swarm SDK response system)
|
||||||
- https://github.com/momentum-mod/game/blob/1d066180b3bf74830c51e6914d46c40b0bea1fc2/mp/src/game/server/player.cpp#L6543 (spec_goto fix)
|
- https://github.com/momentum-mod/game/blob/1d066180b3bf74830c51e6914d46c40b0bea1fc2/mp/src/game/server/player.cpp#L6543 (spec_goto fix)
|
||||||
- Poison zombie barnacle crash fix implemented based on a snippet from HL2: Plus posted by Agent Agrimar on Discord (Mapbase makes the barnacle recognize it as poison just like poison headcrabs)
|
- Poison zombie barnacle crash fix implemented based on a snippet from HL2: Plus posted by Agent Agrimar on Discord (Mapbase makes the barnacle recognize it as poison just like poison headcrabs)
|
||||||
- https://gamebanana.com/skins/172192 (Airboat handling fix; This is asset-based and not reflected in the code)
|
- https://gamebanana.com/skins/172192 (Airboat handling fix; This is asset-based and not reflected in the code)
|
||||||
- Vortigaunt LOS fix originally created by dky.tehkingd.u for HL2:CE
|
- Vortigaunt LOS fix originally created by dky.tehkingd.u for HL2:CE
|
||||||
- https://combineoverwiki.net/wiki/File:Combine_main_symbol.svg ("icon_combine" instructor icon in "materials/vgui/hud/gameinstructor_hl2_1"; This is asset-based and not reflected in the code)
|
- https://combineoverwiki.net/wiki/File:Combine_main_symbol.svg ("icon_combine" instructor icon in "materials/vgui/hud/gameinstructor_hl2_1"; This is asset-based and not reflected in the code)
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------------------------------------
|
//-------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
If there is anything missing from this list, please contact Blixibon.
|
If there is anything missing from this list, please contact Blixibon.
|
||||||
|
|
||||||
//===================================================================================================================================================
|
//=========================================================================================================================
|
||||||
|
|
||||||
Aside from the content list above, Mapbase has more descriptive and up-to-date credits on this wiki article:
|
Aside from the content list above, Mapbase has more descriptive and up-to-date credits on this wiki article:
|
||||||
https://github.com/mapbase-source/source-sdk-2013/wiki/Mapbase-Credits
|
https://github.com/mapbase-source/source-sdk-2013/wiki/Mapbase-Credits
|
||||||
|
|
||||||
//===================================================================================================================================================
|
Other relevant articles:
|
||||||
|
* https://github.com/mapbase-source/source-sdk-2013/wiki/Mapbase-Disclaimers
|
||||||
|
* https://github.com/mapbase-source/source-sdk-2013/wiki/Frequently-Asked-Questions-(FAQ)
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
In memory of Holly Liberatore (moofemp)
|
||||||
|
|
||||||
|
//=========================================================================================================================
|
||||||
|
|
||||||
Please see the Source SDK 2013 license below:
|
Please see the Source SDK 2013 license below:
|
||||||
|
|
||||||
|
@ -6,10 +6,11 @@ MAKEFILE_LINK:=$(THISFILE).link
|
|||||||
|
|
||||||
-include $(MAKEFILE_LINK)
|
-include $(MAKEFILE_LINK)
|
||||||
|
|
||||||
$(MAKEFILE_LINK): $(shell which $(CC)) $(THISFILE)
|
# depend on CXX so the correct makefile can be selected when the system is updated
|
||||||
if [ "$(shell printf "$(shell $(CC) -dumpversion)\n8" | sort -Vr | head -1)" = 8 ]; then \
|
$(MAKEFILE_LINK): $(shell which $(CXX)) $(THISFILE) $(SRCROOT)/devtools/gcc9+support.cpp
|
||||||
$(COMPILE.cpp) -o gcc9+support.o gcc9+support.c ;\
|
@ if [ "$(shell printf "$(shell $(CXX) -dumpversion)\n8" | sort -Vr | head -1)" = 8 ]; then \
|
||||||
ln -sf $(MAKEFILE_BASE).default $@ ;\
|
ln -sf $(MAKEFILE_BASE).default $@ ;\
|
||||||
else \
|
else \
|
||||||
|
$(COMPILE.cpp) -m32 -o $(SRCROOT)/devtools/gcc9+support.o $(SRCROOT)/devtools/gcc9+support.cpp &&\
|
||||||
ln -sf $(MAKEFILE_BASE).gcc8 $@ ;\
|
ln -sf $(MAKEFILE_BASE).gcc8 $@ ;\
|
||||||
fi
|
fi
|
||||||
|
@ -813,7 +813,11 @@ bool GameData::RemapNameField( const char *pszInValue, char *pszOutValue, TNameF
|
|||||||
{
|
{
|
||||||
strcpy( pszOutValue, pszInValue );
|
strcpy( pszOutValue, pszInValue );
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if ( pszInValue[ 0 ] && pszInValue[ 0 ] != '@' && pszInValue[ 0 ] != '!' )
|
||||||
|
#else
|
||||||
if ( pszInValue[ 0 ] && pszInValue[ 0 ] != '@' )
|
if ( pszInValue[ 0 ] && pszInValue[ 0 ] != '@' )
|
||||||
|
#endif
|
||||||
{ // ! at the start of a value means it is global and should not be remaped
|
{ // ! at the start of a value means it is global and should not be remaped
|
||||||
switch( NameFixup )
|
switch( NameFixup )
|
||||||
{
|
{
|
||||||
|
@ -92,6 +92,7 @@ private:
|
|||||||
float m_flLinearAtten;
|
float m_flLinearAtten;
|
||||||
float m_flQuadraticAtten;
|
float m_flQuadraticAtten;
|
||||||
float m_flShadowAtten;
|
float m_flShadowAtten;
|
||||||
|
float m_flShadowFilter;
|
||||||
|
|
||||||
bool m_bAlwaysDraw;
|
bool m_bAlwaysDraw;
|
||||||
//bool m_bProjectedTextureVersion;
|
//bool m_bProjectedTextureVersion;
|
||||||
|
@ -264,6 +264,9 @@ LINK_ENTITY_TO_CLASS( client_ragdoll, C_ClientRagdoll );
|
|||||||
BEGIN_DATADESC( C_ClientRagdoll )
|
BEGIN_DATADESC( C_ClientRagdoll )
|
||||||
DEFINE_FIELD( m_bFadeOut, FIELD_BOOLEAN ),
|
DEFINE_FIELD( m_bFadeOut, FIELD_BOOLEAN ),
|
||||||
DEFINE_FIELD( m_bImportant, FIELD_BOOLEAN ),
|
DEFINE_FIELD( m_bImportant, FIELD_BOOLEAN ),
|
||||||
|
#ifdef MAPBASE
|
||||||
|
DEFINE_FIELD( m_flForcedRetireTime, FIELD_FLOAT ),
|
||||||
|
#endif
|
||||||
DEFINE_FIELD( m_iCurrentFriction, FIELD_INTEGER ),
|
DEFINE_FIELD( m_iCurrentFriction, FIELD_INTEGER ),
|
||||||
DEFINE_FIELD( m_iMinFriction, FIELD_INTEGER ),
|
DEFINE_FIELD( m_iMinFriction, FIELD_INTEGER ),
|
||||||
DEFINE_FIELD( m_iMaxFriction, FIELD_INTEGER ),
|
DEFINE_FIELD( m_iMaxFriction, FIELD_INTEGER ),
|
||||||
@ -286,6 +289,22 @@ BEGIN_DATADESC( C_ClientRagdoll )
|
|||||||
|
|
||||||
END_DATADESC()
|
END_DATADESC()
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
BEGIN_ENT_SCRIPTDESC( C_ClientRagdoll, C_BaseAnimating, "Client-side ragdolls" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( SUB_Remove, "FadeOut", "Fades out the ragdoll and removes it from the client." )
|
||||||
|
|
||||||
|
// TODO: Proper shared ragdoll funcs?
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetRagdollObject, "GetRagdollObject", "Gets the ragdoll object of the specified index." )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetRagdollObjectCount, "GetRagdollObjectCount", "Gets the number of ragdoll objects on this ragdoll." )
|
||||||
|
|
||||||
|
END_SCRIPTDESC();
|
||||||
|
|
||||||
|
ScriptHook_t C_BaseAnimating::g_Hook_OnClientRagdoll;
|
||||||
|
ScriptHook_t C_BaseAnimating::g_Hook_FireEvent;
|
||||||
|
//ScriptHook_t C_BaseAnimating::g_Hook_BuildTransformations;
|
||||||
|
#endif
|
||||||
|
|
||||||
BEGIN_ENT_SCRIPTDESC( C_BaseAnimating, C_BaseEntity, "Animating models client-side" )
|
BEGIN_ENT_SCRIPTDESC( C_BaseAnimating, C_BaseEntity, "Animating models client-side" )
|
||||||
#ifdef MAPBASE_VSCRIPT
|
#ifdef MAPBASE_VSCRIPT
|
||||||
DEFINE_SCRIPTFUNC_NAMED( ScriptGetPoseParameter, "GetPoseParameter", "Get the specified pose parameter's value" )
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetPoseParameter, "GetPoseParameter", "Get the specified pose parameter's value" )
|
||||||
@ -293,6 +312,22 @@ BEGIN_ENT_SCRIPTDESC( C_BaseAnimating, C_BaseEntity, "Animating models client-si
|
|||||||
DEFINE_SCRIPTFUNC_NAMED( ScriptSetPoseParameter, "SetPoseParameter", "Set the specified pose parameter to the specified value" )
|
DEFINE_SCRIPTFUNC_NAMED( ScriptSetPoseParameter, "SetPoseParameter", "Set the specified pose parameter to the specified value" )
|
||||||
DEFINE_SCRIPTFUNC( IsSequenceFinished, "Ask whether the main sequence is done playing" )
|
DEFINE_SCRIPTFUNC( IsSequenceFinished, "Ask whether the main sequence is done playing" )
|
||||||
#ifdef MAPBASE_VSCRIPT
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptLookupAttachment, "LookupAttachment", "Get the named attachement id" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetAttachmentOrigin, "GetAttachmentOrigin", "Get the attachement id's origin vector" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetAttachmentAngles, "GetAttachmentAngles", "Get the attachement id's angles as a p,y,r vector" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetAttachmentMatrix, "GetAttachmentMatrix", "Get the attachement id's matrix transform" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( LookupBone, "Get the named bone id" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetBoneTransform, "GetBoneTransform", "Get the transform for the specified bone" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptSetBoneTransform, "SetBoneTransform", "Set the transform for the specified bone" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptAttachEntityToBone, "AttachEntityToBone", "Attaches this entity to the specified target and bone. Also allows for optional local position offset" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptRemoveBoneAttachment, "RemoveBoneAttachment", "Removes the specified bone attachment" )
|
||||||
|
//DEFINE_SCRIPTFUNC( RemoveBoneAttachments, "Removes all bone attachments" )
|
||||||
|
DEFINE_SCRIPTFUNC( DestroyBoneAttachments, "Destroys all bone attachments" )
|
||||||
|
DEFINE_SCRIPTFUNC( GetNumBoneAttachments, "Gets the number of bone attachments" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetBoneAttachment, "GetBoneAttachment", "Gets the specified bone attachment" )
|
||||||
|
|
||||||
DEFINE_SCRIPTFUNC( SetBodygroup, "Sets a bodygroup")
|
DEFINE_SCRIPTFUNC( SetBodygroup, "Sets a bodygroup")
|
||||||
DEFINE_SCRIPTFUNC( GetBodygroup, "Gets a bodygroup" )
|
DEFINE_SCRIPTFUNC( GetBodygroup, "Gets a bodygroup" )
|
||||||
DEFINE_SCRIPTFUNC( GetBodygroupName, "Gets a bodygroup name" )
|
DEFINE_SCRIPTFUNC( GetBodygroupName, "Gets a bodygroup name" )
|
||||||
@ -302,12 +337,43 @@ BEGIN_ENT_SCRIPTDESC( C_BaseAnimating, C_BaseEntity, "Animating models client-si
|
|||||||
|
|
||||||
DEFINE_SCRIPTFUNC( GetSequence, "Gets the current sequence" )
|
DEFINE_SCRIPTFUNC( GetSequence, "Gets the current sequence" )
|
||||||
DEFINE_SCRIPTFUNC( SetSequence, "Sets the current sequence" )
|
DEFINE_SCRIPTFUNC( SetSequence, "Sets the current sequence" )
|
||||||
DEFINE_SCRIPTFUNC( SequenceLoops, "Loops the current sequence" )
|
DEFINE_SCRIPTFUNC( SequenceLoops, "Does the current sequence loop?" )
|
||||||
DEFINE_SCRIPTFUNC( LookupSequence, "Gets the index of the specified sequence name" )
|
DEFINE_SCRIPTFUNC( LookupSequence, "Gets the index of the specified sequence name" )
|
||||||
DEFINE_SCRIPTFUNC( LookupActivity, "Gets the ID of the specified activity name" )
|
DEFINE_SCRIPTFUNC( LookupActivity, "Gets the ID of the specified activity name" )
|
||||||
DEFINE_SCRIPTFUNC( GetSequenceName, "Gets the name of the specified sequence index" )
|
DEFINE_SCRIPTFUNC( GetSequenceName, "Gets the name of the specified sequence index" )
|
||||||
DEFINE_SCRIPTFUNC( GetSequenceActivityName, "Gets the activity name of the specified sequence index" )
|
DEFINE_SCRIPTFUNC( GetSequenceActivityName, "Gets the activity name of the specified sequence index" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetSequenceMoveDist, "GetSequenceMoveDist", "Gets the move distance of the specified sequence" )
|
||||||
DEFINE_SCRIPTFUNC_NAMED( ScriptGetSequenceActivity, "GetSequenceActivity", "Gets the activity ID of the specified sequence index" )
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetSequenceActivity, "GetSequenceActivity", "Gets the activity ID of the specified sequence index" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptSelectWeightedSequence, "SelectWeightedSequence", "Selects a sequence for the specified activity ID" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( GetPlaybackRate, "" )
|
||||||
|
DEFINE_SCRIPTFUNC( SetPlaybackRate, "" )
|
||||||
|
DEFINE_SCRIPTFUNC( GetCycle, "" )
|
||||||
|
DEFINE_SCRIPTFUNC( SetCycle, "" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetSkin, "GetSkin", "Gets the model's skin" )
|
||||||
|
DEFINE_SCRIPTFUNC( SetSkin, "Sets the model's skin" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( GetForceBone, "Gets the entity's force bone, which is used to determine which bone a ragdoll should apply its force to." )
|
||||||
|
DEFINE_SCRIPTFUNC( SetForceBone, "Sets the entity's force bone, which is used to determine which bone a ragdoll should apply its force to." )
|
||||||
|
DEFINE_SCRIPTFUNC( GetRagdollForce, "Gets the entity's ragdoll force, which is used to apply velocity to a ragdoll." )
|
||||||
|
DEFINE_SCRIPTFUNC( SetRagdollForce, "Sets the entity's ragdoll force, which is used to apply velocity to a ragdoll." )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptBecomeRagdollOnClient, "BecomeRagdollOnClient", "" )
|
||||||
|
DEFINE_SCRIPTFUNC( IsRagdoll, "" )
|
||||||
|
|
||||||
|
BEGIN_SCRIPTHOOK( C_BaseAnimating::g_Hook_OnClientRagdoll, "OnClientRagdoll", FIELD_VOID, "Called when this entity turns into a client-side ragdoll." )
|
||||||
|
DEFINE_SCRIPTHOOK_PARAM( "ragdoll", FIELD_HSCRIPT )
|
||||||
|
END_SCRIPTHOOK()
|
||||||
|
|
||||||
|
BEGIN_SCRIPTHOOK( C_BaseAnimating::g_Hook_FireEvent, "FireEvent", FIELD_BOOLEAN, "Called when handling animation events. Return false to cancel base handling." )
|
||||||
|
DEFINE_SCRIPTHOOK_PARAM( "origin", FIELD_VECTOR )
|
||||||
|
DEFINE_SCRIPTHOOK_PARAM( "angles", FIELD_VECTOR )
|
||||||
|
DEFINE_SCRIPTHOOK_PARAM( "event", FIELD_INTEGER )
|
||||||
|
DEFINE_SCRIPTHOOK_PARAM( "options", FIELD_CSTRING )
|
||||||
|
END_SCRIPTHOOK()
|
||||||
|
|
||||||
|
//BEGIN_SCRIPTHOOK( C_BaseAnimating::g_Hook_BuildTransformations, "BuildTransformations", FIELD_VOID, "Called when building bone transformations. Allows VScript to read/write any bone with Get/SetBoneTransform." )
|
||||||
|
//END_SCRIPTHOOK()
|
||||||
#endif
|
#endif
|
||||||
END_SCRIPTDESC();
|
END_SCRIPTDESC();
|
||||||
|
|
||||||
@ -319,6 +385,9 @@ C_ClientRagdoll::C_ClientRagdoll( bool bRestoring )
|
|||||||
m_bFadeOut = false;
|
m_bFadeOut = false;
|
||||||
m_bFadingOut = false;
|
m_bFadingOut = false;
|
||||||
m_bImportant = false;
|
m_bImportant = false;
|
||||||
|
#ifdef MAPBASE
|
||||||
|
m_flForcedRetireTime = 0.0f;
|
||||||
|
#endif
|
||||||
m_bNoModelParticles = false;
|
m_bNoModelParticles = false;
|
||||||
|
|
||||||
SetClassname("client_ragdoll");
|
SetClassname("client_ragdoll");
|
||||||
@ -399,7 +468,11 @@ void C_ClientRagdoll::OnRestore( void )
|
|||||||
|
|
||||||
if ( m_bFadeOut == true )
|
if ( m_bFadeOut == true )
|
||||||
{
|
{
|
||||||
|
#ifdef MAPBASE
|
||||||
|
s_RagdollLRU.MoveToTopOfLRU( this, m_bImportant, m_flForcedRetireTime );
|
||||||
|
#else
|
||||||
s_RagdollLRU.MoveToTopOfLRU( this, m_bImportant );
|
s_RagdollLRU.MoveToTopOfLRU( this, m_bImportant );
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
NoteRagdollCreationTick( this );
|
NoteRagdollCreationTick( this );
|
||||||
@ -674,6 +747,24 @@ void C_ClientRagdoll::Release( void )
|
|||||||
BaseClass::Release();
|
BaseClass::Release();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
HSCRIPT C_ClientRagdoll::ScriptGetRagdollObject( int iIndex )
|
||||||
|
{
|
||||||
|
if (iIndex < 0 || iIndex > m_pRagdoll->RagdollBoneCount())
|
||||||
|
{
|
||||||
|
Warning("%s GetRagdollObject: Index %i not valid (%i objects)\n", GetDebugName(), iIndex, m_pRagdoll->RagdollBoneCount());
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return g_pScriptVM->RegisterInstance( m_pRagdoll->GetElement(iIndex) );
|
||||||
|
}
|
||||||
|
|
||||||
|
int C_ClientRagdoll::ScriptGetRagdollObjectCount()
|
||||||
|
{
|
||||||
|
return m_pRagdoll->RagdollBoneCount();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Incremented each frame in InvalidateModelBones. Models compare this value to what it
|
// Incremented each frame in InvalidateModelBones. Models compare this value to what it
|
||||||
// was last time they setup their bones to determine if they need to re-setup their bones.
|
// was last time they setup their bones to determine if they need to re-setup their bones.
|
||||||
@ -711,6 +802,10 @@ C_BaseAnimating::C_BaseAnimating() :
|
|||||||
m_nPrevSequence = -1;
|
m_nPrevSequence = -1;
|
||||||
m_nRestoreSequence = -1;
|
m_nRestoreSequence = -1;
|
||||||
m_pRagdoll = NULL;
|
m_pRagdoll = NULL;
|
||||||
|
m_pClientsideRagdoll = NULL;
|
||||||
|
#ifdef MAPBASE
|
||||||
|
m_pServerRagdoll = NULL;
|
||||||
|
#endif
|
||||||
m_builtRagdoll = false;
|
m_builtRagdoll = false;
|
||||||
m_hitboxBoneCacheHandle = 0;
|
m_hitboxBoneCacheHandle = 0;
|
||||||
int i;
|
int i;
|
||||||
@ -1461,6 +1556,94 @@ float C_BaseAnimating::ClampCycle( float flCycle, bool isLooping )
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef MAPBASE_VSCRIPT
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Returns the world location and world angles of an attachment to vscript caller
|
||||||
|
// Input : attachment name
|
||||||
|
// Output : location and angles
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
const Vector& C_BaseAnimating::ScriptGetAttachmentOrigin( int iAttachment )
|
||||||
|
{
|
||||||
|
|
||||||
|
static Vector absOrigin;
|
||||||
|
static QAngle qa;
|
||||||
|
|
||||||
|
C_BaseAnimating::GetAttachment( iAttachment, absOrigin, qa );
|
||||||
|
|
||||||
|
return absOrigin;
|
||||||
|
}
|
||||||
|
|
||||||
|
const Vector& C_BaseAnimating::ScriptGetAttachmentAngles( int iAttachment )
|
||||||
|
{
|
||||||
|
|
||||||
|
static Vector absOrigin;
|
||||||
|
static Vector absAngles;
|
||||||
|
static QAngle qa;
|
||||||
|
|
||||||
|
C_BaseAnimating::GetAttachment( iAttachment, absOrigin, qa );
|
||||||
|
absAngles.x = qa.x;
|
||||||
|
absAngles.y = qa.y;
|
||||||
|
absAngles.z = qa.z;
|
||||||
|
return absAngles;
|
||||||
|
}
|
||||||
|
|
||||||
|
HSCRIPT C_BaseAnimating::ScriptGetAttachmentMatrix( int iAttachment )
|
||||||
|
{
|
||||||
|
static matrix3x4_t matrix;
|
||||||
|
|
||||||
|
C_BaseAnimating::GetAttachment( iAttachment, matrix );
|
||||||
|
return g_pScriptVM->RegisterInstance( &matrix );
|
||||||
|
}
|
||||||
|
|
||||||
|
void C_BaseAnimating::ScriptGetBoneTransform( int iBone, HSCRIPT hTransform )
|
||||||
|
{
|
||||||
|
matrix3x4_t *matTransform = HScriptToClass<matrix3x4_t>( hTransform );
|
||||||
|
if (matTransform == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
|
GetBoneTransform( iBone, *matTransform );
|
||||||
|
}
|
||||||
|
|
||||||
|
void C_BaseAnimating::ScriptSetBoneTransform( int iBone, HSCRIPT hTransform )
|
||||||
|
{
|
||||||
|
matrix3x4_t *matTransform = HScriptToClass<matrix3x4_t>( hTransform );
|
||||||
|
if (matTransform == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
|
MatrixCopy( *matTransform, GetBoneForWrite( iBone ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
void C_BaseAnimating::ScriptAttachEntityToBone( HSCRIPT attachTarget, int boneIndexAttached, const Vector &bonePosition, const QAngle &boneAngles )
|
||||||
|
{
|
||||||
|
C_BaseEntity *pTarget = ToEnt( attachTarget );
|
||||||
|
if (pTarget == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
|
AttachEntityToBone( pTarget->GetBaseAnimating(), boneIndexAttached, bonePosition, boneAngles );
|
||||||
|
}
|
||||||
|
|
||||||
|
void C_BaseAnimating::ScriptRemoveBoneAttachment( HSCRIPT boneAttachment )
|
||||||
|
{
|
||||||
|
C_BaseEntity *pTarget = ToEnt( boneAttachment );
|
||||||
|
if (pTarget == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
|
RemoveBoneAttachment( pTarget->GetBaseAnimating() );
|
||||||
|
}
|
||||||
|
|
||||||
|
HSCRIPT C_BaseAnimating::ScriptGetBoneAttachment( int i )
|
||||||
|
{
|
||||||
|
return ToHScript( GetBoneAttachment( i ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
HSCRIPT C_BaseAnimating::ScriptBecomeRagdollOnClient()
|
||||||
|
{
|
||||||
|
C_BaseAnimating *pRagdoll = BecomeRagdollOnClient();
|
||||||
|
if (!pRagdoll)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
return pRagdoll->GetScriptInstance();
|
||||||
|
}
|
||||||
|
|
||||||
float C_BaseAnimating::ScriptGetPoseParameter( const char* szName )
|
float C_BaseAnimating::ScriptGetPoseParameter( const char* szName )
|
||||||
{
|
{
|
||||||
CStudioHdr* pHdr = GetModelPtr();
|
CStudioHdr* pHdr = GetModelPtr();
|
||||||
@ -1638,7 +1821,23 @@ void C_BaseAnimating::BuildTransformations( CStudioHdr *hdr, Vector *pos, Quater
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
//if (m_ScriptScope.IsInitialized() && g_Hook_BuildTransformations.CanRunInScope(m_ScriptScope))
|
||||||
|
//{
|
||||||
|
// int oldWritableBones = m_BoneAccessor.GetWritableBones();
|
||||||
|
// int oldReadableBones = m_BoneAccessor.GetReadableBones();
|
||||||
|
// m_BoneAccessor.SetWritableBones( BONE_USED_BY_ANYTHING );
|
||||||
|
// m_BoneAccessor.SetReadableBones( BONE_USED_BY_ANYTHING );
|
||||||
|
//
|
||||||
|
// // No parameters
|
||||||
|
// //ScriptVariant_t args[] = {};
|
||||||
|
// //ScriptVariant_t returnValue;
|
||||||
|
// g_Hook_BuildTransformations.Call( m_ScriptScope, NULL, NULL /*&returnValue, args*/ );
|
||||||
|
//
|
||||||
|
// m_BoneAccessor.SetWritableBones( oldWritableBones );
|
||||||
|
// m_BoneAccessor.SetReadableBones( oldReadableBones );
|
||||||
|
//}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -1844,6 +2043,10 @@ CollideType_t C_BaseAnimating::GetCollideType( void )
|
|||||||
return BaseClass::GetCollideType();
|
return BaseClass::GetCollideType();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
ConVar ai_death_pose_enabled( "ai_death_pose_enabled", "1", FCVAR_NONE, "Toggles the death pose fix code, which cancels sequence transitions while a NPC is ragdolling." );
|
||||||
|
#endif
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose: if the active sequence changes, keep track of the previous ones and decay them based on their decay rate
|
// Purpose: if the active sequence changes, keep track of the previous ones and decay them based on their decay rate
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -1860,6 +2063,14 @@ void C_BaseAnimating::MaintainSequenceTransitions( IBoneSetup &boneSetup, float
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if ( IsAboutToRagdoll() && ai_death_pose_enabled.GetBool() )
|
||||||
|
{
|
||||||
|
m_nPrevNewSequenceParity = m_nNewSequenceParity;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
m_SequenceTransitioner.CheckForSequenceChange(
|
m_SequenceTransitioner.CheckForSequenceChange(
|
||||||
boneSetup.GetStudioHdr(),
|
boneSetup.GetStudioHdr(),
|
||||||
GetSequence(),
|
GetSequence(),
|
||||||
@ -2659,14 +2870,29 @@ void C_BaseAnimating::CalculateIKLocks( float currentTime )
|
|||||||
|
|
||||||
// debugoverlay->AddBoxOverlay( origin, Vector( -1, -1, -1 ), Vector( 1, 1, 1 ), QAngle( 0, 0, 0 ), 255, 0, 0, 0, 0 );
|
// debugoverlay->AddBoxOverlay( origin, Vector( -1, -1, -1 ), Vector( 1, 1, 1 ), QAngle( 0, 0, 0 ), 255, 0, 0, 0, 0 );
|
||||||
|
|
||||||
float d = (pTarget->est.pos - origin).Length();
|
Vector vecDelta = (origin - pTarget->est.pos);
|
||||||
|
float d = vecDelta.Length();
|
||||||
|
|
||||||
if ( d >= flDist)
|
if ( d >= flDist)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
flDist = d;
|
flDist = d;
|
||||||
pTarget->SetPos( origin );
|
#ifdef MAPBASE
|
||||||
pTarget->SetAngles( angles );
|
// For blending purposes, IK attachments should obey weight
|
||||||
|
if ( pTarget->est.flWeight < 1.0f )
|
||||||
|
{
|
||||||
|
Quaternion qTarget;
|
||||||
|
AngleQuaternion( angles, qTarget );
|
||||||
|
|
||||||
|
QuaternionSlerp( pTarget->est.q, qTarget, pTarget->est.flWeight, pTarget->est.q );
|
||||||
|
pTarget->SetPos( pTarget->est.pos + (vecDelta * pTarget->est.flWeight) );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
pTarget->SetPos( origin );
|
||||||
|
pTarget->SetAngles( angles );
|
||||||
|
}
|
||||||
// debugoverlay->AddBoxOverlay( pTarget->est.pos, Vector( -pTarget->est.radius, -pTarget->est.radius, -pTarget->est.radius ), Vector( pTarget->est.radius, pTarget->est.radius, pTarget->est.radius), QAngle( 0, 0, 0 ), 0, 255, 0, 0, 0 );
|
// debugoverlay->AddBoxOverlay( pTarget->est.pos, Vector( -pTarget->est.radius, -pTarget->est.radius, -pTarget->est.radius ), Vector( pTarget->est.radius, pTarget->est.radius, pTarget->est.radius), QAngle( 0, 0, 0 ), 0, 255, 0, 0, 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3611,7 +3837,11 @@ void C_BaseAnimating::DoAnimationEvents( CStudioHdr *pStudioHdr )
|
|||||||
flEventCycle,
|
flEventCycle,
|
||||||
gpGlobals->curtime );
|
gpGlobals->curtime );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
if (ScriptHookFireEvent( GetAbsOrigin(), GetAbsAngles(), pevent[ i ].event, pevent[ i ].pszOptions() ) == false)
|
||||||
|
continue;
|
||||||
|
#endif
|
||||||
|
|
||||||
FireEvent( GetAbsOrigin(), GetAbsAngles(), pevent[ i ].event, pevent[ i ].pszOptions() );
|
FireEvent( GetAbsOrigin(), GetAbsAngles(), pevent[ i ].event, pevent[ i ].pszOptions() );
|
||||||
}
|
}
|
||||||
@ -3644,6 +3874,11 @@ void C_BaseAnimating::DoAnimationEvents( CStudioHdr *pStudioHdr )
|
|||||||
gpGlobals->curtime );
|
gpGlobals->curtime );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
if (ScriptHookFireEvent( GetAbsOrigin(), GetAbsAngles(), pevent[ i ].event, pevent[ i ].pszOptions() ) == false)
|
||||||
|
continue;
|
||||||
|
#endif
|
||||||
|
|
||||||
FireEvent( GetAbsOrigin(), GetAbsAngles(), pevent[ i ].event, pevent[ i ].pszOptions() );
|
FireEvent( GetAbsOrigin(), GetAbsAngles(), pevent[ i ].event, pevent[ i ].pszOptions() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3651,6 +3886,26 @@ void C_BaseAnimating::DoAnimationEvents( CStudioHdr *pStudioHdr )
|
|||||||
m_flPrevEventCycle = flEventCycle;
|
m_flPrevEventCycle = flEventCycle;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
bool C_BaseAnimating::ScriptHookFireEvent( const Vector& origin, const QAngle& angles, int event, const char *options )
|
||||||
|
{
|
||||||
|
if (m_ScriptScope.IsInitialized() && g_Hook_FireEvent.CanRunInScope(m_ScriptScope))
|
||||||
|
{
|
||||||
|
// origin, angles, event, options
|
||||||
|
ScriptVariant_t args[] = { origin, angles, event, options };
|
||||||
|
ScriptVariant_t returnValue = true;
|
||||||
|
g_Hook_FireEvent.Call( m_ScriptScope, &returnValue, args );
|
||||||
|
|
||||||
|
return returnValue.m_bool;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose: Parses a muzzle effect event and sends it out for drawing
|
// Purpose: Parses a muzzle effect event and sends it out for drawing
|
||||||
// Input : *options - event parameters in text format
|
// Input : *options - event parameters in text format
|
||||||
@ -4716,12 +4971,18 @@ bool C_BaseAnimating::GetRagdollInitBoneArrays( matrix3x4_t *pDeltaBones0, matri
|
|||||||
return bSuccess;
|
return bSuccess;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
C_ClientRagdoll *C_BaseAnimating::CreateClientRagdoll( bool bRestoring )
|
||||||
|
{
|
||||||
|
//DevMsg( "Creating ragdoll at tick %d\n", gpGlobals->tickcount );
|
||||||
|
return new C_ClientRagdoll( bRestoring );
|
||||||
|
}
|
||||||
|
|
||||||
C_BaseAnimating *C_BaseAnimating::CreateRagdollCopy()
|
C_BaseAnimating *C_BaseAnimating::CreateRagdollCopy()
|
||||||
{
|
{
|
||||||
//Adrian: We now create a separate entity that becomes this entity's ragdoll.
|
//Adrian: We now create a separate entity that becomes this entity's ragdoll.
|
||||||
//That way the server side version of this entity can go away.
|
//That way the server side version of this entity can go away.
|
||||||
//Plus we can hook save/restore code to these ragdolls so they don't fall on restore anymore.
|
//Plus we can hook save/restore code to these ragdolls so they don't fall on restore anymore.
|
||||||
C_ClientRagdoll *pRagdoll = new C_ClientRagdoll( false );
|
C_ClientRagdoll *pRagdoll = CreateClientRagdoll( false );
|
||||||
if ( pRagdoll == NULL )
|
if ( pRagdoll == NULL )
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
@ -4789,9 +5050,9 @@ C_BaseAnimating *C_BaseAnimating::BecomeRagdollOnClient()
|
|||||||
{
|
{
|
||||||
MoveToLastReceivedPosition( true );
|
MoveToLastReceivedPosition( true );
|
||||||
GetAbsOrigin();
|
GetAbsOrigin();
|
||||||
|
m_pClientsideRagdoll = CreateRagdollCopy();
|
||||||
|
|
||||||
C_BaseAnimating *pRagdoll = CreateRagdollCopy();
|
if ( m_pClientsideRagdoll )
|
||||||
if ( pRagdoll )
|
|
||||||
{
|
{
|
||||||
matrix3x4_t boneDelta0[MAXSTUDIOBONES];
|
matrix3x4_t boneDelta0[MAXSTUDIOBONES];
|
||||||
matrix3x4_t boneDelta1[MAXSTUDIOBONES];
|
matrix3x4_t boneDelta1[MAXSTUDIOBONES];
|
||||||
@ -4803,19 +5064,29 @@ C_BaseAnimating *C_BaseAnimating::BecomeRagdollOnClient()
|
|||||||
|
|
||||||
if ( bInitBoneArrays )
|
if ( bInitBoneArrays )
|
||||||
{
|
{
|
||||||
bInitAsClient = pRagdoll->InitAsClientRagdoll( boneDelta0, boneDelta1, currentBones, boneDt );
|
bInitAsClient = m_pClientsideRagdoll->InitAsClientRagdoll( boneDelta0, boneDelta1, currentBones, boneDt );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( !bInitAsClient || !bInitBoneArrays )
|
if ( !bInitAsClient || !bInitBoneArrays )
|
||||||
{
|
{
|
||||||
Warning( "C_BaseAnimating::BecomeRagdollOnClient failed. pRagdoll:%p bInitBoneArrays:%d bInitAsClient:%d\n",
|
Warning( "C_BaseAnimating::BecomeRagdollOnClient failed. pRagdoll:%p bInitBoneArrays:%d bInitAsClient:%d\n",
|
||||||
pRagdoll, bInitBoneArrays, bInitAsClient );
|
m_pClientsideRagdoll, bInitBoneArrays, bInitAsClient );
|
||||||
pRagdoll->Release();
|
m_pClientsideRagdoll->Release();
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
// Hook for ragdolling
|
||||||
|
if (m_ScriptScope.IsInitialized() && g_Hook_OnClientRagdoll.CanRunInScope( m_ScriptScope ))
|
||||||
|
{
|
||||||
|
// ragdoll
|
||||||
|
ScriptVariant_t args[] = { ScriptVariant_t( m_pClientsideRagdoll->GetScriptInstance() ) };
|
||||||
|
g_Hook_OnClientRagdoll.Call( m_ScriptScope, NULL, args );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
return pRagdoll;
|
return m_pClientsideRagdoll;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool C_BaseAnimating::InitAsClientRagdoll( const matrix3x4_t *pDeltaBones0, const matrix3x4_t *pDeltaBones1, const matrix3x4_t *pCurrentBonePosition, float boneDt, bool bFixedConstraints )
|
bool C_BaseAnimating::InitAsClientRagdoll( const matrix3x4_t *pDeltaBones0, const matrix3x4_t *pDeltaBones1, const matrix3x4_t *pCurrentBonePosition, float boneDt, bool bFixedConstraints )
|
||||||
@ -5281,6 +5552,11 @@ void C_BaseAnimating::StudioFrameAdvance()
|
|||||||
|
|
||||||
if ( flNewCycle < 0.0f || flNewCycle >= 1.0f )
|
if ( flNewCycle < 0.0f || flNewCycle >= 1.0f )
|
||||||
{
|
{
|
||||||
|
if (flNewCycle >= 1.0f)
|
||||||
|
{
|
||||||
|
ReachedEndOfSequence();
|
||||||
|
}
|
||||||
|
|
||||||
if ( IsSequenceLooping( hdr, GetSequence() ) )
|
if ( IsSequenceLooping( hdr, GetSequence() ) )
|
||||||
{
|
{
|
||||||
flNewCycle -= (int)(flNewCycle);
|
flNewCycle -= (int)(flNewCycle);
|
||||||
|
@ -38,6 +38,7 @@ class C_BaseClientShader
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
class IRagdoll;
|
class IRagdoll;
|
||||||
|
class C_ClientRagdoll;
|
||||||
class CIKContext;
|
class CIKContext;
|
||||||
class CIKState;
|
class CIKState;
|
||||||
class ConVar;
|
class ConVar;
|
||||||
@ -79,7 +80,7 @@ public:
|
|||||||
QAngle m_angRotation;
|
QAngle m_angRotation;
|
||||||
Vector m_vOriginVelocity;
|
Vector m_vOriginVelocity;
|
||||||
int m_nLastFramecount : 31;
|
int m_nLastFramecount : 31;
|
||||||
int m_bAnglesComputed : 1;
|
bool m_bAnglesComputed : 1;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -164,6 +165,10 @@ public:
|
|||||||
virtual void FireObsoleteEvent( const Vector& origin, const QAngle& angles, int event, const char *options );
|
virtual void FireObsoleteEvent( const Vector& origin, const QAngle& angles, int event, const char *options );
|
||||||
virtual const char* ModifyEventParticles( const char* token ) { return token; }
|
virtual const char* ModifyEventParticles( const char* token ) { return token; }
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
bool ScriptHookFireEvent( const Vector& origin, const QAngle& angles, int event, const char *options );
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined ( SDK_DLL ) || defined ( HL2MP )
|
#if defined ( SDK_DLL ) || defined ( HL2MP )
|
||||||
virtual void ResetEventsParity() { m_nPrevResetEventsParity = -1; } // used to force animation events to function on players so the muzzleflashes and other events occur
|
virtual void ResetEventsParity() { m_nPrevResetEventsParity = -1; } // used to force animation events to function on players so the muzzleflashes and other events occur
|
||||||
// so new functions don't have to be made to parse the models like CSS does in ProcessMuzzleFlashEvent
|
// so new functions don't have to be made to parse the models like CSS does in ProcessMuzzleFlashEvent
|
||||||
@ -297,6 +302,7 @@ public:
|
|||||||
bool IsRagdoll() const;
|
bool IsRagdoll() const;
|
||||||
bool IsAboutToRagdoll() const;
|
bool IsAboutToRagdoll() const;
|
||||||
virtual C_BaseAnimating *BecomeRagdollOnClient();
|
virtual C_BaseAnimating *BecomeRagdollOnClient();
|
||||||
|
virtual C_ClientRagdoll *CreateClientRagdoll( bool bRestoring = false );
|
||||||
C_BaseAnimating *CreateRagdollCopy();
|
C_BaseAnimating *CreateRagdollCopy();
|
||||||
bool InitAsClientRagdoll( const matrix3x4_t *pDeltaBones0, const matrix3x4_t *pDeltaBones1, const matrix3x4_t *pCurrentBonePosition, float boneDt, bool bFixedConstraints=false );
|
bool InitAsClientRagdoll( const matrix3x4_t *pDeltaBones0, const matrix3x4_t *pDeltaBones1, const matrix3x4_t *pCurrentBonePosition, float boneDt, bool bFixedConstraints=false );
|
||||||
void IgniteRagdoll( C_BaseAnimating *pSource );
|
void IgniteRagdoll( C_BaseAnimating *pSource );
|
||||||
@ -350,6 +356,8 @@ public:
|
|||||||
void ClientSideAnimationChanged();
|
void ClientSideAnimationChanged();
|
||||||
virtual unsigned int ComputeClientSideAnimationFlags();
|
virtual unsigned int ComputeClientSideAnimationFlags();
|
||||||
|
|
||||||
|
virtual void ReachedEndOfSequence() { return; }
|
||||||
|
|
||||||
virtual void ResetClientsideFrame( void ) { SetCycle( 0 ); }
|
virtual void ResetClientsideFrame( void ) { SetCycle( 0 ); }
|
||||||
|
|
||||||
void SetCycle( float flCycle );
|
void SetCycle( float flCycle );
|
||||||
@ -456,6 +464,37 @@ public:
|
|||||||
virtual void UpdateOnRemove( void );
|
virtual void UpdateOnRemove( void );
|
||||||
|
|
||||||
#ifdef MAPBASE_VSCRIPT
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
int ScriptLookupAttachment( const char *pAttachmentName ) { return LookupAttachment( pAttachmentName ); }
|
||||||
|
const Vector& ScriptGetAttachmentOrigin(int iAttachment);
|
||||||
|
const Vector& ScriptGetAttachmentAngles(int iAttachment);
|
||||||
|
HSCRIPT ScriptGetAttachmentMatrix(int iAttachment);
|
||||||
|
|
||||||
|
void ScriptGetBoneTransform( int iBone, HSCRIPT hTransform );
|
||||||
|
void ScriptSetBoneTransform( int iBone, HSCRIPT hTransform );
|
||||||
|
|
||||||
|
void ScriptAttachEntityToBone( HSCRIPT attachTarget, int boneIndexAttached, const Vector &bonePosition, const QAngle &boneAngles );
|
||||||
|
void ScriptRemoveBoneAttachment( HSCRIPT boneAttachment );
|
||||||
|
HSCRIPT ScriptGetBoneAttachment( int i );
|
||||||
|
|
||||||
|
int ScriptGetSequenceActivity( int iSequence ) { return GetSequenceActivity( iSequence ); }
|
||||||
|
float ScriptGetSequenceMoveDist( int iSequence ) { return GetSequenceMoveDist( GetModelPtr(), iSequence ); }
|
||||||
|
int ScriptSelectWeightedSequence( int activity ) { return SelectWeightedSequence( (Activity)activity ); }
|
||||||
|
|
||||||
|
// For VScript
|
||||||
|
int ScriptGetSkin() { return GetSkin(); }
|
||||||
|
void SetSkin( int iSkin ) { m_nSkin = iSkin; }
|
||||||
|
|
||||||
|
int GetForceBone() { return m_nForceBone; }
|
||||||
|
void SetForceBone( int iBone ) { m_nForceBone = iBone; }
|
||||||
|
const Vector& GetRagdollForce() { return m_vecForce; }
|
||||||
|
void SetRagdollForce( const Vector &vecForce ) { m_vecForce = vecForce; }
|
||||||
|
|
||||||
|
HSCRIPT ScriptBecomeRagdollOnClient();
|
||||||
|
|
||||||
|
static ScriptHook_t g_Hook_OnClientRagdoll;
|
||||||
|
static ScriptHook_t g_Hook_FireEvent;
|
||||||
|
//static ScriptHook_t g_Hook_BuildTransformations; // UNDONE: Thread access issues
|
||||||
|
|
||||||
float ScriptGetPoseParameter(const char* szName);
|
float ScriptGetPoseParameter(const char* szName);
|
||||||
#endif
|
#endif
|
||||||
void ScriptSetPoseParameter(const char* szName, float fValue);
|
void ScriptSetPoseParameter(const char* szName, float fValue);
|
||||||
@ -477,10 +516,6 @@ protected:
|
|||||||
|
|
||||||
virtual bool CalcAttachments();
|
virtual bool CalcAttachments();
|
||||||
|
|
||||||
#ifdef MAPBASE_VSCRIPT
|
|
||||||
int ScriptGetSequenceActivity( int iSequence ) { return GetSequenceActivity( iSequence ); }
|
|
||||||
#endif
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// This method should return true if the bones have changed + SetupBones needs to be called
|
// This method should return true if the bones have changed + SetupBones needs to be called
|
||||||
virtual float LastBoneChangedTime() { return FLT_MAX; }
|
virtual float LastBoneChangedTime() { return FLT_MAX; }
|
||||||
@ -498,6 +533,10 @@ private:
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
CRagdoll *m_pRagdoll;
|
CRagdoll *m_pRagdoll;
|
||||||
|
C_BaseAnimating *m_pClientsideRagdoll; // From Alien Swarm SDK
|
||||||
|
#ifdef MAPBASE
|
||||||
|
C_BaseAnimating *m_pServerRagdoll; // Not from Alien Swarm SDK (note that this can exist without the entity having died)
|
||||||
|
#endif
|
||||||
|
|
||||||
// Texture group to use
|
// Texture group to use
|
||||||
int m_nSkin;
|
int m_nSkin;
|
||||||
@ -669,6 +708,9 @@ public:
|
|||||||
C_ClientRagdoll( bool bRestoring = true );
|
C_ClientRagdoll( bool bRestoring = true );
|
||||||
DECLARE_CLASS( C_ClientRagdoll, C_BaseAnimating );
|
DECLARE_CLASS( C_ClientRagdoll, C_BaseAnimating );
|
||||||
DECLARE_DATADESC();
|
DECLARE_DATADESC();
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
DECLARE_ENT_SCRIPTDESC();
|
||||||
|
#endif
|
||||||
|
|
||||||
// inherited from IPVSNotify
|
// inherited from IPVSNotify
|
||||||
virtual void OnPVSStatusChanged( bool bInPVS );
|
virtual void OnPVSStatusChanged( bool bInPVS );
|
||||||
@ -690,8 +732,17 @@ public:
|
|||||||
void FadeOut( void );
|
void FadeOut( void );
|
||||||
virtual float LastBoneChangedTime();
|
virtual float LastBoneChangedTime();
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
HSCRIPT ScriptGetRagdollObject( int iIndex );
|
||||||
|
int ScriptGetRagdollObjectCount();
|
||||||
|
#endif
|
||||||
|
|
||||||
bool m_bFadeOut;
|
bool m_bFadeOut;
|
||||||
bool m_bImportant;
|
bool m_bImportant;
|
||||||
|
#ifdef MAPBASE
|
||||||
|
// Required to save/restore Alien Swarm SDK ragdoll LRU forced fade
|
||||||
|
float m_flForcedRetireTime;
|
||||||
|
#endif
|
||||||
float m_flEffectTime;
|
float m_flEffectTime;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -195,3 +195,39 @@ BEGIN_PREDICTION_DATA( C_BaseCombatCharacter )
|
|||||||
DEFINE_PRED_ARRAY( m_hMyWeapons, FIELD_EHANDLE, MAX_WEAPONS, FTYPEDESC_INSENDTABLE ),
|
DEFINE_PRED_ARRAY( m_hMyWeapons, FIELD_EHANDLE, MAX_WEAPONS, FTYPEDESC_INSENDTABLE ),
|
||||||
|
|
||||||
END_PREDICTION_DATA()
|
END_PREDICTION_DATA()
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
|
||||||
|
BEGIN_ENT_SCRIPTDESC( C_BaseCombatCharacter, CBaseEntity, "" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetAmmoCount, "GetAmmoCount", "" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetActiveWeapon, "GetActiveWeapon", "" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetWeapon, "GetWeapon", "" )
|
||||||
|
END_SCRIPTDESC();
|
||||||
|
|
||||||
|
|
||||||
|
int C_BaseCombatCharacter::ScriptGetAmmoCount( int i )
|
||||||
|
{
|
||||||
|
Assert( i == -1 || i < MAX_AMMO_SLOTS );
|
||||||
|
|
||||||
|
if ( i < 0 || i >= MAX_AMMO_SLOTS )
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
return GetAmmoCount( i );
|
||||||
|
}
|
||||||
|
|
||||||
|
HSCRIPT C_BaseCombatCharacter::ScriptGetActiveWeapon()
|
||||||
|
{
|
||||||
|
return ToHScript( GetActiveWeapon() );
|
||||||
|
}
|
||||||
|
|
||||||
|
HSCRIPT C_BaseCombatCharacter::ScriptGetWeapon( int i )
|
||||||
|
{
|
||||||
|
Assert( i >= 0 && i < MAX_WEAPONS );
|
||||||
|
|
||||||
|
if ( i < 0 || i >= MAX_WEAPONS )
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
return ToHScript( GetWeapon(i) );
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
@ -29,6 +29,9 @@ class C_BaseCombatCharacter : public C_BaseFlex
|
|||||||
public:
|
public:
|
||||||
DECLARE_CLIENTCLASS();
|
DECLARE_CLIENTCLASS();
|
||||||
DECLARE_PREDICTABLE();
|
DECLARE_PREDICTABLE();
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
DECLARE_ENT_SCRIPTDESC();
|
||||||
|
#endif
|
||||||
|
|
||||||
C_BaseCombatCharacter( void );
|
C_BaseCombatCharacter( void );
|
||||||
virtual ~C_BaseCombatCharacter( void );
|
virtual ~C_BaseCombatCharacter( void );
|
||||||
@ -103,6 +106,12 @@ public:
|
|||||||
bool IsClientSideGlowEnabled( void ){ return m_bClientSideGlowEnabled; }
|
bool IsClientSideGlowEnabled( void ){ return m_bClientSideGlowEnabled; }
|
||||||
#endif // GLOWS_ENABLE
|
#endif // GLOWS_ENABLE
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
int ScriptGetAmmoCount( int i );
|
||||||
|
HSCRIPT ScriptGetActiveWeapon();
|
||||||
|
HSCRIPT ScriptGetWeapon( int i );
|
||||||
|
#endif
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
float m_flNextAttack;
|
float m_flNextAttack;
|
||||||
|
@ -125,9 +125,15 @@ void C_BaseCombatWeapon::OnRestore()
|
|||||||
|
|
||||||
int C_BaseCombatWeapon::GetWorldModelIndex( void )
|
int C_BaseCombatWeapon::GetWorldModelIndex( void )
|
||||||
{
|
{
|
||||||
|
#ifdef MAPBASE
|
||||||
|
int iIndex = GetOwner() ? m_iWorldModelIndex.Get() : m_iDroppedModelIndex.Get();
|
||||||
|
#else
|
||||||
|
int iIndex = m_iWorldModelIndex.Get();
|
||||||
|
#endif
|
||||||
|
|
||||||
if ( GameRules() )
|
if ( GameRules() )
|
||||||
{
|
{
|
||||||
const char *pBaseName = modelinfo->GetModelName( modelinfo->GetModel( m_iWorldModelIndex ) );
|
const char *pBaseName = modelinfo->GetModelName( modelinfo->GetModel( iIndex ) );
|
||||||
const char *pTranslatedName = GameRules()->TranslateEffectForVisionFilter( "weapons", pBaseName );
|
const char *pTranslatedName = GameRules()->TranslateEffectForVisionFilter( "weapons", pBaseName );
|
||||||
|
|
||||||
if ( pTranslatedName != pBaseName )
|
if ( pTranslatedName != pBaseName )
|
||||||
@ -136,7 +142,7 @@ int C_BaseCombatWeapon::GetWorldModelIndex( void )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return m_iWorldModelIndex;
|
return iIndex;
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -505,25 +511,44 @@ int C_BaseCombatWeapon::DrawModel( int flags )
|
|||||||
// check if local player chases owner of this weapon in first person
|
// check if local player chases owner of this weapon in first person
|
||||||
C_BasePlayer *localplayer = C_BasePlayer::GetLocalPlayer();
|
C_BasePlayer *localplayer = C_BasePlayer::GetLocalPlayer();
|
||||||
|
|
||||||
if ( localplayer && localplayer->IsObserver() && GetOwner() )
|
if ( localplayer )
|
||||||
{
|
{
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
if (localplayer->m_bDrawPlayerModelExternally)
|
if (localplayer->m_bDrawPlayerModelExternally)
|
||||||
{
|
{
|
||||||
// If this isn't the main view, draw the weapon.
|
// If this isn't the main view, draw the weapon.
|
||||||
view_id_t viewID = CurrentViewID();
|
view_id_t viewID = CurrentViewID();
|
||||||
if (viewID != VIEW_MAIN && viewID != VIEW_INTRO_CAMERA)
|
if ( (!localplayer->InFirstPersonView() || (viewID != VIEW_MAIN && viewID != VIEW_INTRO_CAMERA)) && (viewID != VIEW_SHADOW_DEPTH_TEXTURE || !localplayer->IsEffectActive(EF_DIMLIGHT)) )
|
||||||
return BaseClass::DrawModel( flags );
|
{
|
||||||
|
// TODO: Is this inefficient?
|
||||||
|
int nModelIndex = GetModelIndex();
|
||||||
|
int nWorldModelIndex = GetWorldModelIndex();
|
||||||
|
if (nModelIndex != nWorldModelIndex)
|
||||||
|
{
|
||||||
|
SetModelIndex(nWorldModelIndex);
|
||||||
|
}
|
||||||
|
|
||||||
|
int iDraw = BaseClass::DrawModel(flags);
|
||||||
|
|
||||||
|
if (nModelIndex != nWorldModelIndex)
|
||||||
|
{
|
||||||
|
SetModelIndex(nModelIndex);
|
||||||
|
}
|
||||||
|
|
||||||
|
return iDraw;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
if ( localplayer->IsObserver() && GetOwner() )
|
||||||
// don't draw weapon if chasing this guy as spectator
|
{
|
||||||
// we don't check that in ShouldDraw() since this may change
|
// don't draw weapon if chasing this guy as spectator
|
||||||
// without notification
|
// we don't check that in ShouldDraw() since this may change
|
||||||
|
// without notification
|
||||||
|
|
||||||
if ( localplayer->GetObserverMode() == OBS_MODE_IN_EYE &&
|
if ( localplayer->GetObserverMode() == OBS_MODE_IN_EYE &&
|
||||||
localplayer->GetObserverTarget() == GetOwner() )
|
localplayer->GetObserverTarget() == GetOwner() )
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return BaseClass::DrawModel( flags );
|
return BaseClass::DrawModel( flags );
|
||||||
|
@ -434,7 +434,13 @@ BEGIN_RECV_TABLE_NOBASE( C_BaseEntity, DT_AnimTimeMustBeFirst )
|
|||||||
RecvPropInt( RECVINFO(m_flAnimTime), 0, RecvProxy_AnimTime ),
|
RecvPropInt( RECVINFO(m_flAnimTime), 0, RecvProxy_AnimTime ),
|
||||||
END_RECV_TABLE()
|
END_RECV_TABLE()
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
ScriptHook_t C_BaseEntity::g_Hook_UpdateOnRemove;
|
||||||
|
ScriptHook_t C_BaseEntity::g_Hook_ModifyEmitSoundParams;
|
||||||
|
#endif
|
||||||
|
|
||||||
BEGIN_ENT_SCRIPTDESC_ROOT( C_BaseEntity, "Root class of all client-side entities" )
|
BEGIN_ENT_SCRIPTDESC_ROOT( C_BaseEntity, "Root class of all client-side entities" )
|
||||||
|
DEFINE_SCRIPT_INSTANCE_HELPER( &g_BaseEntityScriptInstanceHelper )
|
||||||
DEFINE_SCRIPTFUNC_NAMED( GetAbsOrigin, "GetOrigin", "" )
|
DEFINE_SCRIPTFUNC_NAMED( GetAbsOrigin, "GetOrigin", "" )
|
||||||
DEFINE_SCRIPTFUNC_NAMED( ScriptGetForward, "GetForwardVector", "Get the forward vector of the entity" )
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetForward, "GetForwardVector", "Get the forward vector of the entity" )
|
||||||
#ifdef MAPBASE_VSCRIPT
|
#ifdef MAPBASE_VSCRIPT
|
||||||
@ -448,6 +454,7 @@ BEGIN_ENT_SCRIPTDESC_ROOT( C_BaseEntity, "Root class of all client-side entities
|
|||||||
|
|
||||||
#ifdef MAPBASE_VSCRIPT
|
#ifdef MAPBASE_VSCRIPT
|
||||||
DEFINE_SCRIPTFUNC( ValidateScriptScope, "Ensure that an entity's script scope has been created" )
|
DEFINE_SCRIPTFUNC( ValidateScriptScope, "Ensure that an entity's script scope has been created" )
|
||||||
|
DEFINE_SCRIPTFUNC( GetOrCreatePrivateScriptScope, "Create and retrieve the script-side data associated with an entity" )
|
||||||
DEFINE_SCRIPTFUNC( GetScriptScope, "Retrieve the script-side data associated with an entity" )
|
DEFINE_SCRIPTFUNC( GetScriptScope, "Retrieve the script-side data associated with an entity" )
|
||||||
|
|
||||||
DEFINE_SCRIPTFUNC( GetHealth, "" )
|
DEFINE_SCRIPTFUNC( GetHealth, "" )
|
||||||
@ -455,6 +462,7 @@ BEGIN_ENT_SCRIPTDESC_ROOT( C_BaseEntity, "Root class of all client-side entities
|
|||||||
|
|
||||||
DEFINE_SCRIPTFUNC_NAMED( ScriptGetModelName, "GetModelName", "Returns the name of the model" )
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetModelName, "GetModelName", "Returns the name of the model" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptStopSound, "StopSound", "Stops a sound from this entity." )
|
||||||
DEFINE_SCRIPTFUNC_NAMED( ScriptEmitSound, "EmitSound", "Plays a sound from this entity." )
|
DEFINE_SCRIPTFUNC_NAMED( ScriptEmitSound, "EmitSound", "Plays a sound from this entity." )
|
||||||
DEFINE_SCRIPTFUNC_NAMED( VScriptPrecacheScriptSound, "PrecacheSoundScript", "Precache a sound for later playing." )
|
DEFINE_SCRIPTFUNC_NAMED( VScriptPrecacheScriptSound, "PrecacheSoundScript", "Precache a sound for later playing." )
|
||||||
DEFINE_SCRIPTFUNC_NAMED( ScriptSoundDuration, "GetSoundDuration", "Returns float duration of the sound. Takes soundname and optional actormodelname." )
|
DEFINE_SCRIPTFUNC_NAMED( ScriptSoundDuration, "GetSoundDuration", "Returns float duration of the sound. Takes soundname and optional actormodelname." )
|
||||||
@ -462,23 +470,106 @@ BEGIN_ENT_SCRIPTDESC_ROOT( C_BaseEntity, "Root class of all client-side entities
|
|||||||
DEFINE_SCRIPTFUNC( GetClassname, "" )
|
DEFINE_SCRIPTFUNC( GetClassname, "" )
|
||||||
DEFINE_SCRIPTFUNC_NAMED( GetEntityName, "GetName", "" )
|
DEFINE_SCRIPTFUNC_NAMED( GetEntityName, "GetName", "" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( SetAbsOrigin, "SetOrigin", "" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptSetForward, "SetForwardVector", "Set the orientation of the entity to have this forward vector" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( GetLocalOrigin, "GetLocalOrigin" )
|
||||||
|
DEFINE_SCRIPTFUNC( SetLocalOrigin, "SetLocalOrigin" )
|
||||||
|
DEFINE_SCRIPTFUNC( GetLocalAngles, "GetLocalAngles" )
|
||||||
|
DEFINE_SCRIPTFUNC( SetLocalAngles, "SetLocalAngles" )
|
||||||
|
|
||||||
DEFINE_SCRIPTFUNC_NAMED( WorldSpaceCenter, "GetCenter", "Get vector to center of object - absolute coords" )
|
DEFINE_SCRIPTFUNC_NAMED( WorldSpaceCenter, "GetCenter", "Get vector to center of object - absolute coords" )
|
||||||
DEFINE_SCRIPTFUNC_NAMED( ScriptEyePosition, "EyePosition", "Get vector to eye position - absolute coords" )
|
DEFINE_SCRIPTFUNC_NAMED( ScriptEyePosition, "EyePosition", "Get vector to eye position - absolute coords" )
|
||||||
DEFINE_SCRIPTFUNC_NAMED( ScriptGetAngles, "GetAngles", "Get entity pitch, yaw, roll as a vector" )
|
DEFINE_SCRIPTFUNC_NAMED( ScriptEyeAngles, "EyeAngles", "Get eye pitch, yaw, roll as a vector" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( GetAbsAngles, "GetAngles", "Get entity pitch, yaw, roll as a vector" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( SetAbsAngles, "SetAngles", "Set entity pitch, yaw, roll" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( SetSize, "" )
|
||||||
DEFINE_SCRIPTFUNC_NAMED( ScriptGetBoundingMins, "GetBoundingMins", "Get a vector containing min bounds, centered on object" )
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetBoundingMins, "GetBoundingMins", "Get a vector containing min bounds, centered on object" )
|
||||||
DEFINE_SCRIPTFUNC_NAMED( ScriptGetBoundingMaxs, "GetBoundingMaxs", "Get a vector containing max bounds, centered on object" )
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetBoundingMaxs, "GetBoundingMaxs", "Get a vector containing max bounds, centered on object" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptEntityToWorldTransform, "EntityToWorldTransform", "Get the entity's transform" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetPhysicsObject, "GetPhysicsObject", "Get the entity's physics object if it has one" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( GetWaterLevel, "Get current level of water submergence" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptSetParent, "SetParent", "" )
|
||||||
DEFINE_SCRIPTFUNC_NAMED( ScriptGetMoveParent, "GetMoveParent", "If in hierarchy, retrieves the entity's parent" )
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetMoveParent, "GetMoveParent", "If in hierarchy, retrieves the entity's parent" )
|
||||||
DEFINE_SCRIPTFUNC_NAMED( ScriptGetRootMoveParent, "GetRootMoveParent", "If in hierarchy, walks up the hierarchy to find the root parent" )
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetRootMoveParent, "GetRootMoveParent", "If in hierarchy, walks up the hierarchy to find the root parent" )
|
||||||
DEFINE_SCRIPTFUNC_NAMED( ScriptFirstMoveChild, "FirstMoveChild", "" )
|
DEFINE_SCRIPTFUNC_NAMED( ScriptFirstMoveChild, "FirstMoveChild", "" )
|
||||||
DEFINE_SCRIPTFUNC_NAMED( ScriptNextMovePeer, "NextMovePeer", "" )
|
DEFINE_SCRIPTFUNC_NAMED( ScriptNextMovePeer, "NextMovePeer", "" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptFollowEntity, "FollowEntity", "Begin following the specified entity. This makes this entity non-solid, parents it to the target entity, and teleports it to the specified entity's origin. The second parameter is whether or not to use bonemerging while following." )
|
||||||
|
DEFINE_SCRIPTFUNC( StopFollowingEntity, "Stops following an entity if we're following one." )
|
||||||
|
DEFINE_SCRIPTFUNC( IsFollowingEntity, "Returns true if this entity is following another entity." )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetFollowedEntity, "GetFollowedEntity", "Get the entity we're following." )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( GetScriptOwnerEntity, "GetOwner", "Gets this entity's owner" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( SetScriptOwnerEntity, "SetOwner", "Sets this entity's owner" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetColorVector, "GetRenderColorVector", "Get the render color as a vector" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetColorR, "GetRenderColorR", "Get the render color's R value" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetColorG, "GetRenderColorG", "Get the render color's G value" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetColorB, "GetRenderColorB", "Get the render color's B value" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetAlpha, "GetRenderAlpha", "Get the render color's alpha value" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptSetColorVector, "SetRenderColorVector", "Set the render color as a vector" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptSetColor, "SetRenderColor", "Set the render color" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptSetColorR, "SetRenderColorR", "Set the render color's R value" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptSetColorG, "SetRenderColorG", "Set the render color's G value" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptSetColorB, "SetRenderColorB", "Set the render color's B value" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptSetAlpha, "SetRenderAlpha", "Set the render color's alpha value" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetRenderMode, "GetRenderMode", "Get render mode" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptSetRenderMode, "SetRenderMode", "Set render mode" )
|
||||||
|
|
||||||
DEFINE_SCRIPTFUNC( GetEffects, "Get effects" )
|
DEFINE_SCRIPTFUNC( GetEffects, "Get effects" )
|
||||||
|
DEFINE_SCRIPTFUNC( AddEffects, "Add effect(s)" )
|
||||||
|
DEFINE_SCRIPTFUNC( RemoveEffects, "Remove effect(s)" )
|
||||||
|
DEFINE_SCRIPTFUNC( ClearEffects, "Clear effect(s)" )
|
||||||
|
DEFINE_SCRIPTFUNC( SetEffects, "Set effect(s)" )
|
||||||
DEFINE_SCRIPTFUNC( IsEffectActive, "Check if an effect is active" )
|
DEFINE_SCRIPTFUNC( IsEffectActive, "Check if an effect is active" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( GetFlags, "Get flags" )
|
||||||
|
DEFINE_SCRIPTFUNC( AddFlag, "Add flag" )
|
||||||
|
DEFINE_SCRIPTFUNC( RemoveFlag, "Remove flag" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( GetEFlags, "Get Eflags" )
|
||||||
|
DEFINE_SCRIPTFUNC( AddEFlags, "Add Eflags" )
|
||||||
|
DEFINE_SCRIPTFUNC( RemoveEFlags, "Remove Eflags" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetMoveType, "GetMoveType", "Get the move type" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptSetMoveType, "SetMoveType", "Set the move type" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( GetCollisionGroup, "Get the collision group" )
|
||||||
|
DEFINE_SCRIPTFUNC( SetCollisionGroup, "Set the collision group" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( GetSolidFlags, "Get solid flags" )
|
||||||
|
DEFINE_SCRIPTFUNC( AddSolidFlags, "Add solid flags" )
|
||||||
|
DEFINE_SCRIPTFUNC( RemoveSolidFlags, "Remove solid flags" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( IsPlayer, "Returns true if this entity is a player." )
|
||||||
|
DEFINE_SCRIPTFUNC( IsNPC, "Returns true if this entity is a NPC." )
|
||||||
|
//DEFINE_SCRIPTFUNC( IsCombatCharacter, "Returns true if this entity is a combat character (player or NPC)." )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( IsBaseCombatWeapon, "IsWeapon", "Returns true if this entity is a weapon." )
|
||||||
|
DEFINE_SCRIPTFUNC( IsWorld, "Returns true if this entity is the world." )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( SetModel, "Set client-only entity model" )
|
||||||
|
//DEFINE_SCRIPTFUNC_NAMED( ScriptInitializeAsClientEntity, "InitializeAsClientEntity", "" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( Remove, "Destroy", "Remove clientside entity" )
|
||||||
DEFINE_SCRIPTFUNC_NAMED( GetEntityIndex, "entindex", "" )
|
DEFINE_SCRIPTFUNC_NAMED( GetEntityIndex, "entindex", "" )
|
||||||
#endif
|
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptSetContextThink, "SetContextThink", "Set a think function on this entity." )
|
||||||
|
|
||||||
|
|
||||||
|
DEFINE_SIMPLE_SCRIPTHOOK( C_BaseEntity::g_Hook_UpdateOnRemove, "UpdateOnRemove", FIELD_VOID, "Called when the entity is being removed." )
|
||||||
|
|
||||||
|
BEGIN_SCRIPTHOOK( C_BaseEntity::g_Hook_ModifyEmitSoundParams, "ModifyEmitSoundParams", FIELD_VOID, "Called every time a sound is emitted on this entity, allowing for its parameters to be modified." )
|
||||||
|
DEFINE_SCRIPTHOOK_PARAM( "params", FIELD_HSCRIPT )
|
||||||
|
END_SCRIPTHOOK()
|
||||||
|
|
||||||
|
#endif // MAPBASE_VSCRIPT
|
||||||
|
|
||||||
END_SCRIPTDESC();
|
END_SCRIPTDESC();
|
||||||
|
|
||||||
#ifndef NO_ENTITY_PREDICTION
|
#ifndef NO_ENTITY_PREDICTION
|
||||||
@ -513,6 +604,7 @@ BEGIN_RECV_TABLE_NOBASE(C_BaseEntity, DT_BaseEntity)
|
|||||||
RecvPropInt(RECVINFO(m_clrRender)),
|
RecvPropInt(RECVINFO(m_clrRender)),
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
RecvPropInt(RECVINFO(m_iViewHideFlags)),
|
RecvPropInt(RECVINFO(m_iViewHideFlags)),
|
||||||
|
RecvPropBool(RECVINFO(m_bDisableFlashlight)),
|
||||||
#endif
|
#endif
|
||||||
RecvPropInt(RECVINFO(m_iTeamNum)),
|
RecvPropInt(RECVINFO(m_iTeamNum)),
|
||||||
RecvPropInt(RECVINFO(m_CollisionGroup)),
|
RecvPropInt(RECVINFO(m_CollisionGroup)),
|
||||||
@ -1278,8 +1370,23 @@ void C_BaseEntity::Term()
|
|||||||
|
|
||||||
if ( m_hScriptInstance )
|
if ( m_hScriptInstance )
|
||||||
{
|
{
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
if ( m_ScriptScope.IsInitialized() && g_Hook_UpdateOnRemove.CanRunInScope( m_ScriptScope ) )
|
||||||
|
{
|
||||||
|
g_Hook_UpdateOnRemove.Call( m_ScriptScope, NULL, NULL );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
g_pScriptVM->RemoveInstance( m_hScriptInstance );
|
g_pScriptVM->RemoveInstance( m_hScriptInstance );
|
||||||
m_hScriptInstance = NULL;
|
m_hScriptInstance = NULL;
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
FOR_EACH_VEC( m_ScriptThinkFuncs, i )
|
||||||
|
{
|
||||||
|
HSCRIPT h = m_ScriptThinkFuncs[i]->m_hfnThink;
|
||||||
|
if ( h ) g_pScriptVM->ReleaseScript( h );
|
||||||
|
}
|
||||||
|
m_ScriptThinkFuncs.PurgeAndDeleteElements();
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1617,6 +1724,11 @@ bool C_BaseEntity::ShouldReceiveProjectedTextures( int flags )
|
|||||||
if ( IsEffectActive( EF_NODRAW ) )
|
if ( IsEffectActive( EF_NODRAW ) )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if ( m_bDisableFlashlight )
|
||||||
|
return false;
|
||||||
|
#endif
|
||||||
|
|
||||||
if( flags & SHADOW_FLAGS_FLASHLIGHT )
|
if( flags & SHADOW_FLAGS_FLASHLIGHT )
|
||||||
{
|
{
|
||||||
if ( GetRenderMode() > kRenderNormal && GetRenderColor().a == 0 )
|
if ( GetRenderMode() > kRenderNormal && GetRenderColor().a == 0 )
|
||||||
@ -4835,9 +4947,15 @@ C_BaseEntity *C_BaseEntity::Instance( int iEnt )
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
|
|
||||||
|
#if _MSC_VER < 1900
|
||||||
#pragma warning( push )
|
#pragma warning( push )
|
||||||
#include <typeinfo.h>
|
#include <typeinfo.h>
|
||||||
#pragma warning( pop )
|
#pragma warning( pop )
|
||||||
|
#else
|
||||||
|
#include <typeinfo>
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -6075,6 +6193,9 @@ BEGIN_DATADESC_NO_BASE( C_BaseEntity )
|
|||||||
DEFINE_FIELD( m_angAbsRotation, FIELD_VECTOR ),
|
DEFINE_FIELD( m_angAbsRotation, FIELD_VECTOR ),
|
||||||
DEFINE_ARRAY( m_rgflCoordinateFrame, FIELD_FLOAT, 12 ), // NOTE: MUST BE IN LOCAL SPACE, NOT POSITION_VECTOR!!! (see CBaseEntity::Restore)
|
DEFINE_ARRAY( m_rgflCoordinateFrame, FIELD_FLOAT, 12 ), // NOTE: MUST BE IN LOCAL SPACE, NOT POSITION_VECTOR!!! (see CBaseEntity::Restore)
|
||||||
DEFINE_FIELD( m_fFlags, FIELD_INTEGER ),
|
DEFINE_FIELD( m_fFlags, FIELD_INTEGER ),
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
DEFINE_FIELD( m_iszScriptId, FIELD_STRING ),
|
||||||
|
#endif
|
||||||
END_DATADESC()
|
END_DATADESC()
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
@ -162,6 +162,15 @@ struct thinkfunc_t
|
|||||||
int m_nLastThinkTick;
|
int m_nLastThinkTick;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
struct scriptthinkfunc_t
|
||||||
|
{
|
||||||
|
float m_flNextThink;
|
||||||
|
HSCRIPT m_hfnThink;
|
||||||
|
unsigned m_iContextHash;
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
#define CREATE_PREDICTED_ENTITY( className ) \
|
#define CREATE_PREDICTED_ENTITY( className ) \
|
||||||
C_BaseEntity::CreatePredictedEntityByName( className, __FILE__, __LINE__ );
|
C_BaseEntity::CreatePredictedEntityByName( className, __FILE__, __LINE__ );
|
||||||
|
|
||||||
@ -267,6 +276,7 @@ public:
|
|||||||
bool ValidateScriptScope();
|
bool ValidateScriptScope();
|
||||||
bool CallScriptFunction( const char* pFunctionName, ScriptVariant_t* pFunctionReturn );
|
bool CallScriptFunction( const char* pFunctionName, ScriptVariant_t* pFunctionReturn );
|
||||||
|
|
||||||
|
HSCRIPT GetOrCreatePrivateScriptScope();
|
||||||
HSCRIPT GetScriptScope() { return m_ScriptScope; }
|
HSCRIPT GetScriptScope() { return m_ScriptScope; }
|
||||||
|
|
||||||
HSCRIPT LookupScriptFunction(const char* pFunctionName);
|
HSCRIPT LookupScriptFunction(const char* pFunctionName);
|
||||||
@ -276,12 +286,18 @@ public:
|
|||||||
bool RunScript( const char* pScriptText, const char* pDebugFilename = "C_BaseEntity::RunScript" );
|
bool RunScript( const char* pScriptText, const char* pDebugFilename = "C_BaseEntity::RunScript" );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
HSCRIPT GetScriptOwnerEntity();
|
||||||
|
virtual void SetScriptOwnerEntity(HSCRIPT pOwner);
|
||||||
|
|
||||||
HSCRIPT GetScriptInstance();
|
HSCRIPT GetScriptInstance();
|
||||||
|
|
||||||
HSCRIPT m_hScriptInstance;
|
HSCRIPT m_hScriptInstance;
|
||||||
string_t m_iszScriptId;
|
string_t m_iszScriptId;
|
||||||
#ifdef MAPBASE_VSCRIPT
|
#ifdef MAPBASE_VSCRIPT
|
||||||
CScriptScope m_ScriptScope;
|
CScriptScope m_ScriptScope;
|
||||||
|
|
||||||
|
static ScriptHook_t g_Hook_UpdateOnRemove;
|
||||||
|
static ScriptHook_t g_Hook_ModifyEmitSoundParams;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// IClientUnknown overrides.
|
// IClientUnknown overrides.
|
||||||
@ -388,7 +404,7 @@ public:
|
|||||||
|
|
||||||
#ifdef MAPBASE_VSCRIPT
|
#ifdef MAPBASE_VSCRIPT
|
||||||
// "I don't know why but wrapping entindex() works, while calling it directly crashes."
|
// "I don't know why but wrapping entindex() works, while calling it directly crashes."
|
||||||
inline int C_BaseEntity::GetEntityIndex() const { return entindex(); }
|
inline int GetEntityIndex() const { return entindex(); }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// This works for client-only entities and returns the GetEntryIndex() of the entity's handle,
|
// This works for client-only entities and returns the GetEntryIndex() of the entity's handle,
|
||||||
@ -1153,6 +1169,11 @@ public:
|
|||||||
bool IsFollowingEntity();
|
bool IsFollowingEntity();
|
||||||
CBaseEntity *GetFollowedEntity();
|
CBaseEntity *GetFollowedEntity();
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
void ScriptFollowEntity( HSCRIPT hBaseEntity, bool bBoneMerge );
|
||||||
|
HSCRIPT ScriptGetFollowedEntity();
|
||||||
|
#endif
|
||||||
|
|
||||||
// For shadows rendering the correct body + sequence...
|
// For shadows rendering the correct body + sequence...
|
||||||
virtual int GetBody() { return 0; }
|
virtual int GetBody() { return 0; }
|
||||||
virtual int GetSkin() { return 0; }
|
virtual int GetSkin() { return 0; }
|
||||||
@ -1168,21 +1189,46 @@ public:
|
|||||||
#ifdef MAPBASE_VSCRIPT
|
#ifdef MAPBASE_VSCRIPT
|
||||||
const char* ScriptGetModelName( void ) const { return STRING(GetModelName()); }
|
const char* ScriptGetModelName( void ) const { return STRING(GetModelName()); }
|
||||||
|
|
||||||
|
void ScriptStopSound(const char* soundname);
|
||||||
void ScriptEmitSound(const char* soundname);
|
void ScriptEmitSound(const char* soundname);
|
||||||
float ScriptSoundDuration(const char* soundname, const char* actormodel);
|
float ScriptSoundDuration(const char* soundname, const char* actormodel);
|
||||||
|
|
||||||
void VScriptPrecacheScriptSound(const char* soundname);
|
void VScriptPrecacheScriptSound(const char* soundname);
|
||||||
|
|
||||||
const Vector& ScriptEyePosition(void) { static Vector vec; vec = EyePosition(); return vec; }
|
const Vector& ScriptEyePosition(void) { static Vector vec; vec = EyePosition(); return vec; }
|
||||||
const Vector& ScriptGetAngles(void) { static Vector vec; QAngle qa = GetAbsAngles(); vec.x = qa.x; vec.y = qa.y; vec.z = qa.z; return vec; }
|
const QAngle& ScriptEyeAngles(void) { static QAngle ang; ang = EyeAngles(); return ang; }
|
||||||
|
void ScriptSetForward( const Vector& v ) { QAngle angles; VectorAngles( v, angles ); SetAbsAngles( angles ); }
|
||||||
|
|
||||||
const Vector& ScriptGetBoundingMins( void ) { return m_Collision.OBBMins(); }
|
const Vector& ScriptGetBoundingMins( void ) { return m_Collision.OBBMins(); }
|
||||||
const Vector& ScriptGetBoundingMaxs( void ) { return m_Collision.OBBMaxs(); }
|
const Vector& ScriptGetBoundingMaxs( void ) { return m_Collision.OBBMaxs(); }
|
||||||
|
|
||||||
|
HSCRIPT ScriptEntityToWorldTransform( void );
|
||||||
|
|
||||||
|
HSCRIPT ScriptGetPhysicsObject( void );
|
||||||
|
|
||||||
|
void ScriptSetParent( HSCRIPT hParent, const char *szAttachment );
|
||||||
HSCRIPT ScriptGetMoveParent( void );
|
HSCRIPT ScriptGetMoveParent( void );
|
||||||
HSCRIPT ScriptGetRootMoveParent();
|
HSCRIPT ScriptGetRootMoveParent();
|
||||||
HSCRIPT ScriptFirstMoveChild( void );
|
HSCRIPT ScriptFirstMoveChild( void );
|
||||||
HSCRIPT ScriptNextMovePeer( void );
|
HSCRIPT ScriptNextMovePeer( void );
|
||||||
|
|
||||||
|
const Vector& ScriptGetColorVector();
|
||||||
|
int ScriptGetColorR() { return m_clrRender.GetR(); }
|
||||||
|
int ScriptGetColorG() { return m_clrRender.GetG(); }
|
||||||
|
int ScriptGetColorB() { return m_clrRender.GetB(); }
|
||||||
|
int ScriptGetAlpha() { return m_clrRender.GetA(); }
|
||||||
|
void ScriptSetColorVector( const Vector& vecColor );
|
||||||
|
void ScriptSetColor( int r, int g, int b );
|
||||||
|
void ScriptSetColorR( int iVal ) { SetRenderColorR( iVal ); }
|
||||||
|
void ScriptSetColorG( int iVal ) { SetRenderColorG( iVal ); }
|
||||||
|
void ScriptSetColorB( int iVal ) { SetRenderColorB( iVal ); }
|
||||||
|
void ScriptSetAlpha( int iVal ) { SetRenderColorA( iVal ); }
|
||||||
|
|
||||||
|
int ScriptGetRenderMode() { return GetRenderMode(); }
|
||||||
|
void ScriptSetRenderMode( int nRenderMode ) { SetRenderMode( (RenderMode_t)nRenderMode ); }
|
||||||
|
|
||||||
|
int ScriptGetMoveType() { return GetMoveType(); }
|
||||||
|
void ScriptSetMoveType( int iMoveType ) { SetMoveType( (MoveType_t)iMoveType ); }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Stubs on client
|
// Stubs on client
|
||||||
@ -1222,7 +1268,7 @@ public:
|
|||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
void FunctionCheck( void *pFunction, const char *name );
|
void FunctionCheck( void *pFunction, const char *name );
|
||||||
|
|
||||||
ENTITYFUNCPTR TouchSet( ENTITYFUNCPTR func, char *name )
|
ENTITYFUNCPTR TouchSet( ENTITYFUNCPTR func, const char *name )
|
||||||
{
|
{
|
||||||
//COMPILE_TIME_ASSERT( sizeof(func) == 4 );
|
//COMPILE_TIME_ASSERT( sizeof(func) == 4 );
|
||||||
m_pfnTouch = func;
|
m_pfnTouch = func;
|
||||||
@ -1359,6 +1405,7 @@ public:
|
|||||||
|
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
int m_iViewHideFlags;
|
int m_iViewHideFlags;
|
||||||
|
bool m_bDisableFlashlight;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@ -1500,6 +1547,15 @@ protected:
|
|||||||
CUtlVector< thinkfunc_t > m_aThinkFunctions;
|
CUtlVector< thinkfunc_t > m_aThinkFunctions;
|
||||||
int m_iCurrentThinkContext;
|
int m_iCurrentThinkContext;
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
public:
|
||||||
|
void ScriptSetContextThink( const char* szContext, HSCRIPT hFunc, float time );
|
||||||
|
void ScriptContextThink();
|
||||||
|
private:
|
||||||
|
CUtlVector< scriptthinkfunc_t* > m_ScriptThinkFuncs;
|
||||||
|
public:
|
||||||
|
#endif
|
||||||
|
|
||||||
// Object eye position
|
// Object eye position
|
||||||
Vector m_vecViewOffset;
|
Vector m_vecViewOffset;
|
||||||
|
|
||||||
|
@ -15,7 +15,7 @@
|
|||||||
#include "ammodef.h"
|
#include "ammodef.h"
|
||||||
#include "vprof.h"
|
#include "vprof.h"
|
||||||
#include "view.h"
|
#include "view.h"
|
||||||
#include "vstdlib/ikeyvaluessystem.h"
|
#include "vstdlib/IKeyValuesSystem.h"
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
#include "usermessages.h"
|
#include "usermessages.h"
|
||||||
#endif
|
#endif
|
||||||
@ -666,7 +666,8 @@ void CIconLesson::UpdateInactive()
|
|||||||
CUtlBuffer msg_data;
|
CUtlBuffer msg_data;
|
||||||
msg_data.PutChar( 1 );
|
msg_data.PutChar( 1 );
|
||||||
msg_data.PutString( m_szHudHint.String() );
|
msg_data.PutString( m_szHudHint.String() );
|
||||||
usermessages->DispatchUserMessage( usermessages->LookupUserMessage( "KeyHintText" ), bf_read( msg_data.Base(), msg_data.TellPut() ) );
|
bf_read msg( msg_data.Base(), msg_data.TellPut() );
|
||||||
|
usermessages->DispatchUserMessage( usermessages->LookupUserMessage( "KeyHintText" ), msg );
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1039,40 +1040,40 @@ Vector CIconLesson::GetIconTargetPosition( C_BaseEntity *pIconTarget )
|
|||||||
|
|
||||||
#define LESSON_VARIABLE_INIT_SYMBOL( _varEnum, _varName, _varType ) g_n##_varEnum##Symbol = KeyValuesSystem()->GetSymbolForString( #_varEnum );
|
#define LESSON_VARIABLE_INIT_SYMBOL( _varEnum, _varName, _varType ) g_n##_varEnum##Symbol = KeyValuesSystem()->GetSymbolForString( #_varEnum );
|
||||||
|
|
||||||
#define LESSON_SCRIPT_STRING_ADD_TO_MAP( _varEnum, _varName, _varType ) g_NameToTypeMap.Insert( #_varEnum, LESSON_VARIABLE_##_varEnum## );
|
#define LESSON_SCRIPT_STRING_ADD_TO_MAP( _varEnum, _varName, _varType ) g_NameToTypeMap.Insert( #_varEnum, LESSON_VARIABLE_##_varEnum );
|
||||||
|
|
||||||
// Create enum value
|
// Create enum value
|
||||||
#define LESSON_VARIABLE_ENUM( _varEnum, _varName, _varType ) LESSON_VARIABLE_##_varEnum##,
|
#define LESSON_VARIABLE_ENUM( _varEnum, _varName, _varType ) LESSON_VARIABLE_##_varEnum,
|
||||||
|
|
||||||
// Init info call
|
// Init info call
|
||||||
#define LESSON_VARIABLE_INIT_INFO_CALL( _varEnum, _varName, _varType ) g_pLessonVariableInfo[ LESSON_VARIABLE_##_varEnum## ].Init_##_varEnum##();
|
#define LESSON_VARIABLE_INIT_INFO_CALL( _varEnum, _varName, _varType ) g_pLessonVariableInfo[ LESSON_VARIABLE_##_varEnum ].Init_##_varEnum();
|
||||||
|
|
||||||
// Init info
|
// Init info
|
||||||
#define LESSON_VARIABLE_INIT_INFO( _varEnum, _varName, _varType ) \
|
#define LESSON_VARIABLE_INIT_INFO( _varEnum, _varName, _varType ) \
|
||||||
void Init_##_varEnum##() \
|
void Init_##_varEnum() \
|
||||||
{ \
|
{ \
|
||||||
iOffset = offsetof( CScriptedIconLesson, CScriptedIconLesson::##_varName## ); \
|
iOffset = offsetof( CScriptedIconLesson, CScriptedIconLesson::_varName ); \
|
||||||
varType = LessonParamTypeFromString( #_varType ); \
|
varType = LessonParamTypeFromString( #_varType ); \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define LESSON_VARIABLE_INIT_INFO_BOOL( _varEnum, _varName, _varType ) \
|
#define LESSON_VARIABLE_INIT_INFO_BOOL( _varEnum, _varName, _varType ) \
|
||||||
void Init_##_varEnum##() \
|
void Init_##_varEnum() \
|
||||||
{ \
|
{ \
|
||||||
iOffset = offsetof( CScriptedIconLesson, CScriptedIconLesson::##_varName## ); \
|
iOffset = offsetof( CScriptedIconLesson, CScriptedIconLesson::_varName ); \
|
||||||
varType = FIELD_BOOLEAN; \
|
varType = FIELD_BOOLEAN; \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define LESSON_VARIABLE_INIT_INFO_EHANDLE( _varEnum, _varName, _varType ) \
|
#define LESSON_VARIABLE_INIT_INFO_EHANDLE( _varEnum, _varName, _varType ) \
|
||||||
void Init_##_varEnum##() \
|
void Init_##_varEnum() \
|
||||||
{ \
|
{ \
|
||||||
iOffset = offsetof( CScriptedIconLesson, CScriptedIconLesson::##_varName## ); \
|
iOffset = offsetof( CScriptedIconLesson, CScriptedIconLesson::_varName ); \
|
||||||
varType = FIELD_EHANDLE; \
|
varType = FIELD_EHANDLE; \
|
||||||
}
|
}
|
||||||
|
|
||||||
#define LESSON_VARIABLE_INIT_INFO_STRING( _varEnum, _varName, _varType ) \
|
#define LESSON_VARIABLE_INIT_INFO_STRING( _varEnum, _varName, _varType ) \
|
||||||
void Init_##_varEnum##() \
|
void Init_##_varEnum() \
|
||||||
{ \
|
{ \
|
||||||
iOffset = offsetof( CScriptedIconLesson, CScriptedIconLesson::##_varName## ); \
|
iOffset = offsetof( CScriptedIconLesson, CScriptedIconLesson::_varName ); \
|
||||||
varType = FIELD_STRING; \
|
varType = FIELD_STRING; \
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1094,15 +1095,15 @@ Vector CIconLesson::GetIconTargetPosition( C_BaseEntity *pIconTarget )
|
|||||||
|
|
||||||
// Process the element action on this variable
|
// Process the element action on this variable
|
||||||
#define PROCESS_LESSON_ACTION( _varEnum, _varName, _varType ) \
|
#define PROCESS_LESSON_ACTION( _varEnum, _varName, _varType ) \
|
||||||
case LESSON_VARIABLE_##_varEnum##:\
|
case LESSON_VARIABLE_##_varEnum:\
|
||||||
return ProcessElementAction( pLessonElement->iAction, pLessonElement->bNot, #_varName, _varName, &pLessonElement->szParam, eventParam_float );
|
return ProcessElementAction( pLessonElement->iAction, pLessonElement->bNot, #_varName, _varName, &pLessonElement->szParam, eventParam_float );
|
||||||
|
|
||||||
#define PROCESS_LESSON_ACTION_EHANDLE( _varEnum, _varName, _varType ) \
|
#define PROCESS_LESSON_ACTION_EHANDLE( _varEnum, _varName, _varType ) \
|
||||||
case LESSON_VARIABLE_##_varEnum##:\
|
case LESSON_VARIABLE_##_varEnum:\
|
||||||
return ProcessElementAction( pLessonElement->iAction, pLessonElement->bNot, #_varName, _varName, &pLessonElement->szParam, eventParam_float, eventParam_BaseEntity, eventParam_string );
|
return ProcessElementAction( pLessonElement->iAction, pLessonElement->bNot, #_varName, _varName, &pLessonElement->szParam, eventParam_float, eventParam_BaseEntity, eventParam_string );
|
||||||
|
|
||||||
#define PROCESS_LESSON_ACTION_STRING( _varEnum, _varName, _varType ) \
|
#define PROCESS_LESSON_ACTION_STRING( _varEnum, _varName, _varType ) \
|
||||||
case LESSON_VARIABLE_##_varEnum##:\
|
case LESSON_VARIABLE_##_varEnum:\
|
||||||
return ProcessElementAction( pLessonElement->iAction, pLessonElement->bNot, #_varName, &_varName, &pLessonElement->szParam, eventParam_string );
|
return ProcessElementAction( pLessonElement->iAction, pLessonElement->bNot, #_varName, &_varName, &pLessonElement->szParam, eventParam_string );
|
||||||
|
|
||||||
// Init the variable from the script (or a convar)
|
// Init the variable from the script (or a convar)
|
||||||
@ -2957,7 +2958,7 @@ bool CScriptedIconLesson::ProcessElementAction( int iAction, bool bNot, const ch
|
|||||||
{
|
{
|
||||||
if ( gameinstructor_verbose.GetInt() > 0 && ShouldShowSpew() )
|
if ( gameinstructor_verbose.GetInt() > 0 && ShouldShowSpew() )
|
||||||
{
|
{
|
||||||
ConColorMsg( CBaseLesson::m_rgbaVerbosePlain, "\t[%s]->HealthFraction() ", pchVarName, pchVarName );
|
ConColorMsg( CBaseLesson::m_rgbaVerbosePlain, "\t[%s]->HealthFraction() ", pchVarName );
|
||||||
ConColorMsg( CBaseLesson::m_rgbaVerboseName, "... " );
|
ConColorMsg( CBaseLesson::m_rgbaVerboseName, "... " );
|
||||||
ConColorMsg( CBaseLesson::m_rgbaVerbosePlain, ( bNot ) ? ( ">= [%s] " ) : ( "< [%s] " ), pchParamName->String() );
|
ConColorMsg( CBaseLesson::m_rgbaVerbosePlain, ( bNot ) ? ( ">= [%s] " ) : ( "< [%s] " ), pchParamName->String() );
|
||||||
ConColorMsg( CBaseLesson::m_rgbaVerboseName, "%f\n", fParam );
|
ConColorMsg( CBaseLesson::m_rgbaVerboseName, "%f\n", fParam );
|
||||||
@ -2969,7 +2970,7 @@ bool CScriptedIconLesson::ProcessElementAction( int iAction, bool bNot, const ch
|
|||||||
|
|
||||||
if ( gameinstructor_verbose.GetInt() > 0 && ShouldShowSpew() )
|
if ( gameinstructor_verbose.GetInt() > 0 && ShouldShowSpew() )
|
||||||
{
|
{
|
||||||
ConColorMsg( CBaseLesson::m_rgbaVerbosePlain, "\t[%s]->HealthFraction() ", pchVarName, pchVarName );
|
ConColorMsg( CBaseLesson::m_rgbaVerbosePlain, "\t[%s]->HealthFraction() ", pchVarName );
|
||||||
ConColorMsg( CBaseLesson::m_rgbaVerboseName, "%f ", pVar->HealthFraction() );
|
ConColorMsg( CBaseLesson::m_rgbaVerboseName, "%f ", pVar->HealthFraction() );
|
||||||
ConColorMsg( CBaseLesson::m_rgbaVerbosePlain, ( bNot ) ? ( ">= [%s] " ) : ( "< [%s] " ), pchParamName->String() );
|
ConColorMsg( CBaseLesson::m_rgbaVerbosePlain, ( bNot ) ? ( ">= [%s] " ) : ( "< [%s] " ), pchParamName->String() );
|
||||||
ConColorMsg( CBaseLesson::m_rgbaVerboseName, "%f\n", fParam );
|
ConColorMsg( CBaseLesson::m_rgbaVerboseName, "%f\n", fParam );
|
||||||
|
@ -426,7 +426,7 @@ private:
|
|||||||
LessonEvent_t * AddUpdateEvent( void );
|
LessonEvent_t * AddUpdateEvent( void );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static CUtlDict< int, int > CScriptedIconLesson::LessonActionMap;
|
static CUtlDict< int, int > LessonActionMap;
|
||||||
|
|
||||||
EHANDLE m_hLocalPlayer;
|
EHANDLE m_hLocalPlayer;
|
||||||
float m_fOutput;
|
float m_fOutput;
|
||||||
|
@ -284,6 +284,7 @@ END_RECV_TABLE()
|
|||||||
RecvPropInt ( RECVINFO( m_spawnflags ), 0, RecvProxy_ShiftPlayerSpawnflags ),
|
RecvPropInt ( RECVINFO( m_spawnflags ), 0, RecvProxy_ShiftPlayerSpawnflags ),
|
||||||
|
|
||||||
RecvPropBool ( RECVINFO( m_bDrawPlayerModelExternally ) ),
|
RecvPropBool ( RECVINFO( m_bDrawPlayerModelExternally ) ),
|
||||||
|
RecvPropBool ( RECVINFO( m_bInTriggerFall ) ),
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
END_RECV_TABLE()
|
END_RECV_TABLE()
|
||||||
@ -334,7 +335,10 @@ END_RECV_TABLE()
|
|||||||
|
|
||||||
RecvPropString( RECVINFO(m_szLastPlaceName) ),
|
RecvPropString( RECVINFO(m_szLastPlaceName) ),
|
||||||
|
|
||||||
RecvPropEHandle(RECVINFO(m_hPostProcessCtrl)), // Send to everybody - for spectating
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
RecvPropEHandle( RECVINFO( m_hPostProcessCtrl ) ), // Send to everybody - for spectating
|
||||||
|
RecvPropEHandle( RECVINFO( m_hColorCorrectionCtrl ) ), // Send to everybody - for spectating
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined USES_ECON_ITEMS
|
#if defined USES_ECON_ITEMS
|
||||||
RecvPropUtlVector( RECVINFO_UTLVECTOR( m_hMyWearables ), MAX_WEARABLES_SENT_FROM_SERVER, RecvPropEHandle(NULL, 0, 0) ),
|
RecvPropUtlVector( RECVINFO_UTLVECTOR( m_hMyWearables ), MAX_WEARABLES_SENT_FROM_SERVER, RecvPropEHandle(NULL, 0, 0) ),
|
||||||
@ -496,14 +500,14 @@ C_BasePlayer::~C_BasePlayer()
|
|||||||
if ( this == s_pLocalPlayer )
|
if ( this == s_pLocalPlayer )
|
||||||
{
|
{
|
||||||
s_pLocalPlayer = NULL;
|
s_pLocalPlayer = NULL;
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef MAPBASE_VSCRIPT
|
#ifdef MAPBASE_VSCRIPT
|
||||||
if ( IsLocalPlayer() && g_pScriptVM )
|
if ( g_pScriptVM )
|
||||||
{
|
{
|
||||||
g_pScriptVM->SetValue( "player", SCRIPT_VARIANT_NULL );
|
g_pScriptVM->SetValue( "player", SCRIPT_VARIANT_NULL );
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
delete m_pFlashlight;
|
delete m_pFlashlight;
|
||||||
}
|
}
|
||||||
@ -861,6 +865,14 @@ void C_BasePlayer::PostDataUpdate( DataUpdateType_t updateType )
|
|||||||
// changed level, which would cause the snd_soundmixer to be left modified.
|
// changed level, which would cause the snd_soundmixer to be left modified.
|
||||||
ConVar *pVar = (ConVar *)cvar->FindVar( "snd_soundmixer" );
|
ConVar *pVar = (ConVar *)cvar->FindVar( "snd_soundmixer" );
|
||||||
pVar->Revert();
|
pVar->Revert();
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
// Moved here from LevelInitPostEntity, which is executed before local player is spawned.
|
||||||
|
if ( g_pScriptVM )
|
||||||
|
{
|
||||||
|
g_pScriptVM->SetValue( "player", GetScriptInstance() );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1373,6 +1385,10 @@ void C_BasePlayer::AddEntity( void )
|
|||||||
|
|
||||||
// Add in lighting effects
|
// Add in lighting effects
|
||||||
CreateLightEffects();
|
CreateLightEffects();
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
SetLocalAnglesDim( X_INDEX, 0 );
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
extern float UTIL_WaterLevel( const Vector &position, float minz, float maxz );
|
extern float UTIL_WaterLevel( const Vector &position, float minz, float maxz );
|
||||||
@ -1495,8 +1511,9 @@ int C_BasePlayer::DrawModel( int flags )
|
|||||||
if (m_bDrawPlayerModelExternally)
|
if (m_bDrawPlayerModelExternally)
|
||||||
{
|
{
|
||||||
// Draw the player in any view except the main or "intro" view, both of which are default first-person views.
|
// Draw the player in any view except the main or "intro" view, both of which are default first-person views.
|
||||||
|
// HACKHACK: Also don't draw in shadow depth textures if the player's flashlight is on, as that causes the playermodel to block it.
|
||||||
view_id_t viewID = CurrentViewID();
|
view_id_t viewID = CurrentViewID();
|
||||||
if (viewID == VIEW_MAIN || viewID == VIEW_INTRO_CAMERA)
|
if (viewID == VIEW_MAIN || viewID == VIEW_INTRO_CAMERA || (viewID == VIEW_SHADOW_DEPTH_TEXTURE && IsEffectActive(EF_DIMLIGHT)))
|
||||||
{
|
{
|
||||||
// Make sure the player model wouldn't draw anyway...
|
// Make sure the player model wouldn't draw anyway...
|
||||||
if (!ShouldDrawThisPlayer())
|
if (!ShouldDrawThisPlayer())
|
||||||
@ -1519,6 +1536,38 @@ int C_BasePlayer::DrawModel( int flags )
|
|||||||
return BaseClass::DrawModel( flags );
|
return BaseClass::DrawModel( flags );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
ConVar cl_player_allow_thirdperson_projtex( "cl_player_allow_thirdperson_projtex", "1", FCVAR_NONE, "Allows players to receive projected textures if they're non-local or in third person." );
|
||||||
|
ConVar cl_player_allow_thirdperson_rttshadows( "cl_player_allow_thirdperson_rttshadows", "0", FCVAR_NONE, "Allows players to cast RTT shadows if they're non-local or in third person." );
|
||||||
|
ConVar cl_player_allow_firstperson_projtex( "cl_player_allow_firstperson_projtex", "1", FCVAR_NONE, "Allows players to receive projected textures even if they're in first person." );
|
||||||
|
ConVar cl_player_allow_firstperson_rttshadows( "cl_player_allow_firstperson_rttshadows", "0", FCVAR_NONE, "Allows players to cast RTT shadows even if they're in first person." );
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
ShadowType_t C_BasePlayer::ShadowCastType()
|
||||||
|
{
|
||||||
|
if ( (!IsLocalPlayer() || ShouldDraw()) ? !cl_player_allow_thirdperson_rttshadows.GetBool() : !cl_player_allow_firstperson_rttshadows.GetBool() )
|
||||||
|
return SHADOWS_NONE;
|
||||||
|
|
||||||
|
if ( !IsVisible() )
|
||||||
|
return SHADOWS_NONE;
|
||||||
|
|
||||||
|
return SHADOWS_RENDER_TO_TEXTURE_DYNAMIC;
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Should this object receive shadows?
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
bool C_BasePlayer::ShouldReceiveProjectedTextures( int flags )
|
||||||
|
{
|
||||||
|
if ( (!IsLocalPlayer() || ShouldDraw()) ? !cl_player_allow_thirdperson_projtex.GetBool() : !cl_player_allow_firstperson_projtex.GetBool() )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
return BaseClass::ShouldReceiveProjectedTextures( flags );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose:
|
// Purpose:
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -2934,6 +2983,7 @@ void C_BasePlayer::UpdateFogBlend( void )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
//
|
//
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -2942,6 +2992,15 @@ C_PostProcessController* C_BasePlayer::GetActivePostProcessController() const
|
|||||||
return m_hPostProcessCtrl.Get();
|
return m_hPostProcessCtrl.Get();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
C_ColorCorrection* C_BasePlayer::GetActiveColorCorrection() const
|
||||||
|
{
|
||||||
|
return m_hColorCorrectionCtrl.Get();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose:
|
// Purpose:
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
@ -23,7 +23,10 @@
|
|||||||
#include "hintsystem.h"
|
#include "hintsystem.h"
|
||||||
#include "SoundEmitterSystem/isoundemittersystembase.h"
|
#include "SoundEmitterSystem/isoundemittersystembase.h"
|
||||||
#include "c_env_fog_controller.h"
|
#include "c_env_fog_controller.h"
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
#include "c_postprocesscontroller.h"
|
#include "c_postprocesscontroller.h"
|
||||||
|
#include "c_colorcorrection.h"
|
||||||
|
#endif
|
||||||
#include "igameevents.h"
|
#include "igameevents.h"
|
||||||
#include "GameEventListener.h"
|
#include "GameEventListener.h"
|
||||||
|
|
||||||
@ -204,6 +207,11 @@ public:
|
|||||||
void SetMaxSpeed( float flMaxSpeed ) { m_flMaxspeed = flMaxSpeed; }
|
void SetMaxSpeed( float flMaxSpeed ) { m_flMaxspeed = flMaxSpeed; }
|
||||||
float MaxSpeed() const { return m_flMaxspeed; }
|
float MaxSpeed() const { return m_flMaxspeed; }
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
// See c_baseplayer.cpp
|
||||||
|
virtual ShadowType_t ShadowCastType();
|
||||||
|
virtual bool ShouldReceiveProjectedTextures( int flags );
|
||||||
|
#else
|
||||||
// Should this object cast shadows?
|
// Should this object cast shadows?
|
||||||
virtual ShadowType_t ShadowCastType() { return SHADOWS_NONE; }
|
virtual ShadowType_t ShadowCastType() { return SHADOWS_NONE; }
|
||||||
|
|
||||||
@ -211,6 +219,7 @@ public:
|
|||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
bool IsLocalPlayer( void ) const;
|
bool IsLocalPlayer( void ) const;
|
||||||
@ -381,7 +390,10 @@ public:
|
|||||||
void UpdateFogController( void );
|
void UpdateFogController( void );
|
||||||
void UpdateFogBlend( void );
|
void UpdateFogBlend( void );
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
C_PostProcessController* GetActivePostProcessController() const;
|
C_PostProcessController* GetActivePostProcessController() const;
|
||||||
|
C_ColorCorrection* GetActiveColorCorrection() const;
|
||||||
|
#endif
|
||||||
|
|
||||||
float GetFOVTime( void ){ return m_flFOVTime; }
|
float GetFOVTime( void ){ return m_flFOVTime; }
|
||||||
|
|
||||||
@ -458,6 +470,8 @@ public:
|
|||||||
|
|
||||||
// Allows the player's model to draw on non-main views, like monitors or mirrors.
|
// Allows the player's model to draw on non-main views, like monitors or mirrors.
|
||||||
bool m_bDrawPlayerModelExternally;
|
bool m_bDrawPlayerModelExternally;
|
||||||
|
|
||||||
|
bool m_bInTriggerFall;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
@ -646,7 +660,10 @@ private:
|
|||||||
// One for left and one for right side of step
|
// One for left and one for right side of step
|
||||||
StepSoundCache_t m_StepSoundCache[ 2 ];
|
StepSoundCache_t m_StepSoundCache[ 2 ];
|
||||||
|
|
||||||
CNetworkHandle(C_PostProcessController, m_hPostProcessCtrl); // active postprocessing controller
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
CNetworkHandle( C_PostProcessController, m_hPostProcessCtrl ); // active postprocessing controller
|
||||||
|
CNetworkHandle( C_ColorCorrection, m_hColorCorrectionCtrl ); // active FXVolume color correction
|
||||||
|
#endif
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
@ -35,7 +35,7 @@
|
|||||||
// memdbgon must be the last include file in a .cpp file!!!
|
// memdbgon must be the last include file in a .cpp file!!!
|
||||||
#include "tier0/memdbgon.h"
|
#include "tier0/memdbgon.h"
|
||||||
|
|
||||||
#ifdef CSTRIKE_DLL
|
#if defined(CSTRIKE_DLL) || defined (MAPBASE)
|
||||||
ConVar cl_righthand( "cl_righthand", "1", FCVAR_ARCHIVE, "Use right-handed view models." );
|
ConVar cl_righthand( "cl_righthand", "1", FCVAR_ARCHIVE, "Use right-handed view models." );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -197,7 +197,7 @@ bool C_BaseViewModel::Interpolate( float currentTime )
|
|||||||
|
|
||||||
bool C_BaseViewModel::ShouldFlipViewModel()
|
bool C_BaseViewModel::ShouldFlipViewModel()
|
||||||
{
|
{
|
||||||
#ifdef CSTRIKE_DLL
|
#if defined(CSTRIKE_DLL) || defined (MAPBASE)
|
||||||
// If cl_righthand is set, then we want them all right-handed.
|
// If cl_righthand is set, then we want them all right-handed.
|
||||||
CBaseCombatWeapon *pWeapon = m_hWeapon.Get();
|
CBaseCombatWeapon *pWeapon = m_hWeapon.Get();
|
||||||
if ( pWeapon )
|
if ( pWeapon )
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
//===========================================================================//
|
//===========================================================================//
|
||||||
#include "cbase.h"
|
#include "cbase.h"
|
||||||
|
|
||||||
|
#include "c_colorcorrection.h"
|
||||||
#include "filesystem.h"
|
#include "filesystem.h"
|
||||||
#include "cdll_client_int.h"
|
#include "cdll_client_int.h"
|
||||||
#include "colorcorrectionmgr.h"
|
#include "colorcorrectionmgr.h"
|
||||||
@ -17,45 +18,27 @@
|
|||||||
|
|
||||||
static ConVar mat_colcorrection_disableentities( "mat_colcorrection_disableentities", "0", FCVAR_NONE, "Disable map color-correction entities" );
|
static ConVar mat_colcorrection_disableentities( "mat_colcorrection_disableentities", "0", FCVAR_NONE, "Disable map color-correction entities" );
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
//------------------------------------------------------------------------------
|
static ConVar mat_colcorrection_forceentitiesclientside( "mat_colcorrection_forceentitiesclientside", "0", FCVAR_CHEAT, "Forces color correction entities to be updated on the client" );
|
||||||
// Purpose : Color correction entity with radial falloff
|
#endif
|
||||||
//------------------------------------------------------------------------------
|
|
||||||
class C_ColorCorrection : public C_BaseEntity
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
DECLARE_CLASS( C_ColorCorrection, C_BaseEntity );
|
|
||||||
|
|
||||||
DECLARE_CLIENTCLASS();
|
|
||||||
|
|
||||||
C_ColorCorrection();
|
|
||||||
virtual ~C_ColorCorrection();
|
|
||||||
|
|
||||||
void OnDataChanged(DataUpdateType_t updateType);
|
|
||||||
bool ShouldDraw();
|
|
||||||
|
|
||||||
void ClientThink();
|
|
||||||
|
|
||||||
private:
|
|
||||||
Vector m_vecOrigin;
|
|
||||||
|
|
||||||
float m_minFalloff;
|
|
||||||
float m_maxFalloff;
|
|
||||||
float m_flCurWeight;
|
|
||||||
char m_netLookupFilename[MAX_PATH];
|
|
||||||
|
|
||||||
bool m_bEnabled;
|
|
||||||
|
|
||||||
ClientCCHandle_t m_CCHandle;
|
|
||||||
};
|
|
||||||
|
|
||||||
IMPLEMENT_CLIENTCLASS_DT(C_ColorCorrection, DT_ColorCorrection, CColorCorrection)
|
IMPLEMENT_CLIENTCLASS_DT(C_ColorCorrection, DT_ColorCorrection, CColorCorrection)
|
||||||
RecvPropVector( RECVINFO(m_vecOrigin) ),
|
RecvPropVector( RECVINFO(m_vecOrigin) ),
|
||||||
RecvPropFloat( RECVINFO(m_minFalloff) ),
|
RecvPropFloat( RECVINFO(m_minFalloff) ),
|
||||||
RecvPropFloat( RECVINFO(m_maxFalloff) ),
|
RecvPropFloat( RECVINFO(m_maxFalloff) ),
|
||||||
RecvPropFloat( RECVINFO(m_flCurWeight) ),
|
RecvPropFloat( RECVINFO(m_flCurWeight) ),
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
RecvPropFloat( RECVINFO(m_flMaxWeight) ),
|
||||||
|
RecvPropFloat( RECVINFO(m_flFadeInDuration) ),
|
||||||
|
RecvPropFloat( RECVINFO(m_flFadeOutDuration) ),
|
||||||
|
#endif
|
||||||
RecvPropString( RECVINFO(m_netLookupFilename) ),
|
RecvPropString( RECVINFO(m_netLookupFilename) ),
|
||||||
RecvPropBool( RECVINFO(m_bEnabled) ),
|
RecvPropBool( RECVINFO(m_bEnabled) ),
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
RecvPropBool( RECVINFO(m_bMaster) ),
|
||||||
|
RecvPropBool( RECVINFO(m_bClientSide) ),
|
||||||
|
RecvPropBool( RECVINFO(m_bExclusive) )
|
||||||
|
#endif
|
||||||
|
|
||||||
END_RECV_TABLE()
|
END_RECV_TABLE()
|
||||||
|
|
||||||
@ -65,14 +48,43 @@ END_RECV_TABLE()
|
|||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
C_ColorCorrection::C_ColorCorrection()
|
C_ColorCorrection::C_ColorCorrection()
|
||||||
{
|
{
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
m_minFalloff = -1.0f;
|
||||||
|
m_maxFalloff = -1.0f;
|
||||||
|
m_flFadeInDuration = 0.0f;
|
||||||
|
m_flFadeOutDuration = 0.0f;
|
||||||
|
m_flCurWeight = 0.0f;
|
||||||
|
m_flMaxWeight = 1.0f;
|
||||||
|
m_netLookupFilename[0] = '\0';
|
||||||
|
m_bEnabled = false;
|
||||||
|
m_bMaster = false;
|
||||||
|
m_bExclusive = false;
|
||||||
|
#endif
|
||||||
m_CCHandle = INVALID_CLIENT_CCHANDLE;
|
m_CCHandle = INVALID_CLIENT_CCHANDLE;
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
m_bFadingIn = false;
|
||||||
|
m_flFadeStartWeight = 0.0f;
|
||||||
|
m_flFadeStartTime = 0.0f;
|
||||||
|
m_flFadeDuration = 0.0f;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
C_ColorCorrection::~C_ColorCorrection()
|
C_ColorCorrection::~C_ColorCorrection()
|
||||||
{
|
{
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
g_pColorCorrectionMgr->RemoveColorCorrectionEntity( this, m_CCHandle );
|
||||||
|
#else
|
||||||
g_pColorCorrectionMgr->RemoveColorCorrection( m_CCHandle );
|
g_pColorCorrectionMgr->RemoveColorCorrection( m_CCHandle );
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
bool C_ColorCorrection::IsClientSide() const
|
||||||
|
{
|
||||||
|
return m_bClientSide || mat_colcorrection_forceentitiesclientside.GetBool();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
// Purpose :
|
// Purpose :
|
||||||
@ -87,11 +99,21 @@ void C_ColorCorrection::OnDataChanged(DataUpdateType_t updateType)
|
|||||||
{
|
{
|
||||||
if ( m_CCHandle == INVALID_CLIENT_CCHANDLE )
|
if ( m_CCHandle == INVALID_CLIENT_CCHANDLE )
|
||||||
{
|
{
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
// forming a unique name without extension
|
||||||
|
char cleanName[MAX_PATH];
|
||||||
|
V_StripExtension( m_netLookupFilename, cleanName, sizeof( cleanName ) );
|
||||||
|
char name[MAX_PATH];
|
||||||
|
Q_snprintf( name, MAX_PATH, "%s_%d", cleanName, entindex() );
|
||||||
|
|
||||||
|
m_CCHandle = g_pColorCorrectionMgr->AddColorCorrectionEntity( this, name, m_netLookupFilename );
|
||||||
|
#else
|
||||||
char filename[MAX_PATH];
|
char filename[MAX_PATH];
|
||||||
Q_strncpy( filename, m_netLookupFilename, MAX_PATH );
|
Q_strncpy( filename, m_netLookupFilename, MAX_PATH );
|
||||||
|
|
||||||
m_CCHandle = g_pColorCorrectionMgr->AddColorCorrection( filename );
|
m_CCHandle = g_pColorCorrectionMgr->AddColorCorrection( filename );
|
||||||
SetNextClientThink( ( m_CCHandle != INVALID_CLIENT_CCHANDLE ) ? CLIENT_THINK_ALWAYS : CLIENT_THINK_NEVER );
|
SetNextClientThink( ( m_CCHandle != INVALID_CLIENT_CCHANDLE ) ? CLIENT_THINK_ALWAYS : CLIENT_THINK_NEVER );
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -104,6 +126,129 @@ bool C_ColorCorrection::ShouldDraw()
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
void C_ColorCorrection::Update( C_BasePlayer *pPlayer, float ccScale )
|
||||||
|
{
|
||||||
|
Assert( m_CCHandle != INVALID_CLIENT_CCHANDLE );
|
||||||
|
|
||||||
|
if ( mat_colcorrection_disableentities.GetInt() )
|
||||||
|
{
|
||||||
|
// Allow the colorcorrectionui panel (or user) to turn off color-correction entities
|
||||||
|
g_pColorCorrectionMgr->SetColorCorrectionWeight( m_CCHandle, 0.0f, m_bExclusive );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// fade weight on client
|
||||||
|
if ( IsClientSide() )
|
||||||
|
{
|
||||||
|
m_flCurWeight = Lerp( GetFadeRatio(), m_flFadeStartWeight, m_bFadingIn ? m_flMaxWeight : 0.0f );
|
||||||
|
}
|
||||||
|
|
||||||
|
if( !m_bEnabled && m_flCurWeight == 0.0f )
|
||||||
|
{
|
||||||
|
g_pColorCorrectionMgr->SetColorCorrectionWeight( m_CCHandle, 0.0f, m_bExclusive );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Vector playerOrigin = pPlayer->GetAbsOrigin();
|
||||||
|
|
||||||
|
float weight = 0;
|
||||||
|
if ( ( m_minFalloff != -1 ) && ( m_maxFalloff != -1 ) && m_minFalloff != m_maxFalloff )
|
||||||
|
{
|
||||||
|
float dist = (playerOrigin - m_vecOrigin).Length();
|
||||||
|
weight = (dist-m_minFalloff) / (m_maxFalloff-m_minFalloff);
|
||||||
|
if ( weight<0.0f ) weight = 0.0f;
|
||||||
|
if ( weight>1.0f ) weight = 1.0f;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_pColorCorrectionMgr->SetColorCorrectionWeight( m_CCHandle, m_flCurWeight * ( 1.0 - weight ) * ccScale, m_bExclusive );
|
||||||
|
}
|
||||||
|
|
||||||
|
void C_ColorCorrection::EnableOnClient( bool bEnable, bool bSkipFade )
|
||||||
|
{
|
||||||
|
if ( !IsClientSide() )
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_bFadingIn = bEnable;
|
||||||
|
|
||||||
|
// initialize countdown timer
|
||||||
|
m_flFadeStartWeight = m_flCurWeight;
|
||||||
|
float flFadeTimeScale = 1.0f;
|
||||||
|
if ( m_flMaxWeight != 0.0f )
|
||||||
|
{
|
||||||
|
flFadeTimeScale = m_flCurWeight / m_flMaxWeight;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( m_bFadingIn )
|
||||||
|
{
|
||||||
|
flFadeTimeScale = 1.0f - flFadeTimeScale;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( bSkipFade )
|
||||||
|
{
|
||||||
|
flFadeTimeScale = 0.0f;
|
||||||
|
}
|
||||||
|
|
||||||
|
StartFade( flFadeTimeScale * ( m_bFadingIn ? m_flFadeInDuration : m_flFadeOutDuration ) );
|
||||||
|
|
||||||
|
// update the clientside weight once here, in case the fade duration is 0
|
||||||
|
m_flCurWeight = Lerp( GetFadeRatio(), m_flFadeStartWeight, m_bFadingIn ? m_flMaxWeight : 0.0f );
|
||||||
|
}
|
||||||
|
|
||||||
|
Vector C_ColorCorrection::GetOrigin()
|
||||||
|
{
|
||||||
|
return m_vecOrigin;
|
||||||
|
}
|
||||||
|
|
||||||
|
float C_ColorCorrection::GetMinFalloff()
|
||||||
|
{
|
||||||
|
return m_minFalloff;
|
||||||
|
}
|
||||||
|
|
||||||
|
float C_ColorCorrection::GetMaxFalloff()
|
||||||
|
{
|
||||||
|
return m_maxFalloff;
|
||||||
|
}
|
||||||
|
|
||||||
|
void C_ColorCorrection::SetWeight( float fWeight )
|
||||||
|
{
|
||||||
|
g_pColorCorrectionMgr->SetColorCorrectionWeight( m_CCHandle, fWeight, false );
|
||||||
|
}
|
||||||
|
|
||||||
|
void C_ColorCorrection::StartFade( float flDuration )
|
||||||
|
{
|
||||||
|
m_flFadeStartTime = gpGlobals->curtime;
|
||||||
|
m_flFadeDuration = MAX( flDuration, 0.0f );
|
||||||
|
}
|
||||||
|
|
||||||
|
float C_ColorCorrection::GetFadeRatio() const
|
||||||
|
{
|
||||||
|
float flRatio = 1.0f;
|
||||||
|
|
||||||
|
if ( m_flFadeDuration != 0.0f )
|
||||||
|
{
|
||||||
|
flRatio = ( gpGlobals->curtime - m_flFadeStartTime ) / m_flFadeDuration;
|
||||||
|
flRatio = clamp( flRatio, 0.0f, 1.0f );
|
||||||
|
}
|
||||||
|
return flRatio;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool C_ColorCorrection::IsFadeTimeElapsed() const
|
||||||
|
{
|
||||||
|
return ( ( gpGlobals->curtime - m_flFadeStartTime ) > m_flFadeDuration ) ||
|
||||||
|
( ( gpGlobals->curtime - m_flFadeStartTime ) < 0.0f );
|
||||||
|
}
|
||||||
|
|
||||||
|
void UpdateColorCorrectionEntities( C_BasePlayer *pPlayer, float ccScale, C_ColorCorrection **pList, int listCount )
|
||||||
|
{
|
||||||
|
for ( int i = 0; i < listCount; i++ )
|
||||||
|
{
|
||||||
|
pList[i]->Update(pPlayer, ccScale);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#else
|
||||||
void C_ColorCorrection::ClientThink()
|
void C_ColorCorrection::ClientThink()
|
||||||
{
|
{
|
||||||
if ( m_CCHandle == INVALID_CLIENT_CCHANDLE )
|
if ( m_CCHandle == INVALID_CLIENT_CCHANDLE )
|
||||||
@ -141,6 +286,7 @@ void C_ColorCorrection::ClientThink()
|
|||||||
|
|
||||||
BaseClass::ClientThink();
|
BaseClass::ClientThink();
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
88
mp/src/game/client/c_colorcorrection.h
Normal file
88
mp/src/game/client/c_colorcorrection.h
Normal file
@ -0,0 +1,88 @@
|
|||||||
|
//========= Mapbase - https://github.com/mapbase-source/source-sdk-2013 ============//
|
||||||
|
//
|
||||||
|
// Note that this header exists in the Alien Swarm SDK, but not in stock Source SDK 2013.
|
||||||
|
// Although technically a new Mapbase file, it only serves to move otherwise identical code,
|
||||||
|
// so most code and repo conventions will pretend it was always there.
|
||||||
|
//
|
||||||
|
// --------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
// Purpose: Color correction entity with simple radial falloff
|
||||||
|
//
|
||||||
|
//=============================================================================//
|
||||||
|
|
||||||
|
#ifndef C_COLORCORRECTION_H
|
||||||
|
#define C_COLORCORRECTION_H
|
||||||
|
#ifdef _WIN32
|
||||||
|
#pragma once
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "colorcorrectionmgr.h"
|
||||||
|
|
||||||
|
//------------------------------------------------------------------------------
|
||||||
|
// Purpose : Color correction entity with radial falloff
|
||||||
|
//------------------------------------------------------------------------------
|
||||||
|
class C_ColorCorrection : public C_BaseEntity
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
DECLARE_CLASS( C_ColorCorrection, C_BaseEntity );
|
||||||
|
|
||||||
|
DECLARE_CLIENTCLASS();
|
||||||
|
|
||||||
|
C_ColorCorrection();
|
||||||
|
virtual ~C_ColorCorrection();
|
||||||
|
|
||||||
|
void OnDataChanged(DataUpdateType_t updateType);
|
||||||
|
bool ShouldDraw();
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
virtual void Update(C_BasePlayer *pPlayer, float ccScale);
|
||||||
|
|
||||||
|
bool IsMaster() const { return m_bMaster; }
|
||||||
|
bool IsClientSide() const;
|
||||||
|
bool IsExclusive() const { return m_bExclusive; }
|
||||||
|
|
||||||
|
void EnableOnClient( bool bEnable, bool bSkipFade = false );
|
||||||
|
|
||||||
|
Vector GetOrigin();
|
||||||
|
float GetMinFalloff();
|
||||||
|
float GetMaxFalloff();
|
||||||
|
|
||||||
|
void SetWeight( float fWeight );
|
||||||
|
|
||||||
|
protected:
|
||||||
|
void StartFade( float flDuration );
|
||||||
|
float GetFadeRatio() const;
|
||||||
|
bool IsFadeTimeElapsed() const;
|
||||||
|
#else
|
||||||
|
void ClientThink();
|
||||||
|
|
||||||
|
private:
|
||||||
|
#endif
|
||||||
|
Vector m_vecOrigin;
|
||||||
|
|
||||||
|
float m_minFalloff;
|
||||||
|
float m_maxFalloff;
|
||||||
|
float m_flCurWeight;
|
||||||
|
char m_netLookupFilename[MAX_PATH];
|
||||||
|
|
||||||
|
bool m_bEnabled;
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
float m_flFadeInDuration;
|
||||||
|
float m_flFadeOutDuration;
|
||||||
|
float m_flMaxWeight;
|
||||||
|
|
||||||
|
bool m_bMaster;
|
||||||
|
bool m_bClientSide;
|
||||||
|
bool m_bExclusive;
|
||||||
|
|
||||||
|
bool m_bFadingIn;
|
||||||
|
float m_flFadeStartWeight;
|
||||||
|
float m_flFadeStartTime;
|
||||||
|
float m_flFadeDuration;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
ClientCCHandle_t m_CCHandle;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
@ -36,9 +36,26 @@ public:
|
|||||||
void OnDataChanged(DataUpdateType_t updateType);
|
void OnDataChanged(DataUpdateType_t updateType);
|
||||||
bool ShouldDraw();
|
bool ShouldDraw();
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
void Update( C_BasePlayer *pPlayer, float ccScale );
|
||||||
|
|
||||||
|
void StartTouch( C_BaseEntity *pOther );
|
||||||
|
void EndTouch( C_BaseEntity *pOther );
|
||||||
|
#else
|
||||||
void ClientThink();
|
void ClientThink();
|
||||||
|
#endif
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
float m_LastEnterWeight;
|
||||||
|
float m_LastEnterTime;
|
||||||
|
|
||||||
|
float m_LastExitWeight;
|
||||||
|
float m_LastExitTime;
|
||||||
|
bool m_bEnabled;
|
||||||
|
float m_MaxWeight;
|
||||||
|
float m_FadeDuration;
|
||||||
|
#endif
|
||||||
float m_Weight;
|
float m_Weight;
|
||||||
char m_lookupFilename[MAX_PATH];
|
char m_lookupFilename[MAX_PATH];
|
||||||
|
|
||||||
@ -46,6 +63,11 @@ private:
|
|||||||
};
|
};
|
||||||
|
|
||||||
IMPLEMENT_CLIENTCLASS_DT(C_ColorCorrectionVolume, DT_ColorCorrectionVolume, CColorCorrectionVolume)
|
IMPLEMENT_CLIENTCLASS_DT(C_ColorCorrectionVolume, DT_ColorCorrectionVolume, CColorCorrectionVolume)
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
RecvPropBool( RECVINFO( m_bEnabled ) ),
|
||||||
|
RecvPropFloat( RECVINFO( m_MaxWeight ) ),
|
||||||
|
RecvPropFloat( RECVINFO( m_FadeDuration ) ),
|
||||||
|
#endif
|
||||||
RecvPropFloat( RECVINFO(m_Weight) ),
|
RecvPropFloat( RECVINFO(m_Weight) ),
|
||||||
RecvPropString( RECVINFO(m_lookupFilename) ),
|
RecvPropString( RECVINFO(m_lookupFilename) ),
|
||||||
END_RECV_TABLE()
|
END_RECV_TABLE()
|
||||||
@ -82,11 +104,21 @@ void C_ColorCorrectionVolume::OnDataChanged(DataUpdateType_t updateType)
|
|||||||
{
|
{
|
||||||
if ( m_CCHandle == INVALID_CLIENT_CCHANDLE )
|
if ( m_CCHandle == INVALID_CLIENT_CCHANDLE )
|
||||||
{
|
{
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
// forming a unique name without extension
|
||||||
|
char cleanName[MAX_PATH];
|
||||||
|
V_StripExtension( m_lookupFilename, cleanName, sizeof( cleanName ) );
|
||||||
|
char name[MAX_PATH];
|
||||||
|
Q_snprintf( name, MAX_PATH, "%s_%d", cleanName, entindex() );
|
||||||
|
|
||||||
|
m_CCHandle = g_pColorCorrectionMgr->AddColorCorrectionVolume( this, name, m_lookupFilename );
|
||||||
|
#else
|
||||||
char filename[MAX_PATH];
|
char filename[MAX_PATH];
|
||||||
Q_strncpy( filename, m_lookupFilename, MAX_PATH );
|
Q_strncpy( filename, m_lookupFilename, MAX_PATH );
|
||||||
|
|
||||||
m_CCHandle = g_pColorCorrectionMgr->AddColorCorrection( filename );
|
m_CCHandle = g_pColorCorrectionMgr->AddColorCorrection( filename );
|
||||||
SetNextClientThink( ( m_CCHandle != INVALID_CLIENT_CCHANDLE ) ? CLIENT_THINK_ALWAYS : CLIENT_THINK_NEVER );
|
SetNextClientThink( ( m_CCHandle != INVALID_CLIENT_CCHANDLE ) ? CLIENT_THINK_ALWAYS : CLIENT_THINK_NEVER );
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -99,11 +131,95 @@ bool C_ColorCorrectionVolume::ShouldDraw()
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
//--------------------------------------------------------------------------------------------------------
|
||||||
|
void C_ColorCorrectionVolume::StartTouch( CBaseEntity *pEntity )
|
||||||
|
{
|
||||||
|
m_LastEnterTime = gpGlobals->curtime;
|
||||||
|
m_LastEnterWeight = m_Weight;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------------------------------------------
|
||||||
|
void C_ColorCorrectionVolume::EndTouch( CBaseEntity *pEntity )
|
||||||
|
{
|
||||||
|
m_LastExitTime = gpGlobals->curtime;
|
||||||
|
m_LastExitWeight = m_Weight;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void C_ColorCorrectionVolume::Update( C_BasePlayer *pPlayer, float ccScale )
|
||||||
|
{
|
||||||
|
if ( pPlayer )
|
||||||
|
{
|
||||||
|
bool isTouching = CollisionProp()->IsPointInBounds( pPlayer->EyePosition() );
|
||||||
|
bool wasTouching = m_LastEnterTime > m_LastExitTime;
|
||||||
|
|
||||||
|
if ( isTouching && !wasTouching )
|
||||||
|
{
|
||||||
|
StartTouch( pPlayer );
|
||||||
|
}
|
||||||
|
else if ( !isTouching && wasTouching )
|
||||||
|
{
|
||||||
|
EndTouch( pPlayer );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if( !m_bEnabled )
|
||||||
|
{
|
||||||
|
m_Weight = 0.0f;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if( m_LastEnterTime > m_LastExitTime )
|
||||||
|
{
|
||||||
|
// we most recently entered the volume
|
||||||
|
|
||||||
|
if( m_Weight < 1.0f )
|
||||||
|
{
|
||||||
|
float dt = gpGlobals->curtime - m_LastEnterTime;
|
||||||
|
float weight = m_LastEnterWeight + dt / ((1.0f-m_LastEnterWeight)*m_FadeDuration);
|
||||||
|
if( weight>1.0f )
|
||||||
|
weight = 1.0f;
|
||||||
|
|
||||||
|
m_Weight = weight;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// we most recently exitted the volume
|
||||||
|
|
||||||
|
if( m_Weight > 0.0f )
|
||||||
|
{
|
||||||
|
float dt = gpGlobals->curtime - m_LastExitTime;
|
||||||
|
float weight = (1.0f-m_LastExitWeight) + dt / (m_LastExitWeight*m_FadeDuration);
|
||||||
|
if( weight>1.0f )
|
||||||
|
weight = 1.0f;
|
||||||
|
|
||||||
|
m_Weight = 1.0f - weight;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Vector entityPosition = GetAbsOrigin();
|
||||||
|
g_pColorCorrectionMgr->SetColorCorrectionWeight( m_CCHandle, m_Weight * ccScale );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void UpdateColorCorrectionVolumes( C_BasePlayer *pPlayer, float ccScale, C_ColorCorrectionVolume **pList, int listCount )
|
||||||
|
{
|
||||||
|
for ( int i = 0; i < listCount; i++ )
|
||||||
|
{
|
||||||
|
pList[i]->Update(pPlayer, ccScale);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#else
|
||||||
void C_ColorCorrectionVolume::ClientThink()
|
void C_ColorCorrectionVolume::ClientThink()
|
||||||
{
|
{
|
||||||
Vector entityPosition = GetAbsOrigin();
|
Vector entityPosition = GetAbsOrigin();
|
||||||
g_pColorCorrectionMgr->SetColorCorrectionWeight( m_CCHandle, m_Weight );
|
g_pColorCorrectionMgr->SetColorCorrectionWeight( m_CCHandle, m_Weight );
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -40,7 +40,10 @@ ConVar r_RainSplashPercentage( "r_RainSplashPercentage", "20", FCVAR_CHEAT ); //
|
|||||||
ConVar r_RainParticleDensity( "r_RainParticleDensity", "1", FCVAR_NONE, "Density of Particle Rain 0-1" );
|
ConVar r_RainParticleDensity( "r_RainParticleDensity", "1", FCVAR_NONE, "Density of Particle Rain 0-1" );
|
||||||
|
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
ConVar r_RainParticleClampOffset( "r_RainParticleClampOffset", "112", FCVAR_NONE, "How far inward or outward to extrude clamped precipitation particle systems" );
|
ConVar r_RainParticleClampOffset_Rain( "r_RainParticleClampOffset_Rain", "120", FCVAR_NONE, "How far inward or outward to extrude clamped precipitation particle systems using the 'Particle Rain' type." );
|
||||||
|
ConVar r_RainParticleClampOffset_Ash( "r_RainParticleClampOffset_Ash", "300", FCVAR_NONE, "How far inward or outward to extrude clamped precipitation particle systems using the 'Particle Ash' type." );
|
||||||
|
ConVar r_RainParticleClampOffset_RainStorm( "r_RainParticleClampOffset_RainStorm", "112", FCVAR_NONE, "How far inward or outward to extrude clamped precipitation particle systems using the 'Particle Rain Storm' type." );
|
||||||
|
ConVar r_RainParticleClampOffset_Snow( "r_RainParticleClampOffset_Snow", "300", FCVAR_NONE, "How far inward or outward to extrude clamped precipitation particle systems using the 'Particle Snow' type." );
|
||||||
ConVar r_RainParticleClampDebug( "r_RainParticleClampDebug", "0", FCVAR_NONE, "Enables debug code for precipitation particle system clamping" );
|
ConVar r_RainParticleClampDebug( "r_RainParticleClampDebug", "0", FCVAR_NONE, "Enables debug code for precipitation particle system clamping" );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -951,6 +954,70 @@ void CClient_Precipitation::CreateParticlePrecip( void )
|
|||||||
UpdateParticlePrecip( pPlayer );
|
UpdateParticlePrecip( pPlayer );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
void CClient_Precipitation::ClampParticlePosition( Vector &vPlayerPos, Vector &vOffsetPos, Vector &vOffsetPosNear, Vector &vOffsetPosFar )
|
||||||
|
{
|
||||||
|
Vector mins, maxs;
|
||||||
|
modelinfo->GetModelBounds( GetModel(), mins, maxs );
|
||||||
|
|
||||||
|
// Account for precipitation height
|
||||||
|
maxs.z += 180;
|
||||||
|
|
||||||
|
Vector vecOrigin; //= WorldSpaceCenter();
|
||||||
|
VectorLerp( mins, maxs, 0.5f, vecOrigin );
|
||||||
|
|
||||||
|
maxs -= vecOrigin;
|
||||||
|
mins -= vecOrigin;
|
||||||
|
|
||||||
|
//float flMax = r_RainParticleClampOffset.GetFloat();
|
||||||
|
float flMax = 0;
|
||||||
|
switch (m_nPrecipType)
|
||||||
|
{
|
||||||
|
case PRECIPITATION_TYPE_PARTICLERAIN:
|
||||||
|
flMax = r_RainParticleClampOffset_Rain.GetFloat();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case PRECIPITATION_TYPE_PARTICLEASH:
|
||||||
|
flMax = r_RainParticleClampOffset_Ash.GetFloat();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case PRECIPITATION_TYPE_PARTICLERAINSTORM:
|
||||||
|
flMax = r_RainParticleClampOffset_RainStorm.GetFloat();
|
||||||
|
break;
|
||||||
|
|
||||||
|
case PRECIPITATION_TYPE_PARTICLESNOW:
|
||||||
|
flMax = r_RainParticleClampOffset_Snow.GetFloat();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
Vector addend( flMax, flMax, 0 );
|
||||||
|
mins += addend;
|
||||||
|
maxs -= addend;
|
||||||
|
|
||||||
|
if (flMax > 0)
|
||||||
|
{
|
||||||
|
// Unless this is extruding outwards, make sure the offset isn't inverting the bounds.
|
||||||
|
// This means precipitation triggers with bounds less than offset*2 will turn into a thin line
|
||||||
|
// and the involved precipitation will pretty much be spatial at all times, which is okay.
|
||||||
|
mins.x = clamp( mins.x, -FLT_MAX, -1 );
|
||||||
|
mins.y = clamp( mins.y, -FLT_MAX, -1 );
|
||||||
|
maxs.x = clamp( maxs.x, 1, FLT_MAX );
|
||||||
|
maxs.y = clamp( maxs.y, 1, FLT_MAX );
|
||||||
|
}
|
||||||
|
|
||||||
|
if (r_RainParticleClampDebug.GetBool())
|
||||||
|
debugoverlay->AddBoxOverlay( vecOrigin, mins, maxs, vec3_angle, 255, 0, 0, 128, 0.15f );
|
||||||
|
|
||||||
|
maxs += vecOrigin;
|
||||||
|
mins += vecOrigin;
|
||||||
|
|
||||||
|
CalcClosestPointOnAABB( mins, maxs, vPlayerPos, vPlayerPos );
|
||||||
|
CalcClosestPointOnAABB( mins, maxs, vOffsetPos, vOffsetPos );
|
||||||
|
CalcClosestPointOnAABB( mins, maxs, vOffsetPosNear, vOffsetPosNear );
|
||||||
|
CalcClosestPointOnAABB( mins, maxs, vOffsetPosFar, vOffsetPosFar );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void CClient_Precipitation::UpdateParticlePrecip( C_BasePlayer *pPlayer )
|
void CClient_Precipitation::UpdateParticlePrecip( C_BasePlayer *pPlayer )
|
||||||
{
|
{
|
||||||
if ( !pPlayer )
|
if ( !pPlayer )
|
||||||
@ -980,44 +1047,7 @@ void CClient_Precipitation::UpdateParticlePrecip( C_BasePlayer *pPlayer )
|
|||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
if (m_spawnflags & SF_PRECIP_PARTICLE_CLAMP)
|
if (m_spawnflags & SF_PRECIP_PARTICLE_CLAMP)
|
||||||
{
|
{
|
||||||
Vector mins, maxs;
|
ClampParticlePosition( vPlayerPos, vOffsetPos, vOffsetPosNear, vOffsetPosFar );
|
||||||
modelinfo->GetModelBounds( GetModel(), mins, maxs );
|
|
||||||
|
|
||||||
// Account for precipitation height
|
|
||||||
maxs.z += 180;
|
|
||||||
|
|
||||||
Vector vecOrigin; //= WorldSpaceCenter();
|
|
||||||
VectorLerp( mins, maxs, 0.5f, vecOrigin );
|
|
||||||
|
|
||||||
maxs -= vecOrigin;
|
|
||||||
mins -= vecOrigin;
|
|
||||||
|
|
||||||
float flMax = r_RainParticleClampOffset.GetFloat();
|
|
||||||
Vector addend( flMax, flMax, 0 );
|
|
||||||
mins += addend;
|
|
||||||
maxs -= addend;
|
|
||||||
|
|
||||||
if (flMax > 0)
|
|
||||||
{
|
|
||||||
// Unless this is extruding outwards, make sure the offset isn't inverting the bounds.
|
|
||||||
// This means precipitation triggers with bounds less than offset*2 will turn into a thin line
|
|
||||||
// and the involved precipitation will pretty much be spatial at all times, which is okay.
|
|
||||||
mins.x = clamp( mins.x, -FLT_MAX, -1 );
|
|
||||||
mins.y = clamp( mins.y, -FLT_MAX, -1 );
|
|
||||||
maxs.x = clamp( maxs.x, 1, FLT_MAX );
|
|
||||||
maxs.y = clamp( maxs.y, 1, FLT_MAX );
|
|
||||||
}
|
|
||||||
|
|
||||||
if (r_RainParticleClampDebug.GetBool())
|
|
||||||
debugoverlay->AddBoxOverlay( vecOrigin, mins, maxs, vec3_angle, 255, 0, 0, 128, 0.15f );
|
|
||||||
|
|
||||||
maxs += vecOrigin;
|
|
||||||
mins += vecOrigin;
|
|
||||||
|
|
||||||
CalcClosestPointOnAABB( mins, maxs, vPlayerPos, vPlayerPos );
|
|
||||||
CalcClosestPointOnAABB( mins, maxs, vOffsetPos, vOffsetPos );
|
|
||||||
CalcClosestPointOnAABB( mins, maxs, vOffsetPosNear, vOffsetPosNear );
|
|
||||||
CalcClosestPointOnAABB( mins, maxs, vOffsetPosFar, vOffsetPosFar );
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1236,6 +1266,13 @@ void CClient_Precipitation::DispatchInnerParticlePrecip( C_BasePlayer *pPlayer,
|
|||||||
Vector vOffsetPosFar = vPlayerPos + Vector ( 0, 0, 180 ) + ( vForward * m_flParticleInnerDist ); // 100.0
|
Vector vOffsetPosFar = vPlayerPos + Vector ( 0, 0, 180 ) + ( vForward * m_flParticleInnerDist ); // 100.0
|
||||||
Vector vDensity = Vector( r_RainParticleDensity.GetFloat(), 0, 0 ) * m_flDensity;
|
Vector vDensity = Vector( r_RainParticleDensity.GetFloat(), 0, 0 ) * m_flDensity;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if (m_spawnflags & SF_PRECIP_PARTICLE_CLAMP)
|
||||||
|
{
|
||||||
|
ClampParticlePosition( vPlayerPos, vOffsetPos, vOffsetPosNear, vOffsetPosFar );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
if (!(m_spawnflags & SF_PRECIP_PARTICLE_NO_OUTER))
|
if (!(m_spawnflags & SF_PRECIP_PARTICLE_NO_OUTER))
|
||||||
#endif
|
#endif
|
||||||
|
@ -130,6 +130,10 @@ private:
|
|||||||
void CreateAshParticle( void );
|
void CreateAshParticle( void );
|
||||||
void CreateRainOrSnowParticle( Vector vSpawnPosition, Vector vVelocity );
|
void CreateRainOrSnowParticle( Vector vSpawnPosition, Vector vVelocity );
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
void ClampParticlePosition( Vector &vPlayerPos, Vector &vOffsetPos, Vector &vOffsetPosNear, Vector &vOffsetPosFar );
|
||||||
|
#endif
|
||||||
|
|
||||||
// Information helpful in creating and rendering particles
|
// Information helpful in creating and rendering particles
|
||||||
IMaterial *m_MatHandle; // material used
|
IMaterial *m_MatHandle; // material used
|
||||||
|
|
||||||
|
@ -25,6 +25,11 @@ ConVar cl_globallight_freeze( "cl_globallight_freeze", "0" );
|
|||||||
// You can set these as KV anyway.
|
// You can set these as KV anyway.
|
||||||
ConVar cl_globallight_xoffset( "cl_globallight_xoffset", "0" );
|
ConVar cl_globallight_xoffset( "cl_globallight_xoffset", "0" );
|
||||||
ConVar cl_globallight_yoffset( "cl_globallight_yoffset", "0" );
|
ConVar cl_globallight_yoffset( "cl_globallight_yoffset", "0" );
|
||||||
|
|
||||||
|
static ConVar cl_globallight_slopescaledepthbias_shadowmap( "cl_globallight_slopescaledepthbias_shadowmap", "16", FCVAR_CHEAT );
|
||||||
|
static ConVar cl_globallight_shadowfiltersize( "cl_globallight_shadowfiltersize", "0.1", FCVAR_CHEAT );
|
||||||
|
static ConVar cl_globallight_depthbias_shadowmap( "cl_globallight_depthbias_shadowmap", "0.00001", FCVAR_CHEAT );
|
||||||
|
static ConVar cl_globallight_depthres( "cl_globallight_depthres", "8192", FCVAR_CHEAT );
|
||||||
#else
|
#else
|
||||||
ConVar cl_globallight_xoffset( "cl_globallight_xoffset", "-800" );
|
ConVar cl_globallight_xoffset( "cl_globallight_xoffset", "-800" );
|
||||||
ConVar cl_globallight_yoffset( "cl_globallight_yoffset", "1600" );
|
ConVar cl_globallight_yoffset( "cl_globallight_yoffset", "1600" );
|
||||||
@ -286,16 +291,21 @@ void C_GlobalLight::ClientThink()
|
|||||||
state.m_bOrtho = false;
|
state.m_bOrtho = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef MAPBASE // Don't draw that huge debug thing
|
#ifdef MAPBASE
|
||||||
|
//state.m_bDrawShadowFrustum = true; // Don't draw that huge debug thing
|
||||||
|
state.m_flShadowMapResolution = cl_globallight_depthres.GetFloat();
|
||||||
|
state.m_flShadowFilterSize = cl_globallight_shadowfiltersize.GetFloat();
|
||||||
|
state.m_flShadowSlopeScaleDepthBias = cl_globallight_slopescaledepthbias_shadowmap.GetFloat();
|
||||||
|
state.m_flShadowDepthBias = cl_globallight_depthbias_shadowmap.GetFloat();
|
||||||
|
state.m_bEnableShadows = m_bEnableShadows;
|
||||||
|
state.m_pSpotlightTexture = m_SpotlightTexture;
|
||||||
|
state.m_nSpotlightTextureFrame = m_nSpotlightTextureFrame;
|
||||||
|
#else
|
||||||
state.m_bDrawShadowFrustum = true;
|
state.m_bDrawShadowFrustum = true;
|
||||||
#endif
|
|
||||||
/*state.m_flShadowSlopeScaleDepthBias = g_pMaterialSystemHardwareConfig->GetShadowSlopeScaleDepthBias();;
|
/*state.m_flShadowSlopeScaleDepthBias = g_pMaterialSystemHardwareConfig->GetShadowSlopeScaleDepthBias();;
|
||||||
state.m_flShadowDepthBias = g_pMaterialSystemHardwareConfig->GetShadowDepthBias();*/
|
state.m_flShadowDepthBias = g_pMaterialSystemHardwareConfig->GetShadowDepthBias();*/
|
||||||
state.m_bEnableShadows = m_bEnableShadows;
|
state.m_bEnableShadows = m_bEnableShadows;
|
||||||
state.m_pSpotlightTexture = m_SpotlightTexture;
|
state.m_pSpotlightTexture = m_SpotlightTexture;
|
||||||
#ifdef MAPBASE
|
|
||||||
state.m_nSpotlightTextureFrame = m_nSpotlightTextureFrame;
|
|
||||||
#else
|
|
||||||
state.m_nSpotlightTextureFrame = 0;
|
state.m_nSpotlightTextureFrame = 0;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -25,8 +25,8 @@
|
|||||||
#include "tier0/memdbgon.h"
|
#include "tier0/memdbgon.h"
|
||||||
|
|
||||||
#ifdef ASW_PROJECTED_TEXTURES
|
#ifdef ASW_PROJECTED_TEXTURES
|
||||||
static ConVar mat_slopescaledepthbias_shadowmap( "mat_slopescaledepthbias_shadowmap", "16", FCVAR_CHEAT );
|
extern ConVarRef mat_slopescaledepthbias_shadowmap;
|
||||||
static ConVar mat_depthbias_shadowmap( "mat_depthbias_shadowmap", "0.00001", FCVAR_CHEAT );
|
extern ConVarRef mat_depthbias_shadowmap;
|
||||||
|
|
||||||
float C_EnvProjectedTexture::m_flVisibleBBoxMinHeight = -FLT_MAX;
|
float C_EnvProjectedTexture::m_flVisibleBBoxMinHeight = -FLT_MAX;
|
||||||
|
|
||||||
@ -60,6 +60,7 @@ IMPLEMENT_CLIENTCLASS_DT( C_EnvProjectedTexture, DT_EnvProjectedTexture, CEnvPro
|
|||||||
RecvPropFloat( RECVINFO( m_flLinearAtten ) ),
|
RecvPropFloat( RECVINFO( m_flLinearAtten ) ),
|
||||||
RecvPropFloat( RECVINFO( m_flQuadraticAtten ) ),
|
RecvPropFloat( RECVINFO( m_flQuadraticAtten ) ),
|
||||||
RecvPropFloat( RECVINFO( m_flShadowAtten ) ),
|
RecvPropFloat( RECVINFO( m_flShadowAtten ) ),
|
||||||
|
RecvPropFloat( RECVINFO( m_flShadowFilter ) ),
|
||||||
RecvPropBool( RECVINFO( m_bAlwaysDraw ) ),
|
RecvPropBool( RECVINFO( m_bAlwaysDraw ) ),
|
||||||
|
|
||||||
// Not needed on the client right now, change when it actually is needed
|
// Not needed on the client right now, change when it actually is needed
|
||||||
@ -97,6 +98,7 @@ C_EnvProjectedTexture *C_EnvProjectedTexture::Create( )
|
|||||||
pEnt->m_flLinearAtten = 100.0f;
|
pEnt->m_flLinearAtten = 100.0f;
|
||||||
pEnt->m_flQuadraticAtten = 0.0f;
|
pEnt->m_flQuadraticAtten = 0.0f;
|
||||||
pEnt->m_flShadowAtten = 0.0f;
|
pEnt->m_flShadowAtten = 0.0f;
|
||||||
|
pEnt->m_flShadowFilter = 0.5f;
|
||||||
//pEnt->m_bProjectedTextureVersion = 1;
|
//pEnt->m_bProjectedTextureVersion = 1;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -283,6 +285,8 @@ void C_EnvProjectedTexture::UpdateLight( void )
|
|||||||
|
|
||||||
// VectorNormalize( vRight );
|
// VectorNormalize( vRight );
|
||||||
// VectorNormalize( vUp );
|
// VectorNormalize( vUp );
|
||||||
|
|
||||||
|
VectorVectors( vForward, vRight, vUp );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -401,6 +405,7 @@ void C_EnvProjectedTexture::UpdateLight( void )
|
|||||||
state.m_flShadowSlopeScaleDepthBias = mat_slopescaledepthbias_shadowmap.GetFloat();
|
state.m_flShadowSlopeScaleDepthBias = mat_slopescaledepthbias_shadowmap.GetFloat();
|
||||||
state.m_flShadowDepthBias = mat_depthbias_shadowmap.GetFloat();
|
state.m_flShadowDepthBias = mat_depthbias_shadowmap.GetFloat();
|
||||||
state.m_flShadowAtten = m_flShadowAtten;
|
state.m_flShadowAtten = m_flShadowAtten;
|
||||||
|
state.m_flShadowFilterSize = m_flShadowFilter;
|
||||||
#else
|
#else
|
||||||
state.m_fQuadraticAtten = 0.0;
|
state.m_fQuadraticAtten = 0.0;
|
||||||
state.m_fLinearAtten = 100;
|
state.m_fLinearAtten = 100;
|
||||||
|
@ -48,6 +48,9 @@ protected:
|
|||||||
int m_iCachedDesiredOverlay;
|
int m_iCachedDesiredOverlay;
|
||||||
int m_iCurrentOverlay;
|
int m_iCurrentOverlay;
|
||||||
float m_flCurrentOverlayTime;
|
float m_flCurrentOverlayTime;
|
||||||
|
#ifdef MAPBASE
|
||||||
|
int m_iOverlayIndex;
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
IMPLEMENT_CLIENTCLASS_DT( C_EnvScreenOverlay, DT_EnvScreenOverlay, CEnvScreenOverlay )
|
IMPLEMENT_CLIENTCLASS_DT( C_EnvScreenOverlay, DT_EnvScreenOverlay, CEnvScreenOverlay )
|
||||||
@ -56,6 +59,9 @@ IMPLEMENT_CLIENTCLASS_DT( C_EnvScreenOverlay, DT_EnvScreenOverlay, CEnvScreenOve
|
|||||||
RecvPropFloat( RECVINFO( m_flStartTime ) ),
|
RecvPropFloat( RECVINFO( m_flStartTime ) ),
|
||||||
RecvPropInt( RECVINFO( m_iDesiredOverlay ) ),
|
RecvPropInt( RECVINFO( m_iDesiredOverlay ) ),
|
||||||
RecvPropBool( RECVINFO( m_bIsActive ) ),
|
RecvPropBool( RECVINFO( m_bIsActive ) ),
|
||||||
|
#ifdef MAPBASE
|
||||||
|
RecvPropInt( RECVINFO( m_iOverlayIndex ) ),
|
||||||
|
#endif
|
||||||
END_RECV_TABLE()
|
END_RECV_TABLE()
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -77,7 +83,11 @@ void C_EnvScreenOverlay::PostDataUpdate( DataUpdateType_t updateType )
|
|||||||
BaseClass::PostDataUpdate( updateType );
|
BaseClass::PostDataUpdate( updateType );
|
||||||
|
|
||||||
// If we have a start time now, start the overlays going
|
// If we have a start time now, start the overlays going
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if ( m_bIsActive && m_flStartTime > 0 && (view->GetScreenOverlayMaterial() == NULL || (m_iOverlayIndex != -1 && view->GetIndexedScreenOverlayMaterial(m_iOverlayIndex) == NULL)) )
|
||||||
|
#else
|
||||||
if ( m_bIsActive && m_flStartTime > 0 && view->GetScreenOverlayMaterial() == NULL )
|
if ( m_bIsActive && m_flStartTime > 0 && view->GetScreenOverlayMaterial() == NULL )
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
StartOverlays();
|
StartOverlays();
|
||||||
}
|
}
|
||||||
@ -111,7 +121,16 @@ void C_EnvScreenOverlay::StopOverlays( void )
|
|||||||
|
|
||||||
if ( m_bWasActive && !m_bIsActive )
|
if ( m_bWasActive && !m_bIsActive )
|
||||||
{
|
{
|
||||||
view->SetScreenOverlayMaterial( NULL );
|
#ifdef MAPBASE
|
||||||
|
if (m_iOverlayIndex != -1)
|
||||||
|
{
|
||||||
|
view->SetIndexedScreenOverlayMaterial( m_iOverlayIndex, NULL );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
view->SetScreenOverlayMaterial( NULL );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -163,7 +182,16 @@ void C_EnvScreenOverlay::StartCurrentOverlay( void )
|
|||||||
IMaterial *pMaterial = materials->FindMaterial( m_iszOverlayNames[m_iCurrentOverlay], TEXTURE_GROUP_CLIENT_EFFECTS, false );
|
IMaterial *pMaterial = materials->FindMaterial( m_iszOverlayNames[m_iCurrentOverlay], TEXTURE_GROUP_CLIENT_EFFECTS, false );
|
||||||
if ( !IsErrorMaterial( pMaterial ) )
|
if ( !IsErrorMaterial( pMaterial ) )
|
||||||
{
|
{
|
||||||
view->SetScreenOverlayMaterial( pMaterial );
|
#ifdef MAPBASE
|
||||||
|
if (m_iOverlayIndex != -1)
|
||||||
|
{
|
||||||
|
view->SetIndexedScreenOverlayMaterial( m_iOverlayIndex, pMaterial );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
view->SetScreenOverlayMaterial( pMaterial );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
|
|
||||||
|
|
||||||
#include "GameEventListener.h"
|
#include "GameEventListener.h"
|
||||||
#include "vgui_controls/phandle.h"
|
#include "vgui_controls/PHandle.h"
|
||||||
|
|
||||||
class CBaseLesson;
|
class CBaseLesson;
|
||||||
|
|
||||||
|
27
mp/src/game/client/c_movie_display.cpp
Normal file
27
mp/src/game/client/c_movie_display.cpp
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
//========= Copyright © 1996-2009, Valve Corporation, All rights reserved. ============//
|
||||||
|
//
|
||||||
|
// Purpose:
|
||||||
|
//
|
||||||
|
//
|
||||||
|
//=====================================================================================//
|
||||||
|
#include "cbase.h"
|
||||||
|
#include "c_movie_display.h"
|
||||||
|
|
||||||
|
// memdbgon must be the last include file in a .cpp file!!!
|
||||||
|
#include "tier0/memdbgon.h"
|
||||||
|
|
||||||
|
IMPLEMENT_CLIENTCLASS_DT( C_MovieDisplay, DT_MovieDisplay, CMovieDisplay )
|
||||||
|
RecvPropBool( RECVINFO( m_bEnabled ) ),
|
||||||
|
RecvPropBool( RECVINFO( m_bLooping ) ),
|
||||||
|
RecvPropBool( RECVINFO( m_bMuted ) ),
|
||||||
|
RecvPropString( RECVINFO( m_szMovieFilename ) ),
|
||||||
|
RecvPropString( RECVINFO( m_szGroupName ) ),
|
||||||
|
END_RECV_TABLE()
|
||||||
|
|
||||||
|
C_MovieDisplay::C_MovieDisplay()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
C_MovieDisplay::~C_MovieDisplay()
|
||||||
|
{
|
||||||
|
}
|
36
mp/src/game/client/c_movie_display.h
Normal file
36
mp/src/game/client/c_movie_display.h
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
//========= Copyright © 1996-2009, Valve Corporation, All rights reserved. ============//
|
||||||
|
//
|
||||||
|
// Purpose:
|
||||||
|
//
|
||||||
|
//=====================================================================================//
|
||||||
|
|
||||||
|
#ifndef C_MOVIE_DISPLAY_H
|
||||||
|
#define C_MOVIE_DISPLAY_H
|
||||||
|
|
||||||
|
#include "cbase.h"
|
||||||
|
|
||||||
|
class C_MovieDisplay : public C_BaseEntity
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
DECLARE_CLASS( C_MovieDisplay, C_BaseEntity );
|
||||||
|
DECLARE_CLIENTCLASS();
|
||||||
|
|
||||||
|
C_MovieDisplay();
|
||||||
|
~C_MovieDisplay();
|
||||||
|
|
||||||
|
bool IsEnabled( void ) const { return m_bEnabled; }
|
||||||
|
bool IsLooping( void ) const { return m_bLooping; }
|
||||||
|
bool IsMuted(void) const { return m_bMuted; }
|
||||||
|
|
||||||
|
const char *GetMovieFilename( void ) const { return m_szMovieFilename; }
|
||||||
|
const char *GetGroupName( void ) const { return m_szGroupName; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
bool m_bEnabled;
|
||||||
|
bool m_bLooping;
|
||||||
|
bool m_bMuted;
|
||||||
|
char m_szMovieFilename[128];
|
||||||
|
char m_szGroupName[128];
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif //C_MOVIE_DISPLAY_H
|
@ -42,6 +42,7 @@ protected:
|
|||||||
|
|
||||||
|
|
||||||
EHANDLE m_hControlPointEnts[kMAXCONTROLPOINTS];
|
EHANDLE m_hControlPointEnts[kMAXCONTROLPOINTS];
|
||||||
|
Vector m_vControlPointVecs[kMAXCONTROLPOINTS];
|
||||||
// SendPropArray3( SENDINFO_ARRAY3(m_iControlPointParents), SendPropInt( SENDINFO_ARRAY(m_iControlPointParents), 3, SPROP_UNSIGNED ) ),
|
// SendPropArray3( SENDINFO_ARRAY3(m_iControlPointParents), SendPropInt( SENDINFO_ARRAY(m_iControlPointParents), 3, SPROP_UNSIGNED ) ),
|
||||||
unsigned char m_iControlPointParents[kMAXCONTROLPOINTS];
|
unsigned char m_iControlPointParents[kMAXCONTROLPOINTS];
|
||||||
|
|
||||||
@ -65,6 +66,7 @@ BEGIN_RECV_TABLE_NOBASE( C_ParticleSystem, DT_ParticleSystem )
|
|||||||
RecvPropFloat( RECVINFO( m_flStartTime ) ),
|
RecvPropFloat( RECVINFO( m_flStartTime ) ),
|
||||||
|
|
||||||
RecvPropArray3( RECVINFO_ARRAY(m_hControlPointEnts), RecvPropEHandle( RECVINFO( m_hControlPointEnts[0] ) ) ),
|
RecvPropArray3( RECVINFO_ARRAY(m_hControlPointEnts), RecvPropEHandle( RECVINFO( m_hControlPointEnts[0] ) ) ),
|
||||||
|
RecvPropArray3( RECVINFO_ARRAY(m_vControlPointVecs), RecvPropVector( RECVINFO( m_vControlPointVecs[0] ) ) ),
|
||||||
RecvPropArray3( RECVINFO_ARRAY(m_iControlPointParents), RecvPropInt( RECVINFO(m_iControlPointParents[0]))),
|
RecvPropArray3( RECVINFO_ARRAY(m_iControlPointParents), RecvPropInt( RECVINFO(m_iControlPointParents[0]))),
|
||||||
RecvPropBool( RECVINFO( m_bWeatherEffect ) ),
|
RecvPropBool( RECVINFO( m_bWeatherEffect ) ),
|
||||||
END_RECV_TABLE();
|
END_RECV_TABLE();
|
||||||
@ -150,21 +152,41 @@ void C_ParticleSystem::ClientThink( void )
|
|||||||
AssertMsg1( pEffect, "Particle system couldn't make %s", pszName );
|
AssertMsg1( pEffect, "Particle system couldn't make %s", pszName );
|
||||||
if (pEffect)
|
if (pEffect)
|
||||||
{
|
{
|
||||||
for ( int i = 0 ; i < kMAXCONTROLPOINTS ; ++i )
|
if (m_vControlPointVecs[0] != GetAbsOrigin() && m_hControlPointEnts[0] == NULL)
|
||||||
{
|
{
|
||||||
CBaseEntity *pOnEntity = m_hControlPointEnts[i].Get();
|
// we are using info_particle_system_coordinate
|
||||||
if ( pOnEntity )
|
for (int i = 0; i < kMAXCONTROLPOINTS; ++i)
|
||||||
{
|
{
|
||||||
ParticleProp()->AddControlPoint( pEffect, i + 1, pOnEntity, PATTACH_ABSORIGIN_FOLLOW );
|
ParticleProp()->AddControlPoint(pEffect, i + 1, this, PATTACH_WORLDORIGIN, 0, m_vControlPointVecs[i] - GetAbsOrigin());
|
||||||
|
|
||||||
|
AssertMsg2(m_iControlPointParents[i] >= 0 && m_iControlPointParents[i] <= kMAXCONTROLPOINTS,
|
||||||
|
"Particle system specified bogus control point parent (%d) for point %d.",
|
||||||
|
m_iControlPointParents[i], i);
|
||||||
|
|
||||||
|
if (m_iControlPointParents[i] != 0)
|
||||||
|
{
|
||||||
|
pEffect->SetControlPointParent(i + 1, m_iControlPointParents[i]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
AssertMsg2( m_iControlPointParents[i] >= 0 && m_iControlPointParents[i] <= kMAXCONTROLPOINTS ,
|
else
|
||||||
"Particle system specified bogus control point parent (%d) for point %d.",
|
{
|
||||||
m_iControlPointParents[i], i );
|
for ( int i = 0 ; i < kMAXCONTROLPOINTS ; ++i )
|
||||||
|
|
||||||
if (m_iControlPointParents[i] != 0)
|
|
||||||
{
|
{
|
||||||
pEffect->SetControlPointParent(i+1, m_iControlPointParents[i]);
|
CBaseEntity *pOnEntity = m_hControlPointEnts[i].Get();
|
||||||
|
if ( pOnEntity )
|
||||||
|
{
|
||||||
|
ParticleProp()->AddControlPoint( pEffect, i + 1, pOnEntity, PATTACH_ABSORIGIN_FOLLOW );
|
||||||
|
}
|
||||||
|
|
||||||
|
AssertMsg2( m_iControlPointParents[i] >= 0 && m_iControlPointParents[i] <= kMAXCONTROLPOINTS ,
|
||||||
|
"Particle system specified bogus control point parent (%d) for point %d.",
|
||||||
|
m_iControlPointParents[i], i );
|
||||||
|
|
||||||
|
if (m_iControlPointParents[i] != 0)
|
||||||
|
{
|
||||||
|
pEffect->SetControlPointParent(i+1, m_iControlPointParents[i]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -24,6 +24,11 @@ BEGIN_NETWORK_TABLE( CDynamicProp, DT_DynamicProp )
|
|||||||
RecvPropBool(RECVINFO(m_bUseHitboxesForRenderBox)),
|
RecvPropBool(RECVINFO(m_bUseHitboxesForRenderBox)),
|
||||||
END_NETWORK_TABLE()
|
END_NETWORK_TABLE()
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
// Allows client-side VScript to create dynamic props via CreateProp()
|
||||||
|
LINK_ENTITY_TO_CLASS( prop_dynamic, C_DynamicProp );
|
||||||
|
#endif
|
||||||
|
|
||||||
C_DynamicProp::C_DynamicProp( void )
|
C_DynamicProp::C_DynamicProp( void )
|
||||||
{
|
{
|
||||||
m_iCachedFrameCount = -1;
|
m_iCachedFrameCount = -1;
|
||||||
|
@ -74,6 +74,27 @@ IMPLEMENT_CLIENTCLASS_DT_NOBASE( C_RopeKeyframe, DT_RopeKeyframe, CRopeKeyframe
|
|||||||
RecvPropInt( RECVINFO( m_iParentAttachment ) ),
|
RecvPropInt( RECVINFO( m_iParentAttachment ) ),
|
||||||
END_RECV_TABLE()
|
END_RECV_TABLE()
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
BEGIN_ENT_SCRIPTDESC( C_RopeKeyframe, C_BaseEntity, "The clientside class of move_rope and keyframe_rope" )
|
||||||
|
DEFINE_SCRIPTFUNC( GetNodePosition, "Gets the position of the specified node index" )
|
||||||
|
DEFINE_SCRIPTFUNC( GetNumNodes, "Gets the number of nodes available" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetStartEntity, "GetStartEntity", "Gets the rope's start entity" )
|
||||||
|
DEFINE_SCRIPTFUNC_NAMED( ScriptGetEndEntity, "GetEndEntity", "Gets the rope's end entity" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( SetupHangDistance, "Sets the rope's hang distance" )
|
||||||
|
DEFINE_SCRIPTFUNC( SetSlack, "Sets the rope's slack value (extra length)" )
|
||||||
|
DEFINE_SCRIPTFUNC( GetRopeFlags, "Gets the rope's flags" )
|
||||||
|
DEFINE_SCRIPTFUNC( SetRopeFlags, "Sets the rope's flags" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( SetColorMod, "Sets the rope's color mod value" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( ShakeRope, "Shakes the rope with the specified center, radius, and magnitude" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( AnyPointsMoved, "Returns true if any points have moved recently" )
|
||||||
|
END_SCRIPTDESC();
|
||||||
|
#endif
|
||||||
|
|
||||||
#define ROPE_IMPULSE_SCALE 20
|
#define ROPE_IMPULSE_SCALE 20
|
||||||
#define ROPE_IMPULSE_DECAY 0.95
|
#define ROPE_IMPULSE_DECAY 0.95
|
||||||
|
|
||||||
@ -2032,6 +2053,25 @@ bool C_RopeKeyframe::GetAttachment( int number, Vector &origin, QAngle &angles )
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
const Vector &C_RopeKeyframe::GetNodePosition( int index )
|
||||||
|
{
|
||||||
|
int nNodes = m_RopePhysics.NumNodes();
|
||||||
|
if ( index >= nNodes || nNodes < 2 )
|
||||||
|
{
|
||||||
|
Warning( "C_RopeKeyframe::GetNodePosition(): Invalid node index %i (number of nodes is %i)\n", index, nNodes );
|
||||||
|
return vec3_origin;
|
||||||
|
}
|
||||||
|
|
||||||
|
return m_RopePhysics.GetNode( index )->m_vPredicted;
|
||||||
|
}
|
||||||
|
|
||||||
|
int C_RopeKeyframe::GetNumNodes()
|
||||||
|
{
|
||||||
|
return m_RopePhysics.NumNodes();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
bool C_RopeKeyframe::AnyPointsMoved()
|
bool C_RopeKeyframe::AnyPointsMoved()
|
||||||
{
|
{
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
|
@ -33,6 +33,9 @@ public:
|
|||||||
DECLARE_CLASS( C_RopeKeyframe, C_BaseEntity );
|
DECLARE_CLASS( C_RopeKeyframe, C_BaseEntity );
|
||||||
DECLARE_CLIENTCLASS();
|
DECLARE_CLIENTCLASS();
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
DECLARE_ENT_SCRIPTDESC();
|
||||||
|
#endif
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
@ -142,6 +145,11 @@ public:
|
|||||||
virtual bool GetAttachment( int number, Vector &origin );
|
virtual bool GetAttachment( int number, Vector &origin );
|
||||||
virtual bool GetAttachmentVelocity( int number, Vector &originVel, Quaternion &angleVel );
|
virtual bool GetAttachmentVelocity( int number, Vector &originVel, Quaternion &angleVel );
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
const Vector &GetNodePosition( int index );
|
||||||
|
int GetNumNodes();
|
||||||
|
#endif
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
void FinishInit( const char *pMaterialName );
|
void FinishInit( const char *pMaterialName );
|
||||||
@ -166,6 +174,11 @@ private:
|
|||||||
void ReceiveMessage( int classID, bf_read &msg );
|
void ReceiveMessage( int classID, bf_read &msg );
|
||||||
bool CalculateEndPointAttachment( C_BaseEntity *pEnt, int iAttachment, Vector &vPos, QAngle *pAngles );
|
bool CalculateEndPointAttachment( C_BaseEntity *pEnt, int iAttachment, Vector &vPos, QAngle *pAngles );
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
HSCRIPT ScriptGetStartEntity() { return ToHScript( GetStartEntity() ); }
|
||||||
|
HSCRIPT ScriptGetEndEntity() { return ToHScript( GetEndEntity() ); }
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// Track which links touched something last frame. Used to prevent wind from gusting on them.
|
// Track which links touched something last frame. Used to prevent wind from gusting on them.
|
||||||
|
@ -112,6 +112,15 @@ public:
|
|||||||
C_BasePlayer *GetPlayerOwner( void );
|
C_BasePlayer *GetPlayerOwner( void );
|
||||||
bool IsInputOnlyToOwner( void );
|
bool IsInputOnlyToOwner( void );
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
void GetSize( float &width, float &height ) const { width = m_flWidth; height = m_flHeight; }
|
||||||
|
void GetPixelSize( int &width, int &height ) const { width = m_nPixelWidth; height = m_nPixelHeight; }
|
||||||
|
void SetWidth( float flWidth ) { m_flWidth = flWidth; }
|
||||||
|
void SetHeight( float flHeight ) { m_flHeight = flHeight; }
|
||||||
|
void SetPixelWidth( int nWidth ) { m_nPixelWidth = nWidth; }
|
||||||
|
void SetPixelHeight( int nHeight ) { m_nPixelHeight = nHeight; }
|
||||||
|
#endif
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// Vgui screen management
|
// Vgui screen management
|
||||||
void CreateVguiScreen( const char *pTypeName );
|
void CreateVguiScreen( const char *pTypeName );
|
||||||
|
@ -13,6 +13,9 @@
|
|||||||
#include "ivieweffects.h"
|
#include "ivieweffects.h"
|
||||||
#include "shake.h"
|
#include "shake.h"
|
||||||
#include "eventlist.h"
|
#include "eventlist.h"
|
||||||
|
#ifdef MAPBASE
|
||||||
|
#include "mapentities_shared.h"
|
||||||
|
#endif
|
||||||
// NVNT haptic include for notification of world precache
|
// NVNT haptic include for notification of world precache
|
||||||
#include "haptics/haptic_utils.h"
|
#include "haptics/haptic_utils.h"
|
||||||
// memdbgon must be the last include file in a .cpp file!!!
|
// memdbgon must be the last include file in a .cpp file!!!
|
||||||
@ -62,9 +65,6 @@ BEGIN_RECV_TABLE( C_World, DT_World )
|
|||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
RecvPropString(RECVINFO(m_iszChapterTitle)),
|
RecvPropString(RECVINFO(m_iszChapterTitle)),
|
||||||
#endif
|
#endif
|
||||||
#ifdef MAPBASE_VSCRIPT
|
|
||||||
RecvPropInt(RECVINFO(m_iScriptLanguageClient)),
|
|
||||||
#endif
|
|
||||||
END_RECV_TABLE()
|
END_RECV_TABLE()
|
||||||
|
|
||||||
#ifdef MAPBASE_VSCRIPT
|
#ifdef MAPBASE_VSCRIPT
|
||||||
@ -86,6 +86,11 @@ bool C_World::Init( int entnum, int iSerialNum )
|
|||||||
ActivityList_Init();
|
ActivityList_Init();
|
||||||
EventList_Init();
|
EventList_Init();
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
m_iScriptLanguageServer = SL_NONE;
|
||||||
|
m_iScriptLanguageClient = SL_NONE;
|
||||||
|
#endif
|
||||||
|
|
||||||
return BaseClass::Init( entnum, iSerialNum );
|
return BaseClass::Init( entnum, iSerialNum );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -129,11 +134,6 @@ void C_World::OnDataChanged( DataUpdateType_t updateType )
|
|||||||
engine->SetOcclusionParameters( params );
|
engine->SetOcclusionParameters( params );
|
||||||
|
|
||||||
modelinfo->SetLevelScreenFadeRange( m_flMinPropScreenSpaceWidth, m_flMaxPropScreenSpaceWidth );
|
modelinfo->SetLevelScreenFadeRange( m_flMinPropScreenSpaceWidth, m_flMaxPropScreenSpaceWidth );
|
||||||
|
|
||||||
#ifdef MAPBASE_VSCRIPT
|
|
||||||
// This is now here so that C_World has time to receive the selected script language
|
|
||||||
VScriptClientInit();
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -199,6 +199,72 @@ void C_World::Spawn( void )
|
|||||||
Precache();
|
Precache();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Parse data from a map file
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
bool C_World::KeyValue( const char *szKeyName, const char *szValue )
|
||||||
|
{
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
if ( FStrEq( szKeyName, "vscriptlanguage" ) )
|
||||||
|
{
|
||||||
|
m_iScriptLanguageServer = atoi( szValue );
|
||||||
|
}
|
||||||
|
else if ( FStrEq( szKeyName, "vscriptlanguage_client" ) )
|
||||||
|
{
|
||||||
|
m_iScriptLanguageClient = atoi( szValue );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
return BaseClass::KeyValue( szKeyName, szValue );
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Parses worldspawn data from BSP on the client
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void C_World::ParseWorldMapData( const char *pMapData )
|
||||||
|
{
|
||||||
|
char szTokenBuffer[MAPKEY_MAXLENGTH];
|
||||||
|
for ( ; true; pMapData = MapEntity_SkipToNextEntity(pMapData, szTokenBuffer) )
|
||||||
|
{
|
||||||
|
//
|
||||||
|
// Parse the opening brace.
|
||||||
|
//
|
||||||
|
char token[MAPKEY_MAXLENGTH];
|
||||||
|
pMapData = MapEntity_ParseToken( pMapData, token );
|
||||||
|
|
||||||
|
//
|
||||||
|
// Check to see if we've finished or not.
|
||||||
|
//
|
||||||
|
if (!pMapData)
|
||||||
|
break;
|
||||||
|
|
||||||
|
if (token[0] != '{')
|
||||||
|
{
|
||||||
|
Error( "MapEntity_ParseAllEntities: found %s when expecting {", token);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
CEntityMapData entData( (char*)pMapData );
|
||||||
|
char className[MAPKEY_MAXLENGTH];
|
||||||
|
|
||||||
|
if (!entData.ExtractValue( "classname", className ))
|
||||||
|
{
|
||||||
|
Error( "classname missing from entity!\n" );
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( !Q_strcmp( className, "worldspawn" ) )
|
||||||
|
{
|
||||||
|
// Set up keyvalues.
|
||||||
|
ParseMapData( &entData );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
C_World *GetClientWorldEntity()
|
C_World *GetClientWorldEntity()
|
||||||
|
@ -31,6 +31,7 @@ public:
|
|||||||
|
|
||||||
virtual void Precache();
|
virtual void Precache();
|
||||||
virtual void Spawn();
|
virtual void Spawn();
|
||||||
|
virtual bool KeyValue( const char *szKeyName, const char *szValue );
|
||||||
|
|
||||||
// Don't worry about adding the world to the collision list; it's already there
|
// Don't worry about adding the world to the collision list; it's already there
|
||||||
virtual CollideType_t GetCollideType( void ) { return ENTITY_SHOULD_NOT_COLLIDE; }
|
virtual CollideType_t GetCollideType( void ) { return ENTITY_SHOULD_NOT_COLLIDE; }
|
||||||
@ -41,8 +42,17 @@ public:
|
|||||||
float GetWaveHeight() const;
|
float GetWaveHeight() const;
|
||||||
const char *GetDetailSpriteMaterial() const;
|
const char *GetDetailSpriteMaterial() const;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
// A special function which parses map data for the client world entity before LevelInitPreEntity().
|
||||||
|
// This can be used to access keyvalues early and without transmitting from the server.
|
||||||
|
void ParseWorldMapData( const char *pMapData );
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef MAPBASE_VSCRIPT
|
#ifdef MAPBASE_VSCRIPT
|
||||||
ScriptLanguage_t GetScriptLanguage() { return (ScriptLanguage_t)m_iScriptLanguageClient; }
|
void ClientThink() { ScriptContextThink(); }
|
||||||
|
|
||||||
|
// -2 = Use server language
|
||||||
|
ScriptLanguage_t GetScriptLanguage() { return (ScriptLanguage_t)(m_iScriptLanguageClient != -2 ? m_iScriptLanguageClient : m_iScriptLanguageServer); }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
public:
|
public:
|
||||||
@ -64,6 +74,7 @@ public:
|
|||||||
char m_iszChapterTitle[64];
|
char m_iszChapterTitle[64];
|
||||||
#endif
|
#endif
|
||||||
#ifdef MAPBASE_VSCRIPT
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
int m_iScriptLanguageServer;
|
||||||
int m_iScriptLanguageClient;
|
int m_iScriptLanguageClient;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -148,6 +148,10 @@
|
|||||||
#include "fbxsystem/fbxsystem.h"
|
#include "fbxsystem/fbxsystem.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
#include "vscript_client.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
extern vgui::IInputInternal *g_InputInternal;
|
extern vgui::IInputInternal *g_InputInternal;
|
||||||
|
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
@ -271,6 +275,8 @@ void ProcessCacheUsedMaterials()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void VGui_ClearVideoPanels();
|
||||||
|
|
||||||
// String tables
|
// String tables
|
||||||
INetworkStringTable *g_pStringTableParticleEffectNames = NULL;
|
INetworkStringTable *g_pStringTableParticleEffectNames = NULL;
|
||||||
INetworkStringTable *g_StringTableEffectDispatch = NULL;
|
INetworkStringTable *g_StringTableEffectDispatch = NULL;
|
||||||
@ -1108,6 +1114,9 @@ int CHLClient::Init( CreateInterfaceFn appSystemFactory, CreateInterfaceFn physi
|
|||||||
g_pGameSaveRestoreBlockSet->AddBlockHandler( GetEntitySaveRestoreBlockHandler() );
|
g_pGameSaveRestoreBlockSet->AddBlockHandler( GetEntitySaveRestoreBlockHandler() );
|
||||||
g_pGameSaveRestoreBlockSet->AddBlockHandler( GetPhysSaveRestoreBlockHandler() );
|
g_pGameSaveRestoreBlockSet->AddBlockHandler( GetPhysSaveRestoreBlockHandler() );
|
||||||
g_pGameSaveRestoreBlockSet->AddBlockHandler( GetViewEffectsRestoreBlockHandler() );
|
g_pGameSaveRestoreBlockSet->AddBlockHandler( GetViewEffectsRestoreBlockHandler() );
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
g_pGameSaveRestoreBlockSet->AddBlockHandler( GetVScriptSaveRestoreBlockHandler() );
|
||||||
|
#endif
|
||||||
|
|
||||||
ClientWorldFactoryInit();
|
ClientWorldFactoryInit();
|
||||||
|
|
||||||
@ -1214,12 +1223,17 @@ void CHLClient::Shutdown( void )
|
|||||||
g_pSixenseInput = NULL;
|
g_pSixenseInput = NULL;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
VGui_ClearVideoPanels();
|
||||||
|
|
||||||
C_BaseAnimating::ShutdownBoneSetupThreadPool();
|
C_BaseAnimating::ShutdownBoneSetupThreadPool();
|
||||||
ClientWorldFactoryShutdown();
|
ClientWorldFactoryShutdown();
|
||||||
|
|
||||||
g_pGameSaveRestoreBlockSet->RemoveBlockHandler( GetViewEffectsRestoreBlockHandler() );
|
g_pGameSaveRestoreBlockSet->RemoveBlockHandler( GetViewEffectsRestoreBlockHandler() );
|
||||||
g_pGameSaveRestoreBlockSet->RemoveBlockHandler( GetPhysSaveRestoreBlockHandler() );
|
g_pGameSaveRestoreBlockSet->RemoveBlockHandler( GetPhysSaveRestoreBlockHandler() );
|
||||||
g_pGameSaveRestoreBlockSet->RemoveBlockHandler( GetEntitySaveRestoreBlockHandler() );
|
g_pGameSaveRestoreBlockSet->RemoveBlockHandler( GetEntitySaveRestoreBlockHandler() );
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
g_pGameSaveRestoreBlockSet->RemoveBlockHandler( GetVScriptSaveRestoreBlockHandler() );
|
||||||
|
#endif
|
||||||
|
|
||||||
ClientVoiceMgr_Shutdown();
|
ClientVoiceMgr_Shutdown();
|
||||||
|
|
||||||
@ -1639,6 +1653,10 @@ void CHLClient::LevelInitPreEntity( char const* pMapName )
|
|||||||
tempents->LevelInit();
|
tempents->LevelInit();
|
||||||
ResetToneMapping(1.0);
|
ResetToneMapping(1.0);
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
GetClientWorldEntity()->ParseWorldMapData( engine->GetMapEntitiesString() );
|
||||||
|
#endif
|
||||||
|
|
||||||
IGameSystem::LevelInitPreEntityAllSystems(pMapName);
|
IGameSystem::LevelInitPreEntityAllSystems(pMapName);
|
||||||
|
|
||||||
#ifdef USES_ECON_ITEMS
|
#ifdef USES_ECON_ITEMS
|
||||||
|
@ -166,7 +166,6 @@ inline bool FStrEq(const char *sz1, const char *sz2)
|
|||||||
{
|
{
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
// V_stricmp() already checks if the pointers are equal, so having a comparison here is pointless.
|
// V_stricmp() already checks if the pointers are equal, so having a comparison here is pointless.
|
||||||
// I had few reasons to do this, but maybe you'll thank me later.
|
|
||||||
return ( V_stricmp(sz1, sz2) == 0 );
|
return ( V_stricmp(sz1, sz2) == 0 );
|
||||||
#else
|
#else
|
||||||
return ( sz1 == sz2 || V_stricmp(sz1, sz2) == 0 );
|
return ( sz1 == sz2 || V_stricmp(sz1, sz2) == 0 );
|
||||||
|
@ -535,7 +535,6 @@ $Project
|
|||||||
"$SRCDIR\public\dt_utlvector_recv.cpp" \
|
"$SRCDIR\public\dt_utlvector_recv.cpp" \
|
||||||
"$SRCDIR\public\filesystem_helpers.cpp" \
|
"$SRCDIR\public\filesystem_helpers.cpp" \
|
||||||
"$SRCDIR\public\interpolatortypes.cpp" \
|
"$SRCDIR\public\interpolatortypes.cpp" \
|
||||||
"$SRCDIR\game\shared\interval.cpp" \
|
|
||||||
"$SRCDIR\common\language.cpp" \
|
"$SRCDIR\common\language.cpp" \
|
||||||
"$SRCDIR\public\networkvar.cpp" \
|
"$SRCDIR\public\networkvar.cpp" \
|
||||||
"$SRCDIR\common\randoverride.cpp" \
|
"$SRCDIR\common\randoverride.cpp" \
|
||||||
@ -1106,6 +1105,7 @@ $Project
|
|||||||
$File "$SRCDIR\public\vgui_controls\WizardSubPanel.h"
|
$File "$SRCDIR\public\vgui_controls\WizardSubPanel.h"
|
||||||
$File "$SRCDIR\public\worldsize.h"
|
$File "$SRCDIR\public\worldsize.h"
|
||||||
$File "$SRCDIR\public\zip_uncompressed.h"
|
$File "$SRCDIR\public\zip_uncompressed.h"
|
||||||
|
$File "$SRCDIR\public\tier1\interval.h"
|
||||||
//Haptics
|
//Haptics
|
||||||
$File "$SRCDIR\public\haptics\ihaptics.h" [$WIN32]
|
$File "$SRCDIR\public\haptics\ihaptics.h" [$WIN32]
|
||||||
$File "$SRCDIR\public\haptics\haptic_utils.h" [$WIN32]
|
$File "$SRCDIR\public\haptics\haptic_utils.h" [$WIN32]
|
||||||
@ -1162,7 +1162,6 @@ $Project
|
|||||||
$File "$SRCDIR\game\shared\igamesystem.h"
|
$File "$SRCDIR\game\shared\igamesystem.h"
|
||||||
$File "$SRCDIR\game\shared\imovehelper.h"
|
$File "$SRCDIR\game\shared\imovehelper.h"
|
||||||
$File "$SRCDIR\game\shared\in_buttons.h"
|
$File "$SRCDIR\game\shared\in_buttons.h"
|
||||||
$File "$SRCDIR\game\shared\interval.h"
|
|
||||||
$File "$SRCDIR\game\shared\iplayeranimstate.h"
|
$File "$SRCDIR\game\shared\iplayeranimstate.h"
|
||||||
$File "$SRCDIR\game\shared\ipredictionsystem.h"
|
$File "$SRCDIR\game\shared\ipredictionsystem.h"
|
||||||
$File "$SRCDIR\game\shared\itempents.h"
|
$File "$SRCDIR\game\shared\itempents.h"
|
||||||
@ -1260,6 +1259,9 @@ $Project
|
|||||||
$Lib vtf
|
$Lib vtf
|
||||||
$ImpLib steam_api
|
$ImpLib steam_api
|
||||||
|
|
||||||
|
// Discord integration
|
||||||
|
$Lib "$LIBPUBLIC\discord-rpc" [$MAPBASE_RPC]
|
||||||
|
|
||||||
$Libexternal $LIBCOMMON/libcrypto [$OSXALL]
|
$Libexternal $LIBCOMMON/libcrypto [$OSXALL]
|
||||||
$Libexternal "$SRCDIR\lib\common\$(CRYPTOPPDIR)\libcrypto" [$LINUXALL]
|
$Libexternal "$SRCDIR\lib\common\$(CRYPTOPPDIR)\libcrypto" [$LINUXALL]
|
||||||
|
|
||||||
|
@ -12,6 +12,7 @@ $Configuration
|
|||||||
|
|
||||||
$PreprocessorDefinitions "$BASE;MAPBASE_RPC;DISCORD_RPC;STEAM_RPC" [$MAPBASE_RPC]
|
$PreprocessorDefinitions "$BASE;MAPBASE_RPC;DISCORD_RPC;STEAM_RPC" [$MAPBASE_RPC]
|
||||||
$PreprocessorDefinitions "$BASE;MAPBASE_VSCRIPT" [$MAPBASE_VSCRIPT]
|
$PreprocessorDefinitions "$BASE;MAPBASE_VSCRIPT" [$MAPBASE_VSCRIPT]
|
||||||
|
$PreprocessorDefinitions "$BASE;NEW_RESPONSE_SYSTEM" [$NEW_RESPONSE_SYSTEM]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -31,16 +32,23 @@ $Project
|
|||||||
$File "c_postprocesscontroller.cpp"
|
$File "c_postprocesscontroller.cpp"
|
||||||
$File "c_postprocesscontroller.h"
|
$File "c_postprocesscontroller.h"
|
||||||
$File "c_env_dof_controller.cpp"
|
$File "c_env_dof_controller.cpp"
|
||||||
|
$File "c_movie_display.cpp"
|
||||||
|
$File "c_movie_display.h"
|
||||||
|
$File "vgui_movie_display.cpp"
|
||||||
|
$File "convarproxy.cpp"
|
||||||
|
|
||||||
$Folder "Mapbase"
|
$Folder "Mapbase"
|
||||||
{
|
{
|
||||||
$File "$SRCDIR\game\shared\mapbase\mapbase_shared.cpp"
|
$File "$SRCDIR\game\shared\mapbase\mapbase_shared.cpp"
|
||||||
|
$File "$SRCDIR\game\shared\mapbase\mapbase_usermessages.cpp"
|
||||||
$File "$SRCDIR\game\shared\mapbase\mapbase_rpc.cpp"
|
$File "$SRCDIR\game\shared\mapbase\mapbase_rpc.cpp"
|
||||||
$File "$SRCDIR\game\shared\mapbase\mapbase_game_log.cpp"
|
$File "$SRCDIR\game\shared\mapbase\mapbase_game_log.cpp"
|
||||||
$File "$SRCDIR\game\shared\mapbase\MapEdit.cpp"
|
$File "$SRCDIR\game\shared\mapbase\MapEdit.cpp"
|
||||||
$File "$SRCDIR\game\shared\mapbase\MapEdit.h"
|
$File "$SRCDIR\game\shared\mapbase\MapEdit.h"
|
||||||
$File "$SRCDIR\game\shared\mapbase\matchers.cpp"
|
$File "$SRCDIR\game\shared\mapbase\matchers.cpp"
|
||||||
$File "$SRCDIR\game\shared\mapbase\matchers.h"
|
$File "$SRCDIR\game\shared\mapbase\matchers.h"
|
||||||
|
$File "$SRCDIR\game\shared\mapbase\singleplayer_animstate.cpp"
|
||||||
|
$File "$SRCDIR\game\shared\mapbase\singleplayer_animstate.h"
|
||||||
$File "$SRCDIR\game\shared\mapbase\vscript_funcs_shared.cpp" [$MAPBASE_VSCRIPT]
|
$File "$SRCDIR\game\shared\mapbase\vscript_funcs_shared.cpp" [$MAPBASE_VSCRIPT]
|
||||||
$File "$SRCDIR\game\shared\mapbase\vscript_funcs_shared.h" [$MAPBASE_VSCRIPT]
|
$File "$SRCDIR\game\shared\mapbase\vscript_funcs_shared.h" [$MAPBASE_VSCRIPT]
|
||||||
$File "$SRCDIR\game\shared\mapbase\vscript_singletons.cpp" [$MAPBASE_VSCRIPT]
|
$File "$SRCDIR\game\shared\mapbase\vscript_singletons.cpp" [$MAPBASE_VSCRIPT]
|
||||||
@ -50,11 +58,18 @@ $Project
|
|||||||
$File "$SRCDIR\game\shared\mapbase\vscript_consts_weapons.cpp" [$MAPBASE_VSCRIPT]
|
$File "$SRCDIR\game\shared\mapbase\vscript_consts_weapons.cpp" [$MAPBASE_VSCRIPT]
|
||||||
$File "$SRCDIR\game\shared\mapbase\weapon_custom_scripted.cpp" [$MAPBASE_VSCRIPT]
|
$File "$SRCDIR\game\shared\mapbase\weapon_custom_scripted.cpp" [$MAPBASE_VSCRIPT]
|
||||||
$File "$SRCDIR\game\shared\mapbase\weapon_custom_scripted.h" [$MAPBASE_VSCRIPT]
|
$File "$SRCDIR\game\shared\mapbase\weapon_custom_scripted.h" [$MAPBASE_VSCRIPT]
|
||||||
|
$File "$SRCDIR\game\shared\mapbase\logic_script_client.cpp" [$MAPBASE_VSCRIPT]
|
||||||
|
|
||||||
|
$File "mapbase\vscript_vgui.cpp" [$MAPBASE_VSCRIPT]
|
||||||
|
$File "mapbase\vscript_vgui.h" [$MAPBASE_VSCRIPT]
|
||||||
|
$File "mapbase\vscript_vgui.nut" [$MAPBASE_VSCRIPT]
|
||||||
|
|
||||||
$File "mapbase\c_func_clientclip.cpp"
|
$File "mapbase\c_func_clientclip.cpp"
|
||||||
$File "mapbase\c_func_fake_worldportal.cpp"
|
$File "mapbase\c_func_fake_worldportal.cpp"
|
||||||
$File "mapbase\c_func_fake_worldportal.h"
|
$File "mapbase\c_func_fake_worldportal.h"
|
||||||
$File "mapbase\c_point_glow.cpp"
|
$File "mapbase\c_point_glow.cpp"
|
||||||
|
$File "mapbase\c_vgui_text_display.cpp"
|
||||||
|
$File "mapbase\mapbase_autocubemap.cpp"
|
||||||
}
|
}
|
||||||
|
|
||||||
$Folder "HL2 DLL"
|
$Folder "HL2 DLL"
|
||||||
|
@ -298,8 +298,11 @@ ClientModeShared::ClientModeShared()
|
|||||||
m_pWeaponSelection = NULL;
|
m_pWeaponSelection = NULL;
|
||||||
m_nRootSize[ 0 ] = m_nRootSize[ 1 ] = -1;
|
m_nRootSize[ 0 ] = m_nRootSize[ 1 ] = -1;
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
m_pCurrentPostProcessController = NULL;
|
m_pCurrentPostProcessController = NULL;
|
||||||
m_PostProcessLerpTimer.Invalidate();
|
m_PostProcessLerpTimer.Invalidate();
|
||||||
|
m_pCurrentColorCorrection = NULL;
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined( REPLAY_ENABLED )
|
#if defined( REPLAY_ENABLED )
|
||||||
m_pReplayReminderPanel = NULL;
|
m_pReplayReminderPanel = NULL;
|
||||||
@ -656,6 +659,43 @@ void ClientModeShared::Update()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void ClientModeShared::OnColorCorrectionWeightsReset( void )
|
||||||
|
{
|
||||||
|
C_ColorCorrection *pNewColorCorrection = NULL;
|
||||||
|
C_ColorCorrection *pOldColorCorrection = m_pCurrentColorCorrection;
|
||||||
|
C_BasePlayer* pPlayer = C_BasePlayer::GetLocalPlayer();
|
||||||
|
if ( pPlayer )
|
||||||
|
{
|
||||||
|
pNewColorCorrection = pPlayer->GetActiveColorCorrection();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( pNewColorCorrection != pOldColorCorrection )
|
||||||
|
{
|
||||||
|
if ( pOldColorCorrection )
|
||||||
|
{
|
||||||
|
pOldColorCorrection->EnableOnClient( false );
|
||||||
|
}
|
||||||
|
if ( pNewColorCorrection )
|
||||||
|
{
|
||||||
|
pNewColorCorrection->EnableOnClient( true, pOldColorCorrection == NULL );
|
||||||
|
}
|
||||||
|
m_pCurrentColorCorrection = pNewColorCorrection;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
float ClientModeShared::GetColorCorrectionScale( void ) const
|
||||||
|
{
|
||||||
|
return 1.0f;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// This processes all input before SV Move messages are sent
|
// This processes all input before SV Move messages are sent
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -1280,7 +1320,7 @@ void ClientModeShared::FireGameEvent( IGameEvent *event )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( team == 0 && GetLocalTeam() > 0 )
|
if ( team == 0 && GetLocalTeam() )
|
||||||
{
|
{
|
||||||
bValidTeam = false;
|
bValidTeam = false;
|
||||||
}
|
}
|
||||||
|
@ -91,6 +91,11 @@ public:
|
|||||||
virtual void ProcessInput(bool bActive);
|
virtual void ProcessInput(bool bActive);
|
||||||
virtual bool CreateMove( float flInputSampleTime, CUserCmd *cmd );
|
virtual bool CreateMove( float flInputSampleTime, CUserCmd *cmd );
|
||||||
virtual void Update();
|
virtual void Update();
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
virtual void OnColorCorrectionWeightsReset( void );
|
||||||
|
virtual float GetColorCorrectionScale( void ) const;
|
||||||
|
virtual void ClearCurrentColorCorrection() { m_pCurrentColorCorrection = NULL; }
|
||||||
|
#endif
|
||||||
|
|
||||||
// Input
|
// Input
|
||||||
virtual int KeyInput( int down, ButtonCode_t keynum, const char *pszCurrentBinding );
|
virtual int KeyInput( int down, ButtonCode_t keynum, const char *pszCurrentBinding );
|
||||||
@ -165,12 +170,16 @@ private:
|
|||||||
CBaseHudWeaponSelection *m_pWeaponSelection;
|
CBaseHudWeaponSelection *m_pWeaponSelection;
|
||||||
int m_nRootSize[2];
|
int m_nRootSize[2];
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
void UpdatePostProcessingEffects();
|
void UpdatePostProcessingEffects();
|
||||||
|
|
||||||
const C_PostProcessController* m_pCurrentPostProcessController;
|
const C_PostProcessController* m_pCurrentPostProcessController;
|
||||||
PostProcessParameters_t m_CurrentPostProcessParameters;
|
PostProcessParameters_t m_CurrentPostProcessParameters;
|
||||||
PostProcessParameters_t m_LerpStartPostProcessParameters, m_LerpEndPostProcessParameters;
|
PostProcessParameters_t m_LerpStartPostProcessParameters, m_LerpEndPostProcessParameters;
|
||||||
CountdownTimer m_PostProcessLerpTimer;
|
CountdownTimer m_PostProcessLerpTimer;
|
||||||
|
|
||||||
|
CHandle<C_ColorCorrection> m_pCurrentColorCorrection;
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // CLIENTMODE_NORMAL_H
|
#endif // CLIENTMODE_NORMAL_H
|
||||||
|
@ -125,6 +125,11 @@ ConVar r_threaded_client_shadow_manager( "r_threaded_client_shadow_manager", "1"
|
|||||||
ConVar r_threaded_client_shadow_manager( "r_threaded_client_shadow_manager", "0" );
|
ConVar r_threaded_client_shadow_manager( "r_threaded_client_shadow_manager", "0" );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
ConVarRef mat_slopescaledepthbias_shadowmap( "mat_slopescaledepthbias_shadowmap" );
|
||||||
|
ConVarRef mat_depthbias_shadowmap( "mat_depthbias_shadowmap" );
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
#pragma warning( disable: 4701 )
|
#pragma warning( disable: 4701 )
|
||||||
#endif
|
#endif
|
||||||
@ -1424,6 +1429,15 @@ bool CClientShadowMgr::Init()
|
|||||||
|
|
||||||
materials->AddRestoreFunc( ShadowRestoreFunc );
|
materials->AddRestoreFunc( ShadowRestoreFunc );
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
// These need to be referenced here since the cvars don't exist in the initial declaration
|
||||||
|
mat_slopescaledepthbias_shadowmap = ConVarRef( "mat_slopescaledepthbias_shadowmap" );
|
||||||
|
mat_depthbias_shadowmap = ConVarRef( "mat_depthbias_shadowmap" );
|
||||||
|
|
||||||
|
mat_slopescaledepthbias_shadowmap.SetValue( "16" ); // Would do something like 2 here, but it causes citizens to look weird under flashlights
|
||||||
|
mat_depthbias_shadowmap.SetValue( "0.00005" );
|
||||||
|
#endif
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4473,13 +4487,18 @@ void CClientShadowMgr::ComputeShadowDepthTextures( const CViewSetup &viewSetup )
|
|||||||
}
|
}
|
||||||
|
|
||||||
CViewSetup shadowView;
|
CViewSetup shadowView;
|
||||||
|
#ifndef MAPBASE
|
||||||
shadowView.m_flAspectRatio = 1.0f;
|
shadowView.m_flAspectRatio = 1.0f;
|
||||||
|
#endif
|
||||||
shadowView.x = shadowView.y = 0;
|
shadowView.x = shadowView.y = 0;
|
||||||
shadowView.width = shadowDepthTexture->GetActualWidth();
|
shadowView.width = shadowDepthTexture->GetActualWidth();
|
||||||
shadowView.height = shadowDepthTexture->GetActualHeight();
|
shadowView.height = shadowDepthTexture->GetActualHeight();
|
||||||
#ifndef ASW_PROJECTED_TEXTURES
|
#ifndef ASW_PROJECTED_TEXTURES
|
||||||
shadowView.m_bOrtho = false;
|
shadowView.m_bOrtho = false;
|
||||||
shadowView.m_bDoBloomAndToneMapping = false;
|
shadowView.m_bDoBloomAndToneMapping = false;
|
||||||
|
#ifdef MAPBASE
|
||||||
|
shadowView.m_flAspectRatio = (flashlightState.m_fHorizontalFOVDegrees / flashlightState.m_fVerticalFOVDegrees);
|
||||||
|
#endif // MAPBASE
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Copy flashlight parameters
|
// Copy flashlight parameters
|
||||||
@ -4487,6 +4506,10 @@ void CClientShadowMgr::ComputeShadowDepthTextures( const CViewSetup &viewSetup )
|
|||||||
if ( !flashlightState.m_bOrtho )
|
if ( !flashlightState.m_bOrtho )
|
||||||
{
|
{
|
||||||
shadowView.m_bOrtho = false;
|
shadowView.m_bOrtho = false;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
shadowView.m_flAspectRatio = (flashlightState.m_fHorizontalFOVDegrees / flashlightState.m_fVerticalFOVDegrees);
|
||||||
|
#endif // MAPBASE
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -4495,6 +4518,10 @@ void CClientShadowMgr::ComputeShadowDepthTextures( const CViewSetup &viewSetup )
|
|||||||
shadowView.m_OrthoTop = flashlightState.m_fOrthoTop;
|
shadowView.m_OrthoTop = flashlightState.m_fOrthoTop;
|
||||||
shadowView.m_OrthoRight = flashlightState.m_fOrthoRight;
|
shadowView.m_OrthoRight = flashlightState.m_fOrthoRight;
|
||||||
shadowView.m_OrthoBottom = flashlightState.m_fOrthoBottom;
|
shadowView.m_OrthoBottom = flashlightState.m_fOrthoBottom;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
shadowView.m_flAspectRatio = 1.0f;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
shadowView.m_bDoBloomAndToneMapping = false;
|
shadowView.m_bDoBloomAndToneMapping = false;
|
||||||
|
@ -8,6 +8,12 @@
|
|||||||
#include "cbase.h"
|
#include "cbase.h"
|
||||||
#include "tier0/vprof.h"
|
#include "tier0/vprof.h"
|
||||||
#include "colorcorrectionmgr.h"
|
#include "colorcorrectionmgr.h"
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
#include "clientmode_shared.h" //"clientmode.h"
|
||||||
|
|
||||||
|
// NOTE: This has to be the last file included!
|
||||||
|
#include "tier0/memdbgon.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
@ -16,6 +22,13 @@
|
|||||||
static CColorCorrectionMgr s_ColorCorrectionMgr;
|
static CColorCorrectionMgr s_ColorCorrectionMgr;
|
||||||
CColorCorrectionMgr *g_pColorCorrectionMgr = &s_ColorCorrectionMgr;
|
CColorCorrectionMgr *g_pColorCorrectionMgr = &s_ColorCorrectionMgr;
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
static ConVar mat_colcorrection_editor( "mat_colcorrection_editor", "0" );
|
||||||
|
|
||||||
|
static CUtlVector<C_ColorCorrection *> g_ColorCorrectionList;
|
||||||
|
static CUtlVector<C_ColorCorrectionVolume *> g_ColorCorrectionVolumeList;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
// Constructor
|
// Constructor
|
||||||
@ -62,10 +75,89 @@ void CColorCorrectionMgr::RemoveColorCorrection( ClientCCHandle_t h )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
ClientCCHandle_t CColorCorrectionMgr::AddColorCorrectionEntity( C_ColorCorrection *pEntity, const char *pName, const char *pFileName )
|
||||||
|
{
|
||||||
|
ClientCCHandle_t h = AddColorCorrection(pName, pFileName);
|
||||||
|
if ( h != INVALID_CLIENT_CCHANDLE )
|
||||||
|
{
|
||||||
|
Assert(g_ColorCorrectionList.Find(pEntity) == -1);
|
||||||
|
g_ColorCorrectionList.AddToTail(pEntity);
|
||||||
|
}
|
||||||
|
return h;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CColorCorrectionMgr::RemoveColorCorrectionEntity( C_ColorCorrection *pEntity, ClientCCHandle_t h)
|
||||||
|
{
|
||||||
|
RemoveColorCorrection(h);
|
||||||
|
g_ColorCorrectionList.FindAndFastRemove(pEntity);
|
||||||
|
}
|
||||||
|
|
||||||
|
ClientCCHandle_t CColorCorrectionMgr::AddColorCorrectionVolume( C_ColorCorrectionVolume *pVolume, const char *pName, const char *pFileName )
|
||||||
|
{
|
||||||
|
ClientCCHandle_t h = AddColorCorrection(pName, pFileName);
|
||||||
|
if ( h != INVALID_CLIENT_CCHANDLE )
|
||||||
|
{
|
||||||
|
Assert(g_ColorCorrectionVolumeList.Find(pVolume) == -1);
|
||||||
|
g_ColorCorrectionVolumeList.AddToTail(pVolume);
|
||||||
|
}
|
||||||
|
return h;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CColorCorrectionMgr::RemoveColorCorrectionVolume( C_ColorCorrectionVolume *pVolume, ClientCCHandle_t h)
|
||||||
|
{
|
||||||
|
RemoveColorCorrection(h);
|
||||||
|
g_ColorCorrectionVolumeList.FindAndFastRemove(pVolume);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
// Modify color correction weights
|
// Modify color correction weights
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
void CColorCorrectionMgr::SetColorCorrectionWeight( ClientCCHandle_t h, float flWeight, bool bExclusive )
|
||||||
|
{
|
||||||
|
if ( h != INVALID_CLIENT_CCHANDLE )
|
||||||
|
{
|
||||||
|
SetWeightParams_t params = { h, flWeight, bExclusive };
|
||||||
|
m_colorCorrectionWeights.AddToTail( params );
|
||||||
|
if( bExclusive && m_bHaveExclusiveWeight && ( flWeight != 0.0f ) )
|
||||||
|
{
|
||||||
|
DevWarning( "Found multiple active color_correction entities with exclusive setting enabled. This is invalid.\n" );
|
||||||
|
}
|
||||||
|
if ( bExclusive )
|
||||||
|
{
|
||||||
|
m_bHaveExclusiveWeight = true;
|
||||||
|
m_flExclusiveWeight = flWeight;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void CColorCorrectionMgr::CommitColorCorrectionWeights()
|
||||||
|
{
|
||||||
|
CMatRenderContextPtr pRenderContext( g_pMaterialSystem );
|
||||||
|
|
||||||
|
for ( int i = 0; i < m_colorCorrectionWeights.Count(); i++ )
|
||||||
|
{
|
||||||
|
ColorCorrectionHandle_t ccHandle = reinterpret_cast<ColorCorrectionHandle_t>( m_colorCorrectionWeights[i].handle );
|
||||||
|
float flWeight = m_colorCorrectionWeights[i].flWeight;
|
||||||
|
if ( !m_colorCorrectionWeights[i].bExclusive )
|
||||||
|
{
|
||||||
|
flWeight = (1.0f - m_flExclusiveWeight ) * m_colorCorrectionWeights[i].flWeight;
|
||||||
|
}
|
||||||
|
pRenderContext->SetLookupWeight( ccHandle, flWeight );
|
||||||
|
|
||||||
|
// FIXME: NOTE! This doesn't work if the same handle has
|
||||||
|
// its weight set twice with no intervening calls to ResetColorCorrectionWeights
|
||||||
|
// which, at the moment, is true
|
||||||
|
if ( flWeight != 0.0f )
|
||||||
|
{
|
||||||
|
++m_nActiveWeightCount;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
m_colorCorrectionWeights.RemoveAll();
|
||||||
|
}
|
||||||
|
#else
|
||||||
void CColorCorrectionMgr::SetColorCorrectionWeight( ClientCCHandle_t h, float flWeight )
|
void CColorCorrectionMgr::SetColorCorrectionWeight( ClientCCHandle_t h, float flWeight )
|
||||||
{
|
{
|
||||||
if ( h != INVALID_CLIENT_CCHANDLE )
|
if ( h != INVALID_CLIENT_CCHANDLE )
|
||||||
@ -83,6 +175,7 @@ void CColorCorrectionMgr::SetColorCorrectionWeight( ClientCCHandle_t h, float fl
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void CColorCorrectionMgr::ResetColorCorrectionWeights()
|
void CColorCorrectionMgr::ResetColorCorrectionWeights()
|
||||||
{
|
{
|
||||||
@ -93,6 +186,11 @@ void CColorCorrectionMgr::ResetColorCorrectionWeights()
|
|||||||
CMatRenderContextPtr pRenderContext( g_pMaterialSystem );
|
CMatRenderContextPtr pRenderContext( g_pMaterialSystem );
|
||||||
pRenderContext->ResetLookupWeights();
|
pRenderContext->ResetLookupWeights();
|
||||||
m_nActiveWeightCount = 0;
|
m_nActiveWeightCount = 0;
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
m_bHaveExclusiveWeight = false;
|
||||||
|
m_flExclusiveWeight = 0.0f;
|
||||||
|
m_colorCorrectionWeights.RemoveAll();
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void CColorCorrectionMgr::SetResetable( ClientCCHandle_t h, bool bResetable )
|
void CColorCorrectionMgr::SetResetable( ClientCCHandle_t h, bool bResetable )
|
||||||
@ -113,7 +211,34 @@ void CColorCorrectionMgr::SetResetable( ClientCCHandle_t h, bool bResetable )
|
|||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
// Is color correction active?
|
// Is color correction active?
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
bool CColorCorrectionMgr::HasNonZeroColorCorrectionWeights() const
|
||||||
|
{
|
||||||
|
return ( m_nActiveWeightCount != 0 ) || mat_colcorrection_editor.GetBool();
|
||||||
|
}
|
||||||
|
|
||||||
|
void CColorCorrectionMgr::UpdateColorCorrection()
|
||||||
|
{
|
||||||
|
ResetColorCorrectionWeights();
|
||||||
|
C_BasePlayer *pPlayer = C_BasePlayer::GetLocalPlayer();
|
||||||
|
IClientMode *pClientMode = GetClientModeNormal(); //GetClientMode();
|
||||||
|
|
||||||
|
Assert( pClientMode );
|
||||||
|
if ( !pPlayer || !pClientMode )
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
pClientMode->OnColorCorrectionWeightsReset();
|
||||||
|
float ccScale = pClientMode->GetColorCorrectionScale();
|
||||||
|
|
||||||
|
UpdateColorCorrectionEntities( pPlayer, ccScale, g_ColorCorrectionList.Base(), g_ColorCorrectionList.Count() );
|
||||||
|
UpdateColorCorrectionVolumes( pPlayer, ccScale, g_ColorCorrectionVolumeList.Base(), g_ColorCorrectionVolumeList.Count() );
|
||||||
|
CommitColorCorrectionWeights();
|
||||||
|
}
|
||||||
|
#else
|
||||||
bool CColorCorrectionMgr::HasNonZeroColorCorrectionWeights() const
|
bool CColorCorrectionMgr::HasNonZeroColorCorrectionWeights() const
|
||||||
{
|
{
|
||||||
return ( m_nActiveWeightCount != 0 );
|
return ( m_nActiveWeightCount != 0 );
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
@ -14,6 +14,10 @@
|
|||||||
|
|
||||||
#include "igamesystem.h"
|
#include "igamesystem.h"
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
class C_ColorCorrection;
|
||||||
|
class C_ColorCorrectionVolume;
|
||||||
|
#endif
|
||||||
|
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
// Purpose : Singleton manager for color correction on the client
|
// Purpose : Singleton manager for color correction on the client
|
||||||
@ -35,8 +39,21 @@ public:
|
|||||||
ClientCCHandle_t AddColorCorrection( const char *pName, const char *pFileName = NULL );
|
ClientCCHandle_t AddColorCorrection( const char *pName, const char *pFileName = NULL );
|
||||||
void RemoveColorCorrection( ClientCCHandle_t );
|
void RemoveColorCorrection( ClientCCHandle_t );
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
ClientCCHandle_t AddColorCorrectionEntity( C_ColorCorrection *pEntity, const char *pName, const char *pFileName = NULL );
|
||||||
|
void RemoveColorCorrectionEntity( C_ColorCorrection *pEntity, ClientCCHandle_t );
|
||||||
|
|
||||||
|
ClientCCHandle_t AddColorCorrectionVolume( C_ColorCorrectionVolume *pVolume, const char *pName, const char *pFileName = NULL );
|
||||||
|
void RemoveColorCorrectionVolume( C_ColorCorrectionVolume *pVolume, ClientCCHandle_t );
|
||||||
|
#endif
|
||||||
|
|
||||||
// Modify color correction weights
|
// Modify color correction weights
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
void SetColorCorrectionWeight( ClientCCHandle_t h, float flWeight, bool bExclusive = false );
|
||||||
|
void UpdateColorCorrection();
|
||||||
|
#else
|
||||||
void SetColorCorrectionWeight( ClientCCHandle_t h, float flWeight );
|
void SetColorCorrectionWeight( ClientCCHandle_t h, float flWeight );
|
||||||
|
#endif
|
||||||
void ResetColorCorrectionWeights();
|
void ResetColorCorrectionWeights();
|
||||||
void SetResetable( ClientCCHandle_t h, bool bResetable );
|
void SetResetable( ClientCCHandle_t h, bool bResetable );
|
||||||
|
|
||||||
@ -45,8 +62,27 @@ public:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
int m_nActiveWeightCount;
|
int m_nActiveWeightCount;
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
bool m_bHaveExclusiveWeight;
|
||||||
|
float m_flExclusiveWeight;
|
||||||
|
|
||||||
|
struct SetWeightParams_t
|
||||||
|
{
|
||||||
|
ClientCCHandle_t handle;
|
||||||
|
float flWeight;
|
||||||
|
bool bExclusive;
|
||||||
|
};
|
||||||
|
|
||||||
|
CUtlVector< SetWeightParams_t > m_colorCorrectionWeights;
|
||||||
|
|
||||||
|
void CommitColorCorrectionWeights();
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
void UpdateColorCorrectionEntities( C_BasePlayer *pPlayer, float ccScale, C_ColorCorrection **pList, int listCount );
|
||||||
|
void UpdateColorCorrectionVolumes( C_BasePlayer *pPlayer, float ccScale, C_ColorCorrectionVolume **pList, int listCount );
|
||||||
|
#endif
|
||||||
|
|
||||||
//------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------
|
||||||
// Singleton access
|
// Singleton access
|
||||||
|
113
mp/src/game/client/convarproxy.cpp
Normal file
113
mp/src/game/client/convarproxy.cpp
Normal file
@ -0,0 +1,113 @@
|
|||||||
|
//========= Copyright © 1996-2008, Valve Corporation, All rights reserved. ============//
|
||||||
|
//
|
||||||
|
// Material proxy to stuff a convar into a material var.
|
||||||
|
//
|
||||||
|
// $NoKeywords: $
|
||||||
|
//=============================================================================//
|
||||||
|
|
||||||
|
#include "cbase.h"
|
||||||
|
// identifier was truncated to '255' characters in the debug information
|
||||||
|
//#pragma warning(disable: 4786)
|
||||||
|
|
||||||
|
#include "convar.h"
|
||||||
|
#include "materialsystem/imaterialproxy.h"
|
||||||
|
#include "materialsystem/imaterialvar.h"
|
||||||
|
//#include "imaterialproxydict.h"
|
||||||
|
|
||||||
|
// NOTE: This has to be the last file included!
|
||||||
|
#include "tier0/memdbgon.h"
|
||||||
|
|
||||||
|
|
||||||
|
class CConVarMaterialProxy: public IMaterialProxy
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
CConVarMaterialProxy()
|
||||||
|
: m_pResult( NULL ),
|
||||||
|
m_conVarRef( "", true )
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual ~CConVarMaterialProxy()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual bool Init( IMaterial *pMaterial, KeyValues *pKeyValues )
|
||||||
|
{
|
||||||
|
const char *pResult = pKeyValues->GetString( "resultVar" );
|
||||||
|
if ( !pResult )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
bool found;
|
||||||
|
m_pResult = pMaterial->FindVar( pResult, &found );
|
||||||
|
if ( !found )
|
||||||
|
{
|
||||||
|
m_pResult = NULL;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
if ( !Q_stricmp( pResult, "$alpha" ) )
|
||||||
|
{
|
||||||
|
pMaterial->SetMaterialVarFlag( MATERIAL_VAR_ALPHA_MODIFIED_BY_PROXY, true );
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
pResult = pKeyValues->GetString( "convar" );
|
||||||
|
if( !pResult )
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_conVarRef.Init( pResult, false );
|
||||||
|
if ( !m_conVarRef.IsValid() )
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual void OnBind( void* )
|
||||||
|
{
|
||||||
|
switch( m_pResult->GetType() )
|
||||||
|
{
|
||||||
|
case MATERIAL_VAR_TYPE_VECTOR:
|
||||||
|
{
|
||||||
|
float f = m_conVarRef.GetFloat();
|
||||||
|
Vector4D vec( f, f, f, f );
|
||||||
|
m_pResult->SetVecValue( vec.Base(), m_pResult->VectorSize() );
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
case MATERIAL_VAR_TYPE_STRING:
|
||||||
|
m_pResult->SetStringValue( m_conVarRef.GetString() );
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
case MATERIAL_VAR_TYPE_INT:
|
||||||
|
m_pResult->SetIntValue( m_conVarRef.GetInt() );
|
||||||
|
break;
|
||||||
|
|
||||||
|
case MATERIAL_VAR_TYPE_FLOAT:
|
||||||
|
default:
|
||||||
|
m_pResult->SetFloatValue( m_conVarRef.GetFloat() );
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual IMaterial *GetMaterial()
|
||||||
|
{
|
||||||
|
return m_pResult->GetOwningMaterial();
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual void Release()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
IMaterialVar *m_pResult;
|
||||||
|
ConVarRef m_conVarRef;
|
||||||
|
};
|
||||||
|
|
||||||
|
EXPOSE_INTERFACE( CConVarMaterialProxy, IMaterialProxy, "ConVar" IMATERIAL_PROXY_INTERFACE_VERSION );
|
@ -5,6 +5,10 @@
|
|||||||
//=============================================================================
|
//=============================================================================
|
||||||
|
|
||||||
#include "cbase.h"
|
#include "cbase.h"
|
||||||
|
#ifdef MAPBASE
|
||||||
|
#include "proxyentity.h"
|
||||||
|
#include "materialsystem/imaterialvar.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
class C_PropScalable : public C_BaseAnimating
|
class C_PropScalable : public C_BaseAnimating
|
||||||
{
|
{
|
||||||
@ -194,3 +198,56 @@ void C_PropScalable::GetRenderBounds( Vector &theMins, Vector &theMaxs )
|
|||||||
Assert( theMins.IsValid() && theMaxs.IsValid() );
|
Assert( theMins.IsValid() && theMaxs.IsValid() );
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
ConVar r_coreball_update_sphere_center( "r_coreball_update_sphere_center", "1", FCVAR_NONE, "Allows prop_coreball to update its center to the entity's origin" );
|
||||||
|
|
||||||
|
class CCoreBallUpdateMaterialProxy : public CEntityMaterialProxy
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
CCoreBallUpdateMaterialProxy()
|
||||||
|
{
|
||||||
|
m_pMaterial = NULL;
|
||||||
|
m_pSphereCenter = NULL;
|
||||||
|
}
|
||||||
|
virtual ~CCoreBallUpdateMaterialProxy()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
virtual bool Init( IMaterial *pMaterial, KeyValues *pKeyValues )
|
||||||
|
{
|
||||||
|
m_pMaterial = pMaterial;
|
||||||
|
bool found;
|
||||||
|
m_pSphereCenter = m_pMaterial->FindVar( "$spherecenter", &found );
|
||||||
|
if( !found )
|
||||||
|
{
|
||||||
|
m_pSphereCenter = NULL;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
virtual void OnBind( C_BaseEntity *pC_BaseEntity )
|
||||||
|
{
|
||||||
|
if (r_coreball_update_sphere_center.GetBool())
|
||||||
|
{
|
||||||
|
const Vector &origin = pC_BaseEntity->GetAbsOrigin();
|
||||||
|
m_pSphereCenter->SetVecValue( origin.x, origin.y, origin.z );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Just continuously bind the old hacked value (TODO: Optimize so it's not just assigning the same value constantly?)
|
||||||
|
m_pSphereCenter->SetVecValue( 2688.0, 12139.0, 5170.0 );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual IMaterial *GetMaterial()
|
||||||
|
{
|
||||||
|
return m_pMaterial;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
IMaterial *m_pMaterial;
|
||||||
|
IMaterialVar *m_pSphereCenter;
|
||||||
|
};
|
||||||
|
|
||||||
|
EXPOSE_INTERFACE( CCoreBallUpdateMaterialProxy, IMaterialProxy, "CoreBallUpdate" IMATERIAL_PROXY_INTERFACE_VERSION );
|
||||||
|
#endif
|
||||||
|
@ -52,8 +52,8 @@ static ConVar r_flashlightladderdist( "r_flashlightladderdist", "40.0", FCVAR_CH
|
|||||||
static ConVar mat_slopescaledepthbias_shadowmap( "mat_slopescaledepthbias_shadowmap", "16", FCVAR_CHEAT );
|
static ConVar mat_slopescaledepthbias_shadowmap( "mat_slopescaledepthbias_shadowmap", "16", FCVAR_CHEAT );
|
||||||
static ConVar mat_depthbias_shadowmap( "mat_depthbias_shadowmap", "0.0005", FCVAR_CHEAT );
|
static ConVar mat_depthbias_shadowmap( "mat_depthbias_shadowmap", "0.0005", FCVAR_CHEAT );
|
||||||
#else
|
#else
|
||||||
static ConVar mat_slopescaledepthbias_shadowmap( "mat_slopescaledepthbias_shadowmap", "4", FCVAR_CHEAT );
|
extern ConVarRef mat_slopescaledepthbias_shadowmap;
|
||||||
static ConVar mat_depthbias_shadowmap( "mat_depthbias_shadowmap", "0.00001", FCVAR_CHEAT );
|
extern ConVarRef mat_depthbias_shadowmap;
|
||||||
#endif
|
#endif
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
static ConVar r_flashlighttextureoverride( "r_flashlighttextureoverride", "", FCVAR_CHEAT );
|
static ConVar r_flashlighttextureoverride( "r_flashlighttextureoverride", "", FCVAR_CHEAT );
|
||||||
|
@ -25,6 +25,13 @@ extern ConVar r_drawmodeldecals;
|
|||||||
|
|
||||||
ImpactSoundRouteFn g_pImpactSoundRouteFn = NULL;
|
ImpactSoundRouteFn g_pImpactSoundRouteFn = NULL;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
ConVar g_ragdoll_steal_impacts_client( "g_ragdoll_steal_impacts_client", "1", FCVAR_NONE, "Allows clientside death ragdolls to \"steal\" impacts from their source entities. This fixes issues with NPCs dying before decals are applied." );
|
||||||
|
ConVar g_ragdoll_steal_impacts_server( "g_ragdoll_steal_impacts_server", "1", FCVAR_NONE, "Allows serverside death ragdolls to \"steal\" impacts from their source entities. This fixes issues with NPCs dying before decals are applied." );
|
||||||
|
|
||||||
|
ConVar g_ragdoll_client_impact_decals( "g_ragdoll_client_impact_decals", "1", FCVAR_NONE, "Applies decals to clientside ragdolls when they are hit." );
|
||||||
|
#endif
|
||||||
|
|
||||||
//==========================================================================================================================
|
//==========================================================================================================================
|
||||||
// RAGDOLL ENUMERATOR
|
// RAGDOLL ENUMERATOR
|
||||||
//==========================================================================================================================
|
//==========================================================================================================================
|
||||||
@ -32,7 +39,11 @@ CRagdollEnumerator::CRagdollEnumerator( Ray_t& shot, int iDamageType )
|
|||||||
{
|
{
|
||||||
m_rayShot = shot;
|
m_rayShot = shot;
|
||||||
m_iDamageType = iDamageType;
|
m_iDamageType = iDamageType;
|
||||||
|
#ifdef MAPBASE
|
||||||
|
m_pHitEnt = NULL;
|
||||||
|
#else
|
||||||
m_bHit = false;
|
m_bHit = false;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
IterationRetval_t CRagdollEnumerator::EnumElement( IHandleEntity *pHandleEntity )
|
IterationRetval_t CRagdollEnumerator::EnumElement( IHandleEntity *pHandleEntity )
|
||||||
@ -57,7 +68,11 @@ IterationRetval_t CRagdollEnumerator::EnumElement( IHandleEntity *pHandleEntity
|
|||||||
if ( tr.fraction < 1.0 )
|
if ( tr.fraction < 1.0 )
|
||||||
{
|
{
|
||||||
pModel->ImpactTrace( &tr, m_iDamageType, NULL );
|
pModel->ImpactTrace( &tr, m_iDamageType, NULL );
|
||||||
|
#ifdef MAPBASE
|
||||||
|
m_pHitEnt = pModel;
|
||||||
|
#else
|
||||||
m_bHit = true;
|
m_bHit = true;
|
||||||
|
#endif
|
||||||
|
|
||||||
//FIXME: Yes? No?
|
//FIXME: Yes? No?
|
||||||
return ITERATION_STOP;
|
return ITERATION_STOP;
|
||||||
@ -84,6 +99,22 @@ bool FX_AffectRagdolls( Vector vecOrigin, Vector vecStart, int iDamageType )
|
|||||||
return ragdollEnum.Hit();
|
return ragdollEnum.Hit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
C_BaseAnimating *FX_AffectRagdolls_GetHit( Vector vecOrigin, Vector vecStart, int iDamageType )
|
||||||
|
{
|
||||||
|
// don't do this when lots of ragdolls are simulating
|
||||||
|
if ( s_RagdollLRU.CountRagdolls(true) > 1 )
|
||||||
|
return NULL;
|
||||||
|
Ray_t shotRay;
|
||||||
|
shotRay.Init( vecStart, vecOrigin );
|
||||||
|
|
||||||
|
CRagdollEnumerator ragdollEnum( shotRay, iDamageType );
|
||||||
|
partition->EnumerateElementsAlongRay( PARTITION_CLIENT_RESPONSIVE_EDICTS, shotRay, false, &ragdollEnum );
|
||||||
|
|
||||||
|
return ragdollEnum.GetHit();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose:
|
// Purpose:
|
||||||
// Input : &data -
|
// Input : &data -
|
||||||
@ -104,6 +135,22 @@ bool Impact( Vector &vecOrigin, Vector &vecStart, int iMaterial, int iDamageType
|
|||||||
|
|
||||||
Assert ( pEntity );
|
Assert ( pEntity );
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
// If the entity already has a ragdoll that was created on the current tick, use that ragdoll instead.
|
||||||
|
// This allows the killing damage's decals to show up on the ragdoll.
|
||||||
|
if (C_BaseAnimating *pAnimating = pEntity->GetBaseAnimating())
|
||||||
|
{
|
||||||
|
if (pAnimating->m_pClientsideRagdoll && WasRagdollCreatedOnCurrentTick( pAnimating->m_pClientsideRagdoll ) && g_ragdoll_steal_impacts_client.GetBool())
|
||||||
|
{
|
||||||
|
pEntity = pAnimating->m_pClientsideRagdoll;
|
||||||
|
}
|
||||||
|
else if (pAnimating->m_pServerRagdoll && WasRagdollCreatedOnCurrentTick( pAnimating->m_pServerRagdoll ) && g_ragdoll_steal_impacts_server.GetBool())
|
||||||
|
{
|
||||||
|
pEntity = pAnimating->m_pServerRagdoll;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
// Clear out the trace
|
// Clear out the trace
|
||||||
memset( &tr, 0, sizeof(trace_t));
|
memset( &tr, 0, sizeof(trace_t));
|
||||||
tr.fraction = 1.0f;
|
tr.fraction = 1.0f;
|
||||||
@ -115,13 +162,52 @@ bool Impact( Vector &vecOrigin, Vector &vecStart, int iMaterial, int iDamageType
|
|||||||
VectorMA( vecStart, flLength + 8.0f, shotDir, traceExt );
|
VectorMA( vecStart, flLength + 8.0f, shotDir, traceExt );
|
||||||
|
|
||||||
// Attempt to hit ragdolls
|
// Attempt to hit ragdolls
|
||||||
|
|
||||||
bool bHitRagdoll = false;
|
bool bHitRagdoll = false;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if ( !pEntity->IsClientCreated() )
|
||||||
|
{
|
||||||
|
C_BaseAnimating *pRagdoll = FX_AffectRagdolls_GetHit( vecOrigin, vecStart, iDamageType );
|
||||||
|
if (pRagdoll)
|
||||||
|
{
|
||||||
|
bHitRagdoll = true;
|
||||||
|
|
||||||
|
if (g_ragdoll_client_impact_decals.GetBool() && pRagdoll->IsRagdoll())
|
||||||
|
{
|
||||||
|
pEntity = pRagdoll;
|
||||||
|
|
||||||
|
// HACKHACK: Get the ragdoll's nearest bone for its material
|
||||||
|
int iNearestMaterial = 0;
|
||||||
|
float flNearestDistSqr = FLT_MAX;
|
||||||
|
|
||||||
|
IPhysicsObject *pList[VPHYSICS_MAX_OBJECT_LIST_COUNT];
|
||||||
|
int count = pEntity->VPhysicsGetObjectList( pList, ARRAYSIZE(pList) );
|
||||||
|
for ( int i = 0; i < count; i++ )
|
||||||
|
{
|
||||||
|
Vector vecPosition;
|
||||||
|
QAngle angAngles;
|
||||||
|
pList[i]->GetPosition( &vecPosition, &angAngles );
|
||||||
|
float flDistSqr = (vecStart - vecPosition).LengthSqr();
|
||||||
|
if (flDistSqr < flNearestDistSqr)
|
||||||
|
{
|
||||||
|
iNearestMaterial = pList[i]->GetMaterialIndex();
|
||||||
|
flNearestDistSqr = flDistSqr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get the material from the surfaceprop
|
||||||
|
surfacedata_t *psurfaceData = physprops->GetSurfaceData( iNearestMaterial );
|
||||||
|
iMaterial = psurfaceData->game.material;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#else
|
||||||
if ( !pEntity->IsClientCreated() )
|
if ( !pEntity->IsClientCreated() )
|
||||||
{
|
{
|
||||||
bHitRagdoll = FX_AffectRagdolls( vecOrigin, vecStart, iDamageType );
|
bHitRagdoll = FX_AffectRagdolls( vecOrigin, vecStart, iDamageType );
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
if ( (nFlags & IMPACT_NODECAL) == 0 )
|
if ( (nFlags & IMPACT_NODECAL) == 0 )
|
||||||
{
|
{
|
||||||
|
@ -58,12 +58,21 @@ public:
|
|||||||
// Actual work code
|
// Actual work code
|
||||||
virtual IterationRetval_t EnumElement( IHandleEntity *pHandleEntity );
|
virtual IterationRetval_t EnumElement( IHandleEntity *pHandleEntity );
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
bool Hit( void ) const { return m_pHitEnt != NULL; }
|
||||||
|
C_BaseAnimating *GetHit( void ) { return m_pHitEnt; }
|
||||||
|
#else
|
||||||
bool Hit( void ) const { return m_bHit; }
|
bool Hit( void ) const { return m_bHit; }
|
||||||
|
#endif
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Ray_t m_rayShot;
|
Ray_t m_rayShot;
|
||||||
int m_iDamageType;
|
int m_iDamageType;
|
||||||
|
#ifdef MAPBASE
|
||||||
|
C_BaseAnimating *m_pHitEnt;
|
||||||
|
#else
|
||||||
bool m_bHit;
|
bool m_bHit;
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // FX_IMPACT_H
|
#endif // FX_IMPACT_H
|
||||||
|
@ -156,6 +156,32 @@ bool CBaseViewport::LoadHudAnimations( void )
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Reloads HUD animations after loading a map-specific HUD animations file.
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void CBaseViewport::ReloadHudAnimations( void )
|
||||||
|
{
|
||||||
|
// Force a reload
|
||||||
|
if ( LoadHudAnimations() == false )
|
||||||
|
{
|
||||||
|
// Fall back to just the main
|
||||||
|
if ( m_pAnimController->SetScriptFile( GetVPanel(), "scripts/HudAnimations.txt", true ) == false )
|
||||||
|
{
|
||||||
|
Assert(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Loads a map-specific HUD animations file.
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
bool CBaseViewport::LoadCustomHudAnimations( const char *pszFile )
|
||||||
|
{
|
||||||
|
return m_pAnimController->SetScriptFile( GetVPanel(), pszFile, true );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
//================================================================
|
//================================================================
|
||||||
CBaseViewport::CBaseViewport() : vgui::EditablePanel( NULL, "CBaseViewport")
|
CBaseViewport::CBaseViewport() : vgui::EditablePanel( NULL, "CBaseViewport")
|
||||||
{
|
{
|
||||||
|
@ -73,6 +73,10 @@ public:
|
|||||||
public: // IGameEventListener:
|
public: // IGameEventListener:
|
||||||
virtual void FireGameEvent( IGameEvent * event);
|
virtual void FireGameEvent( IGameEvent * event);
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
bool LoadCustomHudAnimations( const char *pszFile );
|
||||||
|
void ReloadHudAnimations( void );
|
||||||
|
#endif
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
|
@ -150,6 +150,10 @@ private:
|
|||||||
static const int ENTRY_IN_USE = -2;
|
static const int ENTRY_IN_USE = -2;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
// For unregistration boundary check
|
||||||
|
public:
|
||||||
|
#endif
|
||||||
CUtlVector< GlowObjectDefinition_t > m_GlowObjectDefinitions;
|
CUtlVector< GlowObjectDefinition_t > m_GlowObjectDefinitions;
|
||||||
int m_nFirstFreeSlot;
|
int m_nFirstFreeSlot;
|
||||||
};
|
};
|
||||||
|
@ -31,6 +31,9 @@ ConVar cl_npc_speedmod_outtime( "cl_npc_speedmod_outtime", "1.5", FCVAR_CLIENTDL
|
|||||||
IMPLEMENT_CLIENTCLASS_DT(C_BaseHLPlayer, DT_HL2_Player, CHL2_Player)
|
IMPLEMENT_CLIENTCLASS_DT(C_BaseHLPlayer, DT_HL2_Player, CHL2_Player)
|
||||||
RecvPropDataTable( RECVINFO_DT(m_HL2Local),0, &REFERENCE_RECV_TABLE(DT_HL2Local) ),
|
RecvPropDataTable( RECVINFO_DT(m_HL2Local),0, &REFERENCE_RECV_TABLE(DT_HL2Local) ),
|
||||||
RecvPropBool( RECVINFO( m_fIsSprinting ) ),
|
RecvPropBool( RECVINFO( m_fIsSprinting ) ),
|
||||||
|
#ifdef SP_ANIM_STATE
|
||||||
|
RecvPropFloat( RECVINFO( m_flAnimRenderYaw ) ),
|
||||||
|
#endif
|
||||||
END_RECV_TABLE()
|
END_RECV_TABLE()
|
||||||
|
|
||||||
BEGIN_PREDICTION_DATA( C_BaseHLPlayer )
|
BEGIN_PREDICTION_DATA( C_BaseHLPlayer )
|
||||||
@ -90,6 +93,13 @@ void C_BaseHLPlayer::OnDataChanged( DataUpdateType_t updateType )
|
|||||||
SetNextClientThink( CLIENT_THINK_ALWAYS );
|
SetNextClientThink( CLIENT_THINK_ALWAYS );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef SP_ANIM_STATE
|
||||||
|
if (m_flAnimRenderYaw != FLT_MAX)
|
||||||
|
{
|
||||||
|
m_angAnimRender = QAngle( 0, m_flAnimRenderYaw, 0 );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
BaseClass::OnDataChanged( updateType );
|
BaseClass::OnDataChanged( updateType );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -657,3 +667,21 @@ void C_BaseHLPlayer::BuildTransformations( CStudioHdr *hdr, Vector *pos, Quatern
|
|||||||
BuildFirstPersonMeathookTransformations( hdr, pos, q, cameraTransform, boneMask, boneComputed, "ValveBiped.Bip01_Head1" );
|
BuildFirstPersonMeathookTransformations( hdr, pos, q, cameraTransform, boneMask, boneComputed, "ValveBiped.Bip01_Head1" );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef SP_ANIM_STATE
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
const QAngle& C_BaseHLPlayer::GetRenderAngles( void )
|
||||||
|
{
|
||||||
|
if ( m_flAnimRenderYaw != FLT_MAX )
|
||||||
|
{
|
||||||
|
return m_angAnimRender;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return BaseClass::GetRenderAngles();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -15,6 +15,10 @@
|
|||||||
#include "c_baseplayer.h"
|
#include "c_baseplayer.h"
|
||||||
#include "c_hl2_playerlocaldata.h"
|
#include "c_hl2_playerlocaldata.h"
|
||||||
|
|
||||||
|
#if !defined( HL2MP ) && defined ( MAPBASE )
|
||||||
|
#include "mapbase/singleplayer_animstate.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
class C_BaseHLPlayer : public C_BasePlayer
|
class C_BaseHLPlayer : public C_BasePlayer
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@ -58,6 +62,10 @@ public:
|
|||||||
|
|
||||||
bool IsWeaponLowered( void ) { return m_HL2Local.m_bWeaponLowered; }
|
bool IsWeaponLowered( void ) { return m_HL2Local.m_bWeaponLowered; }
|
||||||
|
|
||||||
|
#ifdef SP_ANIM_STATE
|
||||||
|
virtual const QAngle& GetRenderAngles( void );
|
||||||
|
#endif
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
C_HL2PlayerLocalData m_HL2Local;
|
C_HL2PlayerLocalData m_HL2Local;
|
||||||
@ -78,7 +86,13 @@ private:
|
|||||||
bool m_bPlayUseDenySound; // Signaled by PlayerUse, but can be unset by HL2 ladder code...
|
bool m_bPlayUseDenySound; // Signaled by PlayerUse, but can be unset by HL2 ladder code...
|
||||||
float m_flSpeedMod;
|
float m_flSpeedMod;
|
||||||
float m_flExitSpeedMod;
|
float m_flExitSpeedMod;
|
||||||
|
|
||||||
|
#ifdef SP_ANIM_STATE
|
||||||
|
// At the moment, we network the render angles since almost none of the player anim stuff is done on the client in SP.
|
||||||
|
// If any of this is ever adapted for MP, this method should be replaced with replicating/moving the anim state to the client.
|
||||||
|
float m_flAnimRenderYaw;
|
||||||
|
QAngle m_angAnimRender;
|
||||||
|
#endif
|
||||||
|
|
||||||
friend class CHL2GameMovement;
|
friend class CHL2GameMovement;
|
||||||
};
|
};
|
||||||
|
@ -32,6 +32,16 @@ struct creditname_t
|
|||||||
float flTimeAdd;
|
float flTimeAdd;
|
||||||
float flTimeStart;
|
float flTimeStart;
|
||||||
int iSlot;
|
int iSlot;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
// New credits stuff
|
||||||
|
|
||||||
|
Color cColorOverride;
|
||||||
|
|
||||||
|
// Images
|
||||||
|
int iImageID = -1;
|
||||||
|
float flImageScale = 1.0f;
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
#define CREDITS_FILE "scripts/credits.txt"
|
#define CREDITS_FILE "scripts/credits.txt"
|
||||||
@ -47,6 +57,9 @@ enum
|
|||||||
#define CREDITS_LOGO 1
|
#define CREDITS_LOGO 1
|
||||||
#define CREDITS_INTRO 2
|
#define CREDITS_INTRO 2
|
||||||
#define CREDITS_OUTRO 3
|
#define CREDITS_OUTRO 3
|
||||||
|
#ifdef MAPBASE
|
||||||
|
#define CREDITS_PRECACHE 4
|
||||||
|
#endif
|
||||||
|
|
||||||
bool g_bRollingCredits = false;
|
bool g_bRollingCredits = false;
|
||||||
|
|
||||||
@ -93,15 +106,27 @@ private:
|
|||||||
void DrawOutroCreditsName( void );
|
void DrawOutroCreditsName( void );
|
||||||
void DrawIntroCreditsName( void );
|
void DrawIntroCreditsName( void );
|
||||||
void DrawLogo( void );
|
void DrawLogo( void );
|
||||||
|
#ifdef MAPBASE
|
||||||
|
void DrawOutroCreditFont( const char *pCreditName, float flYPos, vgui::HFont hTFont, const Color &cColor, int iScreenWidth, int iDivisor = 2 );
|
||||||
|
void DrawOutroCreditTexture( int iImageID, float flYPos, float flImageScale, const Color &cColor, int iScreenWidth, int iDivisor = 2 );
|
||||||
|
#endif
|
||||||
|
|
||||||
void PrepareLogo( float flTime );
|
void PrepareLogo( float flTime );
|
||||||
void PrepareOutroCredits( void );
|
void PrepareOutroCredits( void );
|
||||||
void PrepareIntroCredits( void );
|
void PrepareIntroCredits( void );
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
void PrecacheCredits();
|
||||||
|
#endif
|
||||||
|
|
||||||
float FadeBlend( float fadein, float fadeout, float hold, float localTime );
|
float FadeBlend( float fadein, float fadeout, float hold, float localTime );
|
||||||
|
|
||||||
void PrepareLine( vgui::HFont hFont, char const *pchLine );
|
void PrepareLine( vgui::HFont hFont, char const *pchLine );
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
int GetOrAllocateImageID( const char *szFileName );
|
||||||
|
#endif
|
||||||
|
|
||||||
CPanelAnimationVar( vgui::HFont, m_hTextFont, "TextFont", "Default" );
|
CPanelAnimationVar( vgui::HFont, m_hTextFont, "TextFont", "Default" );
|
||||||
CPanelAnimationVar( Color, m_TextColor, "TextColor", "FgColor" );
|
CPanelAnimationVar( Color, m_TextColor, "TextColor", "FgColor" );
|
||||||
|
|
||||||
@ -110,7 +135,10 @@ private:
|
|||||||
float m_flScrollTime;
|
float m_flScrollTime;
|
||||||
float m_flSeparation;
|
float m_flSeparation;
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
int m_iEndLines;
|
int m_iEndLines;
|
||||||
|
float m_flEndLinesFadeHoldTime;
|
||||||
|
bool m_bAllowColumns;
|
||||||
|
CUtlDict<int, int> m_ImageDict;
|
||||||
#endif
|
#endif
|
||||||
float m_flFadeTime;
|
float m_flFadeTime;
|
||||||
bool m_bLastOneInPlace;
|
bool m_bLastOneInPlace;
|
||||||
@ -141,6 +169,9 @@ private:
|
|||||||
char m_szCreditsFile[MAX_PATH];
|
char m_szCreditsFile[MAX_PATH];
|
||||||
|
|
||||||
char m_szLogoFont[64];
|
char m_szLogoFont[64];
|
||||||
|
char m_szLogo2Font[64];
|
||||||
|
Color m_cLogoColor;
|
||||||
|
Color m_cLogo2Color;
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -202,6 +233,20 @@ void CHudCredits::Clear( void )
|
|||||||
m_bLastOneInPlace = false;
|
m_bLastOneInPlace = false;
|
||||||
m_Alpha = m_TextColor[3];
|
m_Alpha = m_TextColor[3];
|
||||||
m_iLogoState = LOGO_FADEOFF;
|
m_iLogoState = LOGO_FADEOFF;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if ( surface() )
|
||||||
|
{
|
||||||
|
for (int i = m_ImageDict.Count()-1; i >= 0; i--)
|
||||||
|
{
|
||||||
|
if (m_ImageDict[i] != -1)
|
||||||
|
{
|
||||||
|
surface()->DestroyTextureID( m_ImageDict[i] );
|
||||||
|
m_ImageDict.RemoveAt( i );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -229,7 +274,11 @@ void CHudCredits::ReadNames( KeyValues *pKeyValue )
|
|||||||
{
|
{
|
||||||
creditname_t Credits;
|
creditname_t Credits;
|
||||||
V_strcpy_safe( Credits.szCreditName, pKVNames->GetName() );
|
V_strcpy_safe( Credits.szCreditName, pKVNames->GetName() );
|
||||||
|
#ifdef MAPBASE
|
||||||
|
V_strcpy_safe( Credits.szFontName, pKVNames->GetString( (const char *)NULL, "Default" ) );
|
||||||
|
#else
|
||||||
V_strcpy_safe( Credits.szFontName, pKeyValue->GetString( Credits.szCreditName, "Default" ) );
|
V_strcpy_safe( Credits.szFontName, pKeyValue->GetString( Credits.szCreditName, "Default" ) );
|
||||||
|
#endif
|
||||||
|
|
||||||
m_CreditsList.AddToTail( Credits );
|
m_CreditsList.AddToTail( Credits );
|
||||||
pKVNames = pKVNames->GetNextKey();
|
pKVNames = pKVNames->GetNextKey();
|
||||||
@ -248,6 +297,8 @@ void CHudCredits::ReadParams( KeyValues *pKeyValue )
|
|||||||
m_flSeparation = pKeyValue->GetFloat( "separation", 5 );
|
m_flSeparation = pKeyValue->GetFloat( "separation", 5 );
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
m_iEndLines = pKeyValue->GetInt( "endlines", 1 );
|
m_iEndLines = pKeyValue->GetInt( "endlines", 1 );
|
||||||
|
m_flEndLinesFadeHoldTime = pKeyValue->GetFloat( "endlines_fadeholdtime", ( IsConsole() ? 2.0f : 10.0f ) ); // "360 certification requires that we not hold a static image too long."
|
||||||
|
m_bAllowColumns = pKeyValue->GetBool( "allow_columns", false );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
m_flFadeInTime = pKeyValue->GetFloat( "fadeintime", 1 );
|
m_flFadeInTime = pKeyValue->GetFloat( "fadeintime", 1 );
|
||||||
@ -268,6 +319,10 @@ void CHudCredits::ReadParams( KeyValues *pKeyValue )
|
|||||||
|
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
Q_strncpy( m_szLogoFont, pKeyValue->GetString( "logofont", "" ), sizeof( m_szLogoFont ) );
|
Q_strncpy( m_szLogoFont, pKeyValue->GetString( "logofont", "" ), sizeof( m_szLogoFont ) );
|
||||||
|
Q_strncpy( m_szLogo2Font, pKeyValue->GetString( "logo2font", "" ), sizeof( m_szLogo2Font ) );
|
||||||
|
|
||||||
|
m_cLogoColor = pKeyValue->GetColor( "logocolor" );
|
||||||
|
m_cLogo2Color = pKeyValue->GetColor( "logo2color" );
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -300,10 +355,46 @@ void CHudCredits::DrawOutroCreditsName( void )
|
|||||||
if ( pCredit == NULL )
|
if ( pCredit == NULL )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
vgui::HScheme scheme = GetScheme();
|
||||||
|
#else
|
||||||
vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
|
vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
|
||||||
vgui::HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont( pCredit->szFontName, true );
|
#endif
|
||||||
|
vgui::HFont m_hTFont = INVALID_FONT;
|
||||||
|
|
||||||
int iFontTall = surface()->GetFontTall ( m_hTFont );
|
int iFontTall = 1;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if (pCredit->iImageID != -1)
|
||||||
|
{
|
||||||
|
// Get the size of the tallest image if there's multiple
|
||||||
|
int iFontWide;
|
||||||
|
if (m_bAllowColumns && V_strstr( pCredit->szCreditName, "\t" ))
|
||||||
|
{
|
||||||
|
CUtlStringList outStrings;
|
||||||
|
V_SplitString( pCredit->szCreditName, "\t", outStrings );
|
||||||
|
FOR_EACH_VEC( outStrings, i )
|
||||||
|
{
|
||||||
|
int iTempTall;
|
||||||
|
surface()->DrawGetTextureSize( GetOrAllocateImageID( outStrings[i] ), iFontWide, iTempTall );
|
||||||
|
if (iTempTall > iFontTall)
|
||||||
|
iFontTall = iTempTall;
|
||||||
|
}
|
||||||
|
outStrings.PurgeAndDeleteElements();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
surface()->DrawGetTextureSize( GetOrAllocateImageID( pCredit->szCreditName ), iFontWide, iFontTall );
|
||||||
|
}
|
||||||
|
|
||||||
|
iFontTall = ((float)iFontTall * pCredit->flImageScale);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
m_hTFont = vgui::scheme()->GetIScheme( scheme )->GetFont( pCredit->szFontName, true );
|
||||||
|
iFontTall = surface()->GetFontTall( m_hTFont );
|
||||||
|
}
|
||||||
|
|
||||||
if ( pCredit->flYPos < -iFontTall || pCredit->flYPos > iTall )
|
if ( pCredit->flYPos < -iFontTall || pCredit->flYPos > iTall )
|
||||||
{
|
{
|
||||||
@ -317,6 +408,9 @@ void CHudCredits::DrawOutroCreditsName( void )
|
|||||||
Color cColor = m_TextColor;
|
Color cColor = m_TextColor;
|
||||||
|
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
|
if (pCredit->cColorOverride.a() > 0)
|
||||||
|
cColor = pCredit->cColorOverride;
|
||||||
|
|
||||||
// Some lines should stick around and fade out
|
// Some lines should stick around and fade out
|
||||||
if ( i >= m_CreditsList.Count()-m_iEndLines )
|
if ( i >= m_CreditsList.Count()-m_iEndLines )
|
||||||
#else
|
#else
|
||||||
@ -333,8 +427,12 @@ void CHudCredits::DrawOutroCreditsName( void )
|
|||||||
{
|
{
|
||||||
m_bLastOneInPlace = true;
|
m_bLastOneInPlace = true;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
m_flFadeTime = gpGlobals->curtime + m_flEndLinesFadeHoldTime;
|
||||||
|
#else
|
||||||
// 360 certification requires that we not hold a static image too long.
|
// 360 certification requires that we not hold a static image too long.
|
||||||
m_flFadeTime = gpGlobals->curtime + ( IsConsole() ? 2.0f : 10.0f );
|
m_flFadeTime = gpGlobals->curtime + ( IsConsole() ? 2.0f : 10.0f );
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -364,6 +462,50 @@ void CHudCredits::DrawOutroCreditsName( void )
|
|||||||
if ( pCredit->bActive == false )
|
if ( pCredit->bActive == false )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
// Credits separated by tabs should appear divided
|
||||||
|
if (m_bAllowColumns && V_strstr( pCredit->szCreditName, "\t" ))
|
||||||
|
{
|
||||||
|
CUtlStringList outStrings;
|
||||||
|
V_SplitString( pCredit->szCreditName, "\t", outStrings );
|
||||||
|
int iDivisor = 1 + outStrings.Count();
|
||||||
|
if (pCredit->iImageID != -1)
|
||||||
|
{
|
||||||
|
FOR_EACH_VEC( outStrings, i )
|
||||||
|
{
|
||||||
|
int iImageID = GetOrAllocateImageID( outStrings[i] );
|
||||||
|
|
||||||
|
// Center the image if needed
|
||||||
|
int iImageWide, iImageTall = 1;
|
||||||
|
surface()->DrawGetTextureSize( iImageID, iImageWide, iImageTall );
|
||||||
|
if (iImageTall < iFontTall)
|
||||||
|
{
|
||||||
|
DrawOutroCreditTexture( iImageID, pCredit->flYPos + ((iFontTall * 0.5f) - (iImageTall * 0.5f)), pCredit->flImageScale, cColor, iWidth*(i + 1), iDivisor );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
DrawOutroCreditTexture( iImageID, pCredit->flYPos, pCredit->flImageScale, cColor, iWidth*(i + 1), iDivisor );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
FOR_EACH_VEC( outStrings, i )
|
||||||
|
{
|
||||||
|
DrawOutroCreditFont( outStrings[i], pCredit->flYPos, m_hTFont, cColor, iWidth*(i + 1), iDivisor );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
outStrings.PurgeAndDeleteElements();
|
||||||
|
}
|
||||||
|
else if (pCredit->iImageID != -1)
|
||||||
|
{
|
||||||
|
DrawOutroCreditTexture( pCredit->iImageID, pCredit->flYPos, pCredit->flImageScale, cColor, iWidth, 2 );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
DrawOutroCreditFont( pCredit->szCreditName, pCredit->flYPos, m_hTFont, cColor, iWidth, 2 );
|
||||||
|
}
|
||||||
|
#else
|
||||||
surface()->DrawSetTextFont( m_hTFont );
|
surface()->DrawSetTextFont( m_hTFont );
|
||||||
surface()->DrawSetTextColor( cColor[0], cColor[1], cColor[2], cColor[3] );
|
surface()->DrawSetTextColor( cColor[0], cColor[1], cColor[2], cColor[3] );
|
||||||
|
|
||||||
@ -382,9 +524,56 @@ void CHudCredits::DrawOutroCreditsName( void )
|
|||||||
|
|
||||||
surface()->DrawSetTextPos( ( iWidth / 2 ) - ( iStringWidth / 2 ), pCredit->flYPos );
|
surface()->DrawSetTextPos( ( iWidth / 2 ) - ( iStringWidth / 2 ), pCredit->flYPos );
|
||||||
surface()->DrawUnicodeString( unicode );
|
surface()->DrawUnicodeString( unicode );
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
void CHudCredits::DrawOutroCreditFont( const char *pCreditName, float flYPos, vgui::HFont hTFont, const Color &cColor, int iScreenWidth, int iDivisor )
|
||||||
|
{
|
||||||
|
surface()->DrawSetTextFont( hTFont );
|
||||||
|
surface()->DrawSetTextColor( cColor[0], cColor[1], cColor[2], cColor[3] );
|
||||||
|
|
||||||
|
wchar_t unicode[256];
|
||||||
|
|
||||||
|
if ( pCreditName[0] == '#' )
|
||||||
|
{
|
||||||
|
g_pVGuiLocalize->ConstructString( unicode, sizeof(unicode), g_pVGuiLocalize->Find(pCreditName), 0 );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
g_pVGuiLocalize->ConvertANSIToUnicode( pCreditName, unicode, sizeof( unicode ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
int iStringWidth = GetStringPixelWidth( unicode, hTFont );
|
||||||
|
|
||||||
|
// ((iScreenWidth*iMultiplier) / iDivisor)
|
||||||
|
// When needed, just multiply iScreenWidth before sending to the function
|
||||||
|
surface()->DrawSetTextPos( (iScreenWidth / iDivisor) - (iStringWidth / 2), flYPos );
|
||||||
|
surface()->DrawUnicodeString( unicode );
|
||||||
|
}
|
||||||
|
|
||||||
|
void CHudCredits::DrawOutroCreditTexture( int iImageID, float flYPos, float flImageScale, const Color &cColor, int iScreenWidth, int iDivisor )
|
||||||
|
{
|
||||||
|
int iImageWide, iImageTall;
|
||||||
|
surface()->DrawGetTextureSize( iImageID, iImageWide, iImageTall );
|
||||||
|
|
||||||
|
// Scale for resolution
|
||||||
|
flImageScale *= ((float)GetTall() / 900.0f);
|
||||||
|
|
||||||
|
iImageWide = ((float)(iImageWide) * flImageScale);
|
||||||
|
iImageTall = ((float)(iImageTall) * flImageScale);
|
||||||
|
|
||||||
|
iImageWide /= 2;
|
||||||
|
//iImageTall /= 2;
|
||||||
|
iScreenWidth /= iDivisor;
|
||||||
|
|
||||||
|
surface()->DrawSetColor( cColor );
|
||||||
|
surface()->DrawSetTexture( iImageID );
|
||||||
|
surface()->DrawTexturedRect( iScreenWidth - iImageWide, flYPos, iScreenWidth + iImageWide, flYPos + iImageTall );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void CHudCredits::DrawLogo( void )
|
void CHudCredits::DrawLogo( void )
|
||||||
{
|
{
|
||||||
if( m_iLogoState == LOGO_FADEOFF )
|
if( m_iLogoState == LOGO_FADEOFF )
|
||||||
@ -464,13 +653,22 @@ void CHudCredits::DrawLogo( void )
|
|||||||
Q_snprintf( szLogoFont, sizeof( szLogoFont ), "WeaponIcons" );
|
Q_snprintf( szLogoFont, sizeof( szLogoFont ), "WeaponIcons" );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
vgui::HScheme scheme = GetScheme();
|
||||||
|
#else
|
||||||
vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
|
vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
|
||||||
|
#endif
|
||||||
vgui::HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont( szLogoFont );
|
vgui::HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont( szLogoFont );
|
||||||
|
|
||||||
int iFontTall = surface()->GetFontTall ( m_hTFont );
|
int iFontTall = surface()->GetFontTall ( m_hTFont );
|
||||||
|
|
||||||
Color cColor = m_TextColor;
|
Color cColor = m_TextColor;
|
||||||
cColor[3] = m_Alpha;
|
cColor[3] = m_Alpha;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if (m_cLogoColor.a() > 0)
|
||||||
|
cColor = m_cLogoColor;
|
||||||
|
#endif
|
||||||
|
|
||||||
surface()->DrawSetTextFont( m_hTFont );
|
surface()->DrawSetTextFont( m_hTFont );
|
||||||
surface()->DrawSetTextColor( cColor[0], cColor[1], cColor[2], cColor[3] );
|
surface()->DrawSetTextColor( cColor[0], cColor[1], cColor[2], cColor[3] );
|
||||||
@ -485,6 +683,19 @@ void CHudCredits::DrawLogo( void )
|
|||||||
|
|
||||||
if ( Q_strlen( m_szLogo2 ) > 0 )
|
if ( Q_strlen( m_szLogo2 ) > 0 )
|
||||||
{
|
{
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if (m_szLogo2Font[0] != '\0')
|
||||||
|
{
|
||||||
|
m_hTFont = vgui::scheme()->GetIScheme( scheme )->GetFont( m_szLogo2Font );
|
||||||
|
iFontTall = surface()->GetFontTall( m_hTFont );
|
||||||
|
surface()->DrawSetTextFont( m_hTFont );
|
||||||
|
}
|
||||||
|
if (m_cLogo2Color.a() > 0)
|
||||||
|
{
|
||||||
|
surface()->DrawSetTextColor( m_cLogo2Color[0], m_cLogo2Color[1], m_cLogo2Color[2], m_cLogo2Color[3] );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
g_pVGuiLocalize->ConvertANSIToUnicode( m_szLogo2, unicode, sizeof( unicode ) );
|
g_pVGuiLocalize->ConvertANSIToUnicode( m_szLogo2, unicode, sizeof( unicode ) );
|
||||||
|
|
||||||
iStringWidth = GetStringPixelWidth( unicode, m_hTFont );
|
iStringWidth = GetStringPixelWidth( unicode, m_hTFont );
|
||||||
@ -544,14 +755,26 @@ void CHudCredits::DrawIntroCreditsName( void )
|
|||||||
|
|
||||||
if ( pCredit->bActive == false )
|
if ( pCredit->bActive == false )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
vgui::HScheme scheme = GetScheme();
|
||||||
|
#else
|
||||||
vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
|
vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
|
||||||
|
#endif
|
||||||
vgui::HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont( pCredit->szFontName );
|
vgui::HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont( pCredit->szFontName );
|
||||||
|
|
||||||
float localTime = gpGlobals->curtime - pCredit->flTimeStart;
|
float localTime = gpGlobals->curtime - pCredit->flTimeStart;
|
||||||
|
|
||||||
surface()->DrawSetTextFont( m_hTFont );
|
surface()->DrawSetTextFont( m_hTFont );
|
||||||
|
#ifdef MAPBASE
|
||||||
|
Color cColor = m_cColor;
|
||||||
|
if (pCredit->cColorOverride.a() > 0)
|
||||||
|
cColor = pCredit->cColorOverride;
|
||||||
|
|
||||||
|
surface()->DrawSetTextColor( cColor[0], cColor[1], cColor[2], FadeBlend( m_flFadeInTime, m_flFadeOutTime, m_flFadeHoldTime + pCredit->flTimeAdd, localTime ) * cColor[3] );
|
||||||
|
#else
|
||||||
surface()->DrawSetTextColor( m_cColor[0], m_cColor[1], m_cColor[2], FadeBlend( m_flFadeInTime, m_flFadeOutTime, m_flFadeHoldTime + pCredit->flTimeAdd, localTime ) * m_cColor[3] );
|
surface()->DrawSetTextColor( m_cColor[0], m_cColor[1], m_cColor[2], FadeBlend( m_flFadeInTime, m_flFadeOutTime, m_flFadeHoldTime + pCredit->flTimeAdd, localTime ) * m_cColor[3] );
|
||||||
|
#endif
|
||||||
|
|
||||||
wchar_t unicode[256];
|
wchar_t unicode[256];
|
||||||
g_pVGuiLocalize->ConvertANSIToUnicode( pCredit->szCreditName, unicode, sizeof( unicode ) );
|
g_pVGuiLocalize->ConvertANSIToUnicode( pCredit->szCreditName, unicode, sizeof( unicode ) );
|
||||||
@ -692,17 +915,119 @@ void CHudCredits::PrepareOutroCredits( void )
|
|||||||
if ( pCredit == NULL )
|
if ( pCredit == NULL )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
vgui::HScheme scheme = GetScheme();
|
||||||
|
#else
|
||||||
vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
|
vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
|
||||||
vgui::HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont( pCredit->szFontName, true );
|
#endif
|
||||||
|
|
||||||
pCredit->flYPos = iHeight;
|
#ifdef MAPBASE
|
||||||
pCredit->bActive = false;
|
if (pCredit->szFontName[0] == '$')
|
||||||
|
{
|
||||||
|
if (V_strncmp( pCredit->szFontName + 1, "Image", 5 ) == 0)
|
||||||
|
{
|
||||||
|
if (pCredit->szFontName[6] == ';')
|
||||||
|
{
|
||||||
|
CUtlStringList outStrings;
|
||||||
|
V_SplitString( pCredit->szFontName, ";", outStrings );
|
||||||
|
FOR_EACH_VEC( outStrings, i )
|
||||||
|
{
|
||||||
|
switch (i)
|
||||||
|
{
|
||||||
|
// Get scale
|
||||||
|
case 1:
|
||||||
|
pCredit->flImageScale = atof( outStrings[i] );
|
||||||
|
break;
|
||||||
|
|
||||||
iHeight += surface()->GetFontTall ( m_hTFont ) + m_flSeparation;
|
// Get color
|
||||||
|
case 2:
|
||||||
|
int tmp[4];
|
||||||
|
UTIL_StringToIntArray( tmp, 4, outStrings[i] );
|
||||||
|
pCredit->cColorOverride = Color( tmp[0], tmp[1], tmp[2], tmp[3] );
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
outStrings.PurgeAndDeleteElements();
|
||||||
|
}
|
||||||
|
|
||||||
PrepareLine( m_hTFont, pCredit->szCreditName );
|
// Get the size of the tallest image if there's multiple
|
||||||
|
int iFontWide, iFontTall = 1;
|
||||||
|
if (m_bAllowColumns && V_strstr( pCredit->szCreditName, "\t" ))
|
||||||
|
{
|
||||||
|
CUtlStringList outStrings;
|
||||||
|
V_SplitString( pCredit->szCreditName, "\t", outStrings );
|
||||||
|
FOR_EACH_VEC( outStrings, i )
|
||||||
|
{
|
||||||
|
pCredit->iImageID = GetOrAllocateImageID( outStrings[i] );
|
||||||
|
|
||||||
|
int iTempTall;
|
||||||
|
surface()->DrawGetTextureSize( pCredit->iImageID, iFontWide, iTempTall );
|
||||||
|
if (iTempTall > iFontTall)
|
||||||
|
iFontTall = iTempTall;
|
||||||
|
}
|
||||||
|
outStrings.PurgeAndDeleteElements();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
pCredit->iImageID = GetOrAllocateImageID( pCredit->szCreditName );
|
||||||
|
surface()->DrawGetTextureSize( pCredit->iImageID, iFontWide, iFontTall );
|
||||||
|
}
|
||||||
|
|
||||||
|
pCredit->flYPos = iHeight;
|
||||||
|
pCredit->bActive = false;
|
||||||
|
|
||||||
|
iHeight += ((float)iFontTall * pCredit->flImageScale * ((float)GetTall() / 900.0f)) + m_flSeparation;
|
||||||
|
|
||||||
|
//Msg( "'%s' is image type (image scale is %f)\n", pCredit->szCreditName, pCredit->flImageScale );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//Msg( "'%s' is not an image type\n", pCredit->szFontName + 1 );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if (V_strstr( pCredit->szFontName, ";" ))
|
||||||
|
{
|
||||||
|
CUtlStringList outStrings;
|
||||||
|
V_SplitString( pCredit->szFontName, ";", outStrings );
|
||||||
|
FOR_EACH_VEC( outStrings, i )
|
||||||
|
{
|
||||||
|
switch (i)
|
||||||
|
{
|
||||||
|
// Get color
|
||||||
|
case 1:
|
||||||
|
int tmp[4];
|
||||||
|
UTIL_StringToIntArray( tmp, 4, outStrings[i] );
|
||||||
|
pCredit->cColorOverride = Color( tmp[0], tmp[1], tmp[2], tmp[3] );
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Q_strncpy( pCredit->szFontName, outStrings[0], sizeof( pCredit->szFontName ) );
|
||||||
|
outStrings.PurgeAndDeleteElements();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
vgui::HFont m_hTFont = vgui::scheme()->GetIScheme( scheme )->GetFont( pCredit->szFontName, true );
|
||||||
|
|
||||||
|
pCredit->flYPos = iHeight;
|
||||||
|
pCredit->bActive = false;
|
||||||
|
|
||||||
|
iHeight += surface()->GetFontTall ( m_hTFont ) + m_flSeparation;
|
||||||
|
|
||||||
|
PrepareLine( m_hTFont, pCredit->szCreditName );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
// Check if the last line has a color override. If it does, use that as the alpha for the fadeout
|
||||||
|
if (m_CreditsList.Tail().cColorOverride.a() != 0)
|
||||||
|
m_Alpha = m_CreditsList.Tail().cColorOverride.a();
|
||||||
|
#endif
|
||||||
|
|
||||||
SetActive( true );
|
SetActive( true );
|
||||||
|
|
||||||
g_iCreditsPixelHeight = iHeight;
|
g_iCreditsPixelHeight = iHeight;
|
||||||
@ -721,7 +1046,34 @@ void CHudCredits::PrepareIntroCredits( void )
|
|||||||
if ( pCredit == NULL )
|
if ( pCredit == NULL )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if (V_strstr( pCredit->szFontName, ";" ))
|
||||||
|
{
|
||||||
|
CUtlStringList outStrings;
|
||||||
|
V_SplitString( pCredit->szFontName, ";", outStrings );
|
||||||
|
FOR_EACH_VEC( outStrings, i )
|
||||||
|
{
|
||||||
|
switch (i)
|
||||||
|
{
|
||||||
|
// Get color
|
||||||
|
case 1:
|
||||||
|
int tmp[4];
|
||||||
|
UTIL_StringToIntArray( tmp, 4, outStrings[i] );
|
||||||
|
pCredit->cColorOverride = Color( tmp[0], tmp[1], tmp[2], tmp[3] );
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Q_strncpy( pCredit->szFontName, outStrings[0], sizeof( pCredit->szFontName ) );
|
||||||
|
outStrings.PurgeAndDeleteElements();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
vgui::HScheme scheme = GetScheme();
|
||||||
|
#else
|
||||||
vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
|
vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
|
||||||
|
#endif
|
||||||
vgui::HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont( pCredit->szFontName );
|
vgui::HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont( pCredit->szFontName );
|
||||||
|
|
||||||
pCredit->flYPos = m_flY + ( iSlot * surface()->GetFontTall ( m_hTFont ) );
|
pCredit->flYPos = m_flY + ( iSlot * surface()->GetFontTall ( m_hTFont ) );
|
||||||
@ -749,6 +1101,64 @@ void CHudCredits::PrepareIntroCredits( void )
|
|||||||
SetActive( true );
|
SetActive( true );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
void CHudCredits::PrecacheCredits()
|
||||||
|
{
|
||||||
|
PrepareCredits( "OutroCreditsNames" );
|
||||||
|
|
||||||
|
if ( m_CreditsList.Count() == 0 )
|
||||||
|
return;
|
||||||
|
|
||||||
|
for ( int i = 0; i < m_CreditsList.Count(); i++ )
|
||||||
|
{
|
||||||
|
creditname_t *pCredit = &m_CreditsList[i];
|
||||||
|
|
||||||
|
if ( pCredit == NULL )
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (pCredit->szFontName[0] == '$')
|
||||||
|
{
|
||||||
|
if (V_strncmp( pCredit->szFontName + 1, "Image", 5 ) == 0)
|
||||||
|
{
|
||||||
|
if (m_bAllowColumns && V_strstr( pCredit->szCreditName, "\t" ))
|
||||||
|
{
|
||||||
|
CUtlStringList outStrings;
|
||||||
|
V_SplitString( pCredit->szCreditName, "\t", outStrings );
|
||||||
|
FOR_EACH_VEC( outStrings, i )
|
||||||
|
{
|
||||||
|
GetOrAllocateImageID( outStrings[i] );
|
||||||
|
}
|
||||||
|
outStrings.PurgeAndDeleteElements();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
GetOrAllocateImageID( pCredit->szCreditName );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//Msg( "'%s' is not an image type\n", pCredit->szFontName + 1 );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
m_CreditsList.RemoveAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
int CHudCredits::GetOrAllocateImageID( const char *szFileName )
|
||||||
|
{
|
||||||
|
int iIndex = m_ImageDict.Find( szFileName );
|
||||||
|
if (iIndex == m_ImageDict.InvalidIndex())
|
||||||
|
{
|
||||||
|
iIndex = surface()->CreateNewTextureID();
|
||||||
|
m_ImageDict.Insert( szFileName, iIndex );
|
||||||
|
surface()->DrawSetTextureFile( iIndex, szFileName, true, false );
|
||||||
|
return iIndex;
|
||||||
|
}
|
||||||
|
return m_ImageDict[iIndex];
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void CHudCredits::MsgFunc_CreditsMsg( bf_read &msg )
|
void CHudCredits::MsgFunc_CreditsMsg( bf_read &msg )
|
||||||
{
|
{
|
||||||
m_iCreditsType = msg.ReadByte();
|
m_iCreditsType = msg.ReadByte();
|
||||||
@ -777,6 +1187,13 @@ void CHudCredits::MsgFunc_CreditsMsg( bf_read &msg )
|
|||||||
PrepareOutroCredits();
|
PrepareOutroCredits();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
#ifdef MAPBASE
|
||||||
|
case CREDITS_PRECACHE:
|
||||||
|
{
|
||||||
|
PrecacheCredits();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -644,6 +644,15 @@ void CHudWeaponSelection::Paint()
|
|||||||
// This is a bit of a misnomer... we really are asking "Is this the selected slot"?
|
// This is a bit of a misnomer... we really are asking "Is this the selected slot"?
|
||||||
selectedWeapon = true;
|
selectedWeapon = true;
|
||||||
}
|
}
|
||||||
|
#ifdef MAPBASE
|
||||||
|
else if (!hud_showemptyweaponslots.GetBool() && !pWeapon)
|
||||||
|
{
|
||||||
|
// Revert the offset
|
||||||
|
xPos -= ( m_flMediumBoxWide + 5 ) * xModifiers[ i ];
|
||||||
|
yPos -= ( m_flMediumBoxTall + 5 ) * yModifiers[ i ];
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
// Draw the box with the appropriate icon
|
// Draw the box with the appropriate icon
|
||||||
DrawLargeWeaponBox( pWeapon,
|
DrawLargeWeaponBox( pWeapon,
|
||||||
@ -1375,6 +1384,23 @@ void CHudWeaponSelection::PlusTypeFastWeaponSwitch( int iWeaponSlot )
|
|||||||
// Changing vertical/horizontal direction. Reset the selected box position to zero.
|
// Changing vertical/horizontal direction. Reset the selected box position to zero.
|
||||||
m_iSelectedBoxPosition = 0;
|
m_iSelectedBoxPosition = 0;
|
||||||
m_iSelectedSlot = iWeaponSlot;
|
m_iSelectedSlot = iWeaponSlot;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if (!hud_showemptyweaponslots.GetBool())
|
||||||
|
{
|
||||||
|
// Skip empty slots
|
||||||
|
int i = 0;
|
||||||
|
while ( i < MAX_WEAPON_POSITIONS )
|
||||||
|
{
|
||||||
|
C_BaseCombatWeapon *pWeapon = GetWeaponInSlot( iWeaponSlot, i );
|
||||||
|
if ( pWeapon )
|
||||||
|
break;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_iSelectedBoxPosition = i;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -1385,6 +1411,27 @@ void CHudWeaponSelection::PlusTypeFastWeaponSwitch( int iWeaponSlot )
|
|||||||
// Decrementing within the slot. If we're at the zero position in this slot,
|
// Decrementing within the slot. If we're at the zero position in this slot,
|
||||||
// jump to the zero position of the opposite slot. This also counts as our increment.
|
// jump to the zero position of the opposite slot. This also counts as our increment.
|
||||||
increment = -1;
|
increment = -1;
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if (!hud_showemptyweaponslots.GetBool())
|
||||||
|
{
|
||||||
|
// Skip empty slots
|
||||||
|
int iZeroPos = 0;
|
||||||
|
while ( iZeroPos < MAX_WEAPON_POSITIONS )
|
||||||
|
{
|
||||||
|
C_BaseCombatWeapon *pWeapon = GetWeaponInSlot( m_iSelectedSlot, iZeroPos );
|
||||||
|
if ( pWeapon )
|
||||||
|
break;
|
||||||
|
iZeroPos++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( iZeroPos == m_iSelectedBoxPosition )
|
||||||
|
{
|
||||||
|
newSlot = ( m_iSelectedSlot + 2 ) % 4;
|
||||||
|
m_iSelectedBoxPosition = increment = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
if ( 0 == m_iSelectedBoxPosition )
|
if ( 0 == m_iSelectedBoxPosition )
|
||||||
{
|
{
|
||||||
newSlot = ( m_iSelectedSlot + 2 ) % 4;
|
newSlot = ( m_iSelectedSlot + 2 ) % 4;
|
||||||
@ -1402,6 +1449,35 @@ void CHudWeaponSelection::PlusTypeFastWeaponSwitch( int iWeaponSlot )
|
|||||||
lastSlotPos = slotPos;
|
lastSlotPos = slotPos;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if (!hud_showemptyweaponslots.GetBool())
|
||||||
|
{
|
||||||
|
// Skip empty slots
|
||||||
|
int i = m_iSelectedBoxPosition + increment;
|
||||||
|
while ( i >= 0 && i < lastSlotPos )
|
||||||
|
{
|
||||||
|
C_BaseCombatWeapon *pWeapon = GetWeaponInSlot( newSlot, i );
|
||||||
|
if ( !pWeapon )
|
||||||
|
{
|
||||||
|
if (increment < 0)
|
||||||
|
{
|
||||||
|
increment--;
|
||||||
|
i--;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
increment++;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
// Increment/Decrement the selected box position
|
// Increment/Decrement the selected box position
|
||||||
if ( m_iSelectedBoxPosition + increment <= lastSlotPos )
|
if ( m_iSelectedBoxPosition + increment <= lastSlotPos )
|
||||||
|
@ -1303,7 +1303,7 @@ void CHudCloseCaption::Reset( void )
|
|||||||
Unlock();
|
Unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CHudCloseCaption::SplitCommand( wchar_t const **ppIn, wchar_t *cmd, wchar_t *args ) const
|
bool CHudCloseCaption::SplitCommand( wchar_t const **ppIn, wchar_t *cmd, wchar_t *args, int size ) const
|
||||||
{
|
{
|
||||||
const wchar_t *in = *ppIn;
|
const wchar_t *in = *ppIn;
|
||||||
const wchar_t *oldin = in;
|
const wchar_t *oldin = in;
|
||||||
@ -1318,8 +1318,11 @@ bool CHudCloseCaption::SplitCommand( wchar_t const **ppIn, wchar_t *cmd, wchar_t
|
|||||||
cmd[ 0 ]= 0;
|
cmd[ 0 ]= 0;
|
||||||
wchar_t *out = cmd;
|
wchar_t *out = cmd;
|
||||||
in++;
|
in++;
|
||||||
while ( *in != L'\0' && *in != L':' && *in != L'>' && !isspace( *in ) )
|
while ( *in != L'\0' && *in != L':' && *in != L'>' && !V_isspace( *in ) )
|
||||||
{
|
{
|
||||||
|
if ( (int)( out - cmd ) + (int)sizeof( wchar_t ) >= size )
|
||||||
|
break;
|
||||||
|
|
||||||
*out++ = *in++;
|
*out++ = *in++;
|
||||||
}
|
}
|
||||||
*out = L'\0';
|
*out = L'\0';
|
||||||
@ -1334,6 +1337,9 @@ bool CHudCloseCaption::SplitCommand( wchar_t const **ppIn, wchar_t *cmd, wchar_t
|
|||||||
out = args;
|
out = args;
|
||||||
while ( *in != L'\0' && *in != L'>' )
|
while ( *in != L'\0' && *in != L'>' )
|
||||||
{
|
{
|
||||||
|
if ( (int)( out - args ) + (int)sizeof( wchar_t ) >= size )
|
||||||
|
break;
|
||||||
|
|
||||||
*out++ = *in++;
|
*out++ = *in++;
|
||||||
}
|
}
|
||||||
*out = L'\0';
|
*out = L'\0';
|
||||||
@ -1361,7 +1367,7 @@ bool CHudCloseCaption::GetFloatCommandValue( const wchar_t *stream, const wchar_
|
|||||||
wchar_t cmd[ 256 ];
|
wchar_t cmd[ 256 ];
|
||||||
wchar_t args[ 256 ];
|
wchar_t args[ 256 ];
|
||||||
|
|
||||||
if ( SplitCommand( &curpos, cmd, args ) )
|
if ( SplitCommand( &curpos, cmd, args, sizeof( cmd ) ) )
|
||||||
{
|
{
|
||||||
if ( !wcscmp( cmd, findcmd ) )
|
if ( !wcscmp( cmd, findcmd ) )
|
||||||
{
|
{
|
||||||
@ -1385,7 +1391,7 @@ bool CHudCloseCaption::StreamHasCommand( const wchar_t *stream, const wchar_t *f
|
|||||||
wchar_t cmd[ 256 ];
|
wchar_t cmd[ 256 ];
|
||||||
wchar_t args[ 256 ];
|
wchar_t args[ 256 ];
|
||||||
|
|
||||||
if ( SplitCommand( &curpos, cmd, args ) )
|
if ( SplitCommand( &curpos, cmd, args, sizeof( cmd ) ) )
|
||||||
{
|
{
|
||||||
if ( !wcscmp( cmd, findcmd ) )
|
if ( !wcscmp( cmd, findcmd ) )
|
||||||
{
|
{
|
||||||
@ -1424,7 +1430,7 @@ bool CHudCloseCaption::StreamHasCommand( const wchar_t *stream, const wchar_t *s
|
|||||||
wchar_t cmd[ 256 ];
|
wchar_t cmd[ 256 ];
|
||||||
wchar_t args[ 256 ];
|
wchar_t args[ 256 ];
|
||||||
|
|
||||||
if ( SplitCommand( &curpos, cmd, args ) )
|
if ( SplitCommand( &curpos, cmd, args, sizeof( cmd ) ) )
|
||||||
{
|
{
|
||||||
if ( !wcscmp( cmd, search ) )
|
if ( !wcscmp( cmd, search ) )
|
||||||
{
|
{
|
||||||
@ -1516,7 +1522,7 @@ void CHudCloseCaption::Process( const wchar_t *stream, float duration, const cha
|
|||||||
|
|
||||||
const wchar_t *prevpos = curpos;
|
const wchar_t *prevpos = curpos;
|
||||||
|
|
||||||
if ( SplitCommand( &curpos, cmd, args ) )
|
if ( SplitCommand( &curpos, cmd, args, sizeof( cmd ) ) )
|
||||||
{
|
{
|
||||||
if ( !wcscmp( cmd, L"delay" ) )
|
if ( !wcscmp( cmd, L"delay" ) )
|
||||||
{
|
{
|
||||||
@ -1613,6 +1619,9 @@ struct WorkUnitParams
|
|||||||
clr = Color( 255, 255, 255, 255 );
|
clr = Color( 255, 255, 255, 255 );
|
||||||
newline = false;
|
newline = false;
|
||||||
font = 0;
|
font = 0;
|
||||||
|
#ifdef MAPBASE
|
||||||
|
customFont = false;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
~WorkUnitParams()
|
~WorkUnitParams()
|
||||||
@ -1658,6 +1667,9 @@ struct WorkUnitParams
|
|||||||
Color clr;
|
Color clr;
|
||||||
bool newline;
|
bool newline;
|
||||||
vgui::HFont font;
|
vgui::HFont font;
|
||||||
|
#ifdef MAPBASE
|
||||||
|
bool customFont;
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
void CHudCloseCaption::AddWorkUnit( CCloseCaptionItem *item,
|
void CHudCloseCaption::AddWorkUnit( CCloseCaptionItem *item,
|
||||||
@ -1717,7 +1729,7 @@ void CHudCloseCaption::ComputeStreamWork( int available_width, CCloseCaptionItem
|
|||||||
wchar_t cmd[ 256 ];
|
wchar_t cmd[ 256 ];
|
||||||
wchar_t args[ 256 ];
|
wchar_t args[ 256 ];
|
||||||
|
|
||||||
if ( SplitCommand( &curpos, cmd, args ) )
|
if ( SplitCommand( &curpos, cmd, args, sizeof( cmd ) ) )
|
||||||
{
|
{
|
||||||
if ( !wcscmp( cmd, L"cr" ) )
|
if ( !wcscmp( cmd, L"cr" ) )
|
||||||
{
|
{
|
||||||
@ -1772,27 +1784,58 @@ void CHudCloseCaption::ComputeStreamWork( int available_width, CCloseCaptionItem
|
|||||||
{
|
{
|
||||||
AddWorkUnit( item, params );
|
AddWorkUnit( item, params );
|
||||||
params.italic = !params.italic;
|
params.italic = !params.italic;
|
||||||
|
#ifdef MAPBASE
|
||||||
|
params.customFont = false;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
else if ( !wcscmp( cmd, L"B" ) )
|
else if ( !wcscmp( cmd, L"B" ) )
|
||||||
{
|
{
|
||||||
AddWorkUnit( item, params );
|
AddWorkUnit( item, params );
|
||||||
params.bold = !params.bold;
|
params.bold = !params.bold;
|
||||||
|
#ifdef MAPBASE
|
||||||
|
params.customFont = false;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
#ifdef MAPBASE
|
||||||
|
else if ( !wcscmp( cmd, L"font" ) )
|
||||||
|
{
|
||||||
|
AddWorkUnit( item, params );
|
||||||
|
vgui::IScheme *pScheme = vgui::scheme()->GetIScheme( GetScheme() );
|
||||||
|
|
||||||
|
if ( args[0] != 0 )
|
||||||
|
{
|
||||||
|
char font[64];
|
||||||
|
g_pVGuiLocalize->ConvertUnicodeToANSI( args, font, sizeof( font ) );
|
||||||
|
params.font = pScheme->GetFont( font );
|
||||||
|
params.customFont = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
params.customFont = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
int font;
|
vgui::HFont useF = params.font;
|
||||||
if ( IsPC() )
|
#ifdef MAPBASE
|
||||||
|
if (params.customFont == false)
|
||||||
|
#endif
|
||||||
{
|
{
|
||||||
font = params.GetFontNumber();
|
int font;
|
||||||
|
if ( IsPC() )
|
||||||
|
{
|
||||||
|
font = params.GetFontNumber();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
font = streamlen >= cc_smallfontlength.GetInt() ? CCFONT_SMALL : CCFONT_NORMAL;
|
||||||
|
}
|
||||||
|
useF = m_hFonts[font];
|
||||||
|
params.font = useF;
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
font = streamlen >= cc_smallfontlength.GetInt() ? CCFONT_SMALL : CCFONT_NORMAL;
|
|
||||||
}
|
|
||||||
vgui::HFont useF = m_hFonts[font];
|
|
||||||
params.font = useF;
|
|
||||||
|
|
||||||
int w, h;
|
int w, h;
|
||||||
|
|
||||||
@ -1940,7 +1983,7 @@ bool CHudCloseCaption::GetNoRepeatValue( const wchar_t *caption, float &retval )
|
|||||||
wchar_t cmd[ 256 ];
|
wchar_t cmd[ 256 ];
|
||||||
wchar_t args[ 256 ];
|
wchar_t args[ 256 ];
|
||||||
|
|
||||||
if ( SplitCommand( &curpos, cmd, args ) )
|
if ( SplitCommand( &curpos, cmd, args, sizeof( cmd ) ) )
|
||||||
{
|
{
|
||||||
if ( !wcscmp( cmd, L"norepeat" ) )
|
if ( !wcscmp( cmd, L"norepeat" ) )
|
||||||
{
|
{
|
||||||
@ -2631,6 +2674,124 @@ void CHudCloseCaption::InitCaptionDictionary( const char *dbfile )
|
|||||||
g_AsyncCaptionResourceManager.SetDbInfo( m_AsyncCaptions );
|
g_AsyncCaptionResourceManager.SetDbInfo( m_AsyncCaptions );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
void CHudCloseCaption::AddAdditionalCaptionDictionary( const char *dbfile, CUtlVector<CUtlSymbol> &outPathSymbols )
|
||||||
|
{
|
||||||
|
CGMsg( 1, CON_GROUP_MAPBASE_MISC, "Adding additional caption dictionary \"%s\"\n", dbfile );
|
||||||
|
|
||||||
|
g_AsyncCaptionResourceManager.Clear();
|
||||||
|
|
||||||
|
char searchPaths[4096];
|
||||||
|
filesystem->GetSearchPath( "MOD", true, searchPaths, sizeof( searchPaths ) );
|
||||||
|
|
||||||
|
for ( char *path = strtok( searchPaths, ";" ); path; path = strtok( NULL, ";" ) )
|
||||||
|
{
|
||||||
|
if ( IsX360() && ( filesystem->GetDVDMode() == DVDMODE_STRICT ) && !V_stristr( path, ".zip" ) )
|
||||||
|
{
|
||||||
|
// only want zip paths
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
char fullpath[MAX_PATH];
|
||||||
|
Q_snprintf( fullpath, sizeof( fullpath ), "%s%s", path, dbfile );
|
||||||
|
Q_FixSlashes( fullpath );
|
||||||
|
|
||||||
|
if ( IsX360() )
|
||||||
|
{
|
||||||
|
char fullpath360[MAX_PATH];
|
||||||
|
UpdateOrCreateCaptionFile( fullpath, fullpath360, sizeof( fullpath360 ) );
|
||||||
|
Q_strncpy( fullpath, fullpath360, sizeof( fullpath ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Seach for this dictionary. If it already exists, remove it.
|
||||||
|
for (int i = 0; i < m_AsyncCaptions.Count(); ++i)
|
||||||
|
{
|
||||||
|
if (FStrEq( m_AsyncCaptions[i].m_DataBaseFile.String(), fullpath ))
|
||||||
|
{
|
||||||
|
m_AsyncCaptions.Remove( i );
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
FileHandle_t fh = filesystem->Open( fullpath, "rb" );
|
||||||
|
if ( FILESYSTEM_INVALID_HANDLE != fh )
|
||||||
|
{
|
||||||
|
MEM_ALLOC_CREDIT();
|
||||||
|
|
||||||
|
CUtlBuffer dirbuffer;
|
||||||
|
|
||||||
|
AsyncCaption_t& entry = m_AsyncCaptions[ m_AsyncCaptions.AddToTail() ];
|
||||||
|
|
||||||
|
// Read the header
|
||||||
|
filesystem->Read( &entry.m_Header, sizeof( entry.m_Header ), fh );
|
||||||
|
if ( entry.m_Header.magic != COMPILED_CAPTION_FILEID )
|
||||||
|
Error( "Invalid file id for %s\n", fullpath );
|
||||||
|
if ( entry.m_Header.version != COMPILED_CAPTION_VERSION )
|
||||||
|
Error( "Invalid file version for %s\n", fullpath );
|
||||||
|
if ( entry.m_Header.directorysize < 0 || entry.m_Header.directorysize > 64 * 1024 )
|
||||||
|
Error( "Invalid directory size %d for %s\n", entry.m_Header.directorysize, fullpath );
|
||||||
|
//if ( entry.m_Header.blocksize != MAX_BLOCK_SIZE )
|
||||||
|
// Error( "Invalid block size %d, expecting %d for %s\n", entry.m_Header.blocksize, MAX_BLOCK_SIZE, fullpath );
|
||||||
|
|
||||||
|
int directoryBytes = entry.m_Header.directorysize * sizeof( CaptionLookup_t );
|
||||||
|
entry.m_CaptionDirectory.EnsureCapacity( entry.m_Header.directorysize );
|
||||||
|
dirbuffer.EnsureCapacity( directoryBytes );
|
||||||
|
|
||||||
|
filesystem->Read( dirbuffer.Base(), directoryBytes, fh );
|
||||||
|
filesystem->Close( fh );
|
||||||
|
|
||||||
|
entry.m_CaptionDirectory.CopyArray( (const CaptionLookup_t *)dirbuffer.PeekGet(), entry.m_Header.directorysize );
|
||||||
|
entry.m_CaptionDirectory.RedoSort( true );
|
||||||
|
|
||||||
|
entry.m_DataBaseFile = fullpath;
|
||||||
|
outPathSymbols.AddToTail( entry.m_DataBaseFile );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
g_AsyncCaptionResourceManager.SetDbInfo( m_AsyncCaptions );
|
||||||
|
}
|
||||||
|
|
||||||
|
void CHudCloseCaption::AddCustomCaptionFile( char const *file, CUtlVector<CUtlSymbol> &outPathSymbols )
|
||||||
|
{
|
||||||
|
//
|
||||||
|
// 'file' should be something like "maps/mapbase_demo01_closecaption_%language%"
|
||||||
|
//
|
||||||
|
|
||||||
|
CGMsg( 1, CON_GROUP_MAPBASE_MISC, "Adding custom caption file \"%s\"\n", file );
|
||||||
|
|
||||||
|
if (!IsX360())
|
||||||
|
{
|
||||||
|
g_pVGuiLocalize->AddFile( file, "MOD", true );
|
||||||
|
}
|
||||||
|
|
||||||
|
char uilanguage[64];
|
||||||
|
engine->GetUILanguage( uilanguage, sizeof( uilanguage ) );
|
||||||
|
|
||||||
|
char dbfile[512];
|
||||||
|
V_StrSubst( file, "%language%", uilanguage, dbfile, sizeof( dbfile ) );
|
||||||
|
V_SetExtension( dbfile, ".dat", sizeof( dbfile ) );
|
||||||
|
AddAdditionalCaptionDictionary( dbfile, outPathSymbols );
|
||||||
|
}
|
||||||
|
|
||||||
|
void CHudCloseCaption::RemoveCaptionDictionary( const CUtlSymbol &dbFileSymbol )
|
||||||
|
{
|
||||||
|
//
|
||||||
|
// 'file' should be something like "maps/mapbase_demo01_closecaption_%language%"
|
||||||
|
//
|
||||||
|
|
||||||
|
CGMsg( 1, CON_GROUP_MAPBASE_MISC, "Removing custom caption file \"%s\"\n", dbFileSymbol.String() );
|
||||||
|
|
||||||
|
for (int i = 0; i < m_AsyncCaptions.Count(); ++i)
|
||||||
|
{
|
||||||
|
if ( m_AsyncCaptions[i].m_DataBaseFile == dbFileSymbol )
|
||||||
|
{
|
||||||
|
m_AsyncCaptions.Remove( i );
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void CHudCloseCaption::OnFinishAsyncLoad( int nFileIndex, int nBlockNum, AsyncCaptionData_t *pData )
|
void CHudCloseCaption::OnFinishAsyncLoad( int nFileIndex, int nBlockNum, AsyncCaptionData_t *pData )
|
||||||
{
|
{
|
||||||
// Fill in data for all users of pData->m_nBlockNum
|
// Fill in data for all users of pData->m_nBlockNum
|
||||||
|
@ -111,6 +111,11 @@ public:
|
|||||||
void PlayRandomCaption();
|
void PlayRandomCaption();
|
||||||
|
|
||||||
void InitCaptionDictionary( char const *dbfile );
|
void InitCaptionDictionary( char const *dbfile );
|
||||||
|
#ifdef MAPBASE
|
||||||
|
void AddAdditionalCaptionDictionary( char const *dbfile, CUtlVector<CUtlSymbol> &outPathSymbols );
|
||||||
|
void AddCustomCaptionFile( char const *file, CUtlVector<CUtlSymbol> &outPathSymbols );
|
||||||
|
void RemoveCaptionDictionary( const CUtlSymbol &dbFileSymbol );
|
||||||
|
#endif
|
||||||
void OnFinishAsyncLoad( int nFileIndex, int nBlockNum, AsyncCaptionData_t *pData );
|
void OnFinishAsyncLoad( int nFileIndex, int nBlockNum, AsyncCaptionData_t *pData );
|
||||||
|
|
||||||
void Flush();
|
void Flush();
|
||||||
@ -133,6 +138,11 @@ public:
|
|||||||
|
|
||||||
void FindSound( char const *pchANSI );
|
void FindSound( char const *pchANSI );
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
inline bool IsUsingCommentaryDimensions() const { return m_bUsingCommentaryDimensions; }
|
||||||
|
inline void SetUsingCommentaryDimensions( bool bToggle ) { m_bUsingCommentaryDimensions = bToggle; }
|
||||||
|
#endif
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
struct CaptionRepeat
|
struct CaptionRepeat
|
||||||
@ -169,7 +179,7 @@ private:
|
|||||||
|
|
||||||
void DrawStream( wrect_t& rect, wrect_t &rcWindow, CCloseCaptionItem *item, int iFadeLine, float flFadeLineAlpha );
|
void DrawStream( wrect_t& rect, wrect_t &rcWindow, CCloseCaptionItem *item, int iFadeLine, float flFadeLineAlpha );
|
||||||
void ComputeStreamWork( int available_width, CCloseCaptionItem *item );
|
void ComputeStreamWork( int available_width, CCloseCaptionItem *item );
|
||||||
bool SplitCommand( wchar_t const **ppIn, wchar_t *cmd, wchar_t *args ) const;
|
bool SplitCommand( wchar_t const **ppIn, wchar_t *cmd, wchar_t *args, int size ) const;
|
||||||
|
|
||||||
bool StreamHasCommand( const wchar_t *stream, const wchar_t *findcmd ) const;
|
bool StreamHasCommand( const wchar_t *stream, const wchar_t *findcmd ) const;
|
||||||
bool GetFloatCommandValue( const wchar_t *stream, const wchar_t *findcmd, float& value ) const;
|
bool GetFloatCommandValue( const wchar_t *stream, const wchar_t *findcmd, float& value ) const;
|
||||||
@ -212,6 +222,10 @@ private:
|
|||||||
bool m_bVisibleDueToDirect;
|
bool m_bVisibleDueToDirect;
|
||||||
bool m_bPaintDebugInfo;
|
bool m_bPaintDebugInfo;
|
||||||
CUtlSymbol m_CurrentLanguage;
|
CUtlSymbol m_CurrentLanguage;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
bool m_bUsingCommentaryDimensions;
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // HUD_CLOSECAPTION_H
|
#endif // HUD_CLOSECAPTION_H
|
||||||
|
@ -528,15 +528,15 @@ void CLCD::ShowItems_R( CLCDPage *page, unsigned int dwCurTime, CUtlVector< CLCD
|
|||||||
{
|
{
|
||||||
CLCDItem *newItem = NULL;
|
CLCDItem *newItem = NULL;
|
||||||
|
|
||||||
CLCDItem *item = ag->m_Definition[ r ];
|
CLCDItem *itemLocl = ag->m_Definition[ r ];
|
||||||
switch ( item->m_Type )
|
switch ( itemLocl->m_Type )
|
||||||
{
|
{
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LCDITEM_TEXT:
|
case LCDITEM_TEXT:
|
||||||
{
|
{
|
||||||
CLCDItemText *text = static_cast< CLCDItemText * >( item );
|
CLCDItemText *text = static_cast< CLCDItemText * >( itemLocl );
|
||||||
CUtlString s;
|
CUtlString s;
|
||||||
s = text->m_OriginalText;
|
s = text->m_OriginalText;
|
||||||
Replace( s, prefix, s1 );
|
Replace( s, prefix, s1 );
|
||||||
@ -551,7 +551,7 @@ void CLCD::ShowItems_R( CLCDPage *page, unsigned int dwCurTime, CUtlVector< CLCD
|
|||||||
|
|
||||||
// text->m_OriginalText = s;
|
// text->m_OriginalText = s;
|
||||||
|
|
||||||
CLCDItemText *copy = static_cast< CLCDItemText * >( page->Alloc( item->m_Type ) );
|
CLCDItemText *copy = static_cast< CLCDItemText * >( page->Alloc( itemLocl->m_Type ) );
|
||||||
*copy = *text;
|
*copy = *text;
|
||||||
copy->m_bActive = true;
|
copy->m_bActive = true;
|
||||||
copy->m_OriginalText = s;
|
copy->m_OriginalText = s;
|
||||||
@ -564,8 +564,8 @@ void CLCD::ShowItems_R( CLCDPage *page, unsigned int dwCurTime, CUtlVector< CLCD
|
|||||||
break;
|
break;
|
||||||
case LCDITEM_ICON:
|
case LCDITEM_ICON:
|
||||||
{
|
{
|
||||||
CLCDItemIcon *icon = static_cast< CLCDItemIcon * >( item );
|
CLCDItemIcon *icon = static_cast< CLCDItemIcon * >( itemLocl );
|
||||||
CLCDItemIcon *copy = static_cast< CLCDItemIcon * >( page->Alloc( item->m_Type ) );
|
CLCDItemIcon *copy = static_cast< CLCDItemIcon * >( page->Alloc( itemLocl->m_Type ) );
|
||||||
*copy = *icon;
|
*copy = *icon;
|
||||||
copy->m_bActive = true;
|
copy->m_bActive = true;
|
||||||
copy->Create( m_lcd );
|
copy->Create( m_lcd );
|
||||||
@ -1186,16 +1186,16 @@ void CLCD::DumpPlayer()
|
|||||||
C_Team *team = player->GetTeam();
|
C_Team *team = player->GetTeam();
|
||||||
if ( team )
|
if ( team )
|
||||||
{
|
{
|
||||||
CDescribeData helper( team );
|
CDescribeData helperLocl( team );
|
||||||
helper.DumpDescription( team->GetPredDescMap() );
|
helperLocl.DumpDescription( team->GetPredDescMap() );
|
||||||
}
|
}
|
||||||
|
|
||||||
Msg( "(playerresource)\n\n" );
|
Msg( "(playerresource)\n\n" );
|
||||||
|
|
||||||
if ( g_PR )
|
if ( g_PR )
|
||||||
{
|
{
|
||||||
CDescribeData helper( g_PR );
|
CDescribeData helperLocl( g_PR );
|
||||||
helper.DumpDescription( g_PR->GetPredDescMap() );
|
helperLocl.DumpDescription( g_PR->GetPredDescMap() );
|
||||||
}
|
}
|
||||||
|
|
||||||
Msg( "(localplayerweapon)\n\n" );
|
Msg( "(localplayerweapon)\n\n" );
|
||||||
@ -1203,8 +1203,8 @@ void CLCD::DumpPlayer()
|
|||||||
C_BaseCombatWeapon *active = player->GetActiveWeapon();
|
C_BaseCombatWeapon *active = player->GetActiveWeapon();
|
||||||
if ( active )
|
if ( active )
|
||||||
{
|
{
|
||||||
CDescribeData helper( active );
|
CDescribeData helperLocl( active );
|
||||||
helper.DumpDescription( active->GetPredDescMap() );
|
helperLocl.DumpDescription( active->GetPredDescMap() );
|
||||||
}
|
}
|
||||||
|
|
||||||
Msg( "Other replacements:\n\n" );
|
Msg( "Other replacements:\n\n" );
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
#include "iclientmode.h"
|
#include "iclientmode.h"
|
||||||
#include <vgui/ILocalize.h>
|
#include <vgui/ILocalize.h>
|
||||||
#include <vgui/ISurface.h>
|
#include <vgui/ISurface.h>
|
||||||
#include <vgui/IVGUI.h>
|
#include <vgui/IVGui.h>
|
||||||
#include <vgui_controls/EditablePanel.h>
|
#include <vgui_controls/EditablePanel.h>
|
||||||
#include <vgui_controls/Controls.h>
|
#include <vgui_controls/Controls.h>
|
||||||
#include <vgui_controls/Label.h>
|
#include <vgui_controls/Label.h>
|
||||||
|
@ -34,7 +34,7 @@
|
|||||||
#define LOCATOR_ICON_FX_FADE_OUT 0x00000800 // Set when deactivated so it can smoothly vanish
|
#define LOCATOR_ICON_FX_FADE_OUT 0x00000800 // Set when deactivated so it can smoothly vanish
|
||||||
#define LOCATOR_ICON_FX_FADE_IN 0x00001000 // Set when activated so it can smoothly appear
|
#define LOCATOR_ICON_FX_FADE_IN 0x00001000 // Set when activated so it can smoothly appear
|
||||||
|
|
||||||
#include "tier1/UtlSymbol.h"
|
#include "tier1/utlsymbol.h"
|
||||||
|
|
||||||
// See comments in UtlSymbol on why this is useful
|
// See comments in UtlSymbol on why this is useful
|
||||||
DECLARE_PRIVATE_SYMBOLTYPE( CGameInstructorSymbol );
|
DECLARE_PRIVATE_SYMBOLTYPE( CGameInstructorSymbol );
|
||||||
|
@ -21,9 +21,15 @@ static CPDumpPanel *g_pPDumpPanel = NULL;
|
|||||||
// we pragma'd away in platform.h, so this little compiler specific hack will eliminate those warnings while
|
// we pragma'd away in platform.h, so this little compiler specific hack will eliminate those warnings while
|
||||||
// retaining our own warning setup...ywb
|
// retaining our own warning setup...ywb
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
|
|
||||||
|
#if _MSC_VER < 1900
|
||||||
#pragma warning( push )
|
#pragma warning( push )
|
||||||
#include <typeinfo.h>
|
#include <typeinfo.h>
|
||||||
#pragma warning( pop )
|
#pragma warning( pop )
|
||||||
|
#else
|
||||||
|
#include <typeinfo>
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
using namespace vgui;
|
using namespace vgui;
|
||||||
|
@ -58,6 +58,9 @@ public:
|
|||||||
// Hidden bits.
|
// Hidden bits.
|
||||||
// HIDEHUD_ flags that note when this element should be hidden in the HUD
|
// HIDEHUD_ flags that note when this element should be hidden in the HUD
|
||||||
virtual void SetHiddenBits( int iBits );
|
virtual void SetHiddenBits( int iBits );
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
int GetHiddenBits() const { return m_iHiddenBits; }
|
||||||
|
#endif
|
||||||
|
|
||||||
bool IsParentedToClientDLLRootPanel() const;
|
bool IsParentedToClientDLLRootPanel() const;
|
||||||
void SetParentedToClientDLLRootPanel( bool parented );
|
void SetParentedToClientDLLRootPanel( bool parented );
|
||||||
|
@ -112,6 +112,11 @@ public:
|
|||||||
|
|
||||||
virtual bool CanRecordDemo( char *errorMsg, int length ) const = 0;
|
virtual bool CanRecordDemo( char *errorMsg, int length ) const = 0;
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
virtual void OnColorCorrectionWeightsReset( void ) = 0;
|
||||||
|
virtual float GetColorCorrectionScale( void ) const = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
virtual void ComputeVguiResConditions( KeyValues *pkvConditions ) = 0;
|
virtual void ComputeVguiResConditions( KeyValues *pkvConditions ) = 0;
|
||||||
|
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
|
@ -25,7 +25,9 @@
|
|||||||
#include "tier0/icommandline.h"
|
#include "tier0/icommandline.h"
|
||||||
#include "inputsystem/iinputsystem.h"
|
#include "inputsystem/iinputsystem.h"
|
||||||
#include "inputsystem/ButtonCode.h"
|
#include "inputsystem/ButtonCode.h"
|
||||||
|
#if _MSC_VER < 1900
|
||||||
#include "math.h"
|
#include "math.h"
|
||||||
|
#endif
|
||||||
#include "tier1/convar_serverbounded.h"
|
#include "tier1/convar_serverbounded.h"
|
||||||
#include "cam_thirdperson.h"
|
#include "cam_thirdperson.h"
|
||||||
|
|
||||||
|
@ -119,6 +119,13 @@ public:
|
|||||||
virtual void SetScreenOverlayMaterial( IMaterial *pMaterial ) = 0;
|
virtual void SetScreenOverlayMaterial( IMaterial *pMaterial ) = 0;
|
||||||
virtual IMaterial *GetScreenOverlayMaterial( ) = 0;
|
virtual IMaterial *GetScreenOverlayMaterial( ) = 0;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
virtual void SetIndexedScreenOverlayMaterial( int i, IMaterial *pMaterial ) = 0;
|
||||||
|
virtual IMaterial *GetIndexedScreenOverlayMaterial( int i ) = 0;
|
||||||
|
virtual void ResetIndexedScreenOverlays() = 0;
|
||||||
|
virtual int GetMaxIndexedScreenOverlays() const = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
virtual void WriteSaveGameScreenshot( const char *pFilename ) = 0;
|
virtual void WriteSaveGameScreenshot( const char *pFilename ) = 0;
|
||||||
virtual void WriteSaveGameScreenshotOfSize( const char *pFilename, int width, int height, bool bCreatePowerOf2Padded = false, bool bWriteVTF = false ) = 0;
|
virtual void WriteSaveGameScreenshotOfSize( const char *pFilename, int width, int height, bool bCreatePowerOf2Padded = false, bool bWriteVTF = false ) = 0;
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
//========= Mapbase - https://github.com/mapbase-source/source-sdk-2013 ============//
|
//========= Mapbase - https://github.com/mapbase-source/source-sdk-2013 ============//
|
||||||
//
|
//
|
||||||
// Purpose: Recreates Portal 2 linked_portal_door functionality using SDK code only.
|
// Purpose: Recreates Portal 2 linked_portal_door visual functionality using SDK code only.
|
||||||
// (basically a combination of point_camera and func_reflective_glass)
|
// (basically a combination of point_camera and func_reflective_glass)
|
||||||
//
|
//
|
||||||
// $NoKeywords: $
|
// $NoKeywords: $
|
||||||
@ -58,70 +58,11 @@ bool C_FuncFakeWorldPortal::ShouldDraw()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
// Do we have a fake world portal in view?
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
C_FuncFakeWorldPortal *IsFakeWorldPortalInView( const CViewSetup& view, cplane_t &plane )
|
|
||||||
{
|
|
||||||
// Early out if no cameras
|
|
||||||
C_FuncFakeWorldPortal *pReflectiveGlass = GetFakeWorldPortalList();
|
|
||||||
if ( !pReflectiveGlass )
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
Frustum_t frustum;
|
|
||||||
GeneratePerspectiveFrustum( view.origin, view.angles, view.zNear, view.zFar, view.fov, view.m_flAspectRatio, frustum );
|
|
||||||
|
|
||||||
cplane_t localPlane;
|
|
||||||
Vector vecOrigin, vecWorld, vecDelta, vecForward;
|
|
||||||
AngleVectors( view.angles, &vecForward, NULL, NULL );
|
|
||||||
|
|
||||||
for ( ; pReflectiveGlass != NULL; pReflectiveGlass = pReflectiveGlass->m_pNext )
|
|
||||||
{
|
|
||||||
if ( pReflectiveGlass->IsDormant() )
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if ( pReflectiveGlass->m_iViewHideFlags & (1 << CurrentViewID()) )
|
|
||||||
continue;
|
|
||||||
|
|
||||||
Vector vecMins, vecMaxs;
|
|
||||||
pReflectiveGlass->GetRenderBoundsWorldspace( vecMins, vecMaxs );
|
|
||||||
if ( R_CullBox( vecMins, vecMaxs, frustum ) )
|
|
||||||
continue;
|
|
||||||
|
|
||||||
const model_t *pModel = pReflectiveGlass->GetModel();
|
|
||||||
const matrix3x4_t& mat = pReflectiveGlass->EntityToWorldTransform();
|
|
||||||
|
|
||||||
int nCount = modelinfo->GetBrushModelPlaneCount( pModel );
|
|
||||||
for ( int i = 0; i < nCount; ++i )
|
|
||||||
{
|
|
||||||
modelinfo->GetBrushModelPlane( pModel, i, localPlane, &vecOrigin );
|
|
||||||
|
|
||||||
MatrixTransformPlane( mat, localPlane, plane ); // Transform to world space
|
|
||||||
VectorTransform( vecOrigin, mat, vecWorld );
|
|
||||||
|
|
||||||
if ( view.origin.Dot( plane.normal ) <= plane.dist ) // Check for view behind plane
|
|
||||||
continue;
|
|
||||||
|
|
||||||
VectorSubtract( vecWorld, view.origin, vecDelta ); // Backface cull
|
|
||||||
if ( vecDelta.Dot( plane.normal ) >= 0 )
|
|
||||||
continue;
|
|
||||||
|
|
||||||
// Must have valid plane
|
|
||||||
if ( !pReflectiveGlass->m_hTargetPlane )
|
|
||||||
continue;
|
|
||||||
|
|
||||||
return pReflectiveGlass;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Iterates through fake world portals instead of just picking one
|
// Iterates through fake world portals instead of just picking one
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
C_FuncFakeWorldPortal *NextFakeWorldPortal( C_FuncFakeWorldPortal *pStart, const CViewSetup& view, cplane_t &plane,
|
C_FuncFakeWorldPortal *NextFakeWorldPortal( C_FuncFakeWorldPortal *pStart, const CViewSetup& view,
|
||||||
const Frustum_t &frustum )
|
Vector &vecAbsPlaneNormal, float &flLocalPlaneDist, const Frustum_t &frustum )
|
||||||
{
|
{
|
||||||
// Early out if no cameras
|
// Early out if no cameras
|
||||||
C_FuncFakeWorldPortal *pReflectiveGlass = NULL;
|
C_FuncFakeWorldPortal *pReflectiveGlass = NULL;
|
||||||
@ -130,8 +71,9 @@ C_FuncFakeWorldPortal *NextFakeWorldPortal( C_FuncFakeWorldPortal *pStart, const
|
|||||||
else
|
else
|
||||||
pReflectiveGlass = pStart->m_pNext;
|
pReflectiveGlass = pStart->m_pNext;
|
||||||
|
|
||||||
cplane_t localPlane;
|
cplane_t localPlane, worldPlane;
|
||||||
Vector vecOrigin, vecWorld, vecDelta;
|
Vector vecMins, vecMaxs, vecLocalOrigin, vecAbsOrigin, vecDelta;
|
||||||
|
|
||||||
for ( ; pReflectiveGlass != NULL; pReflectiveGlass = pReflectiveGlass->m_pNext )
|
for ( ; pReflectiveGlass != NULL; pReflectiveGlass = pReflectiveGlass->m_pNext )
|
||||||
{
|
{
|
||||||
if ( pReflectiveGlass->IsDormant() )
|
if ( pReflectiveGlass->IsDormant() )
|
||||||
@ -140,7 +82,10 @@ C_FuncFakeWorldPortal *NextFakeWorldPortal( C_FuncFakeWorldPortal *pStart, const
|
|||||||
if ( pReflectiveGlass->m_iViewHideFlags & (1 << CurrentViewID()) )
|
if ( pReflectiveGlass->m_iViewHideFlags & (1 << CurrentViewID()) )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
Vector vecMins, vecMaxs;
|
// Must have valid plane
|
||||||
|
if ( !pReflectiveGlass->m_hTargetPlane )
|
||||||
|
continue;
|
||||||
|
|
||||||
pReflectiveGlass->GetRenderBoundsWorldspace( vecMins, vecMaxs );
|
pReflectiveGlass->GetRenderBoundsWorldspace( vecMins, vecMaxs );
|
||||||
if ( R_CullBox( vecMins, vecMaxs, frustum ) )
|
if ( R_CullBox( vecMins, vecMaxs, frustum ) )
|
||||||
continue;
|
continue;
|
||||||
@ -151,21 +96,21 @@ C_FuncFakeWorldPortal *NextFakeWorldPortal( C_FuncFakeWorldPortal *pStart, const
|
|||||||
int nCount = modelinfo->GetBrushModelPlaneCount( pModel );
|
int nCount = modelinfo->GetBrushModelPlaneCount( pModel );
|
||||||
for ( int i = 0; i < nCount; ++i )
|
for ( int i = 0; i < nCount; ++i )
|
||||||
{
|
{
|
||||||
modelinfo->GetBrushModelPlane( pModel, i, localPlane, &vecOrigin );
|
modelinfo->GetBrushModelPlane( pModel, i, localPlane, &vecLocalOrigin );
|
||||||
|
|
||||||
MatrixTransformPlane( mat, localPlane, plane ); // Transform to world space
|
MatrixTransformPlane( mat, localPlane, worldPlane ); // Transform to world space
|
||||||
VectorTransform( vecOrigin, mat, vecWorld );
|
|
||||||
|
|
||||||
if ( view.origin.Dot( plane.normal ) <= plane.dist ) // Check for view behind plane
|
if ( view.origin.Dot( worldPlane.normal ) <= worldPlane.dist ) // Check for view behind plane
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
VectorSubtract( vecWorld, view.origin, vecDelta ); // Backface cull
|
VectorTransform( vecLocalOrigin, mat, vecAbsOrigin );
|
||||||
if ( vecDelta.Dot( plane.normal ) >= 0 )
|
VectorSubtract( vecAbsOrigin, view.origin, vecDelta );
|
||||||
|
|
||||||
|
if ( vecDelta.Dot( worldPlane.normal ) >= 0 ) // Backface cull
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
// Must have valid plane
|
flLocalPlaneDist = localPlane.dist;
|
||||||
if ( !pReflectiveGlass->m_hTargetPlane )
|
vecAbsPlaneNormal = worldPlane.normal;
|
||||||
continue;
|
|
||||||
|
|
||||||
return pReflectiveGlass;
|
return pReflectiveGlass;
|
||||||
}
|
}
|
||||||
|
@ -53,10 +53,8 @@ public:
|
|||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Do we have reflective glass in view? If so, what's the reflection plane?
|
// Do we have reflective glass in view? If so, what's the reflection plane?
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
C_FuncFakeWorldPortal *IsFakeWorldPortalInView( const CViewSetup& view, cplane_t &plane );
|
C_FuncFakeWorldPortal *NextFakeWorldPortal( C_FuncFakeWorldPortal *pStart, const CViewSetup& view,
|
||||||
|
Vector &vecAbsPlaneNormal, float &flLocalPlaneDist, const Frustum_t &frustum );
|
||||||
C_FuncFakeWorldPortal *NextFakeWorldPortal( C_FuncFakeWorldPortal *pStart, const CViewSetup& view, cplane_t &plane,
|
|
||||||
const Frustum_t &frustum );
|
|
||||||
|
|
||||||
|
|
||||||
#endif // C_FUNC_FAKE_WORLDPORTAL
|
#endif // C_FUNC_FAKE_WORLDPORTAL
|
||||||
|
282
mp/src/game/client/mapbase/c_vgui_text_display.cpp
Normal file
282
mp/src/game/client/mapbase/c_vgui_text_display.cpp
Normal file
@ -0,0 +1,282 @@
|
|||||||
|
//========= Mapbase - https://github.com/mapbase-source/source-sdk-2013 ============//
|
||||||
|
//
|
||||||
|
// Purpose: Displays easy, flexible VGui text. Mapbase equivalent of point_worldtext.
|
||||||
|
//
|
||||||
|
// $NoKeywords: $
|
||||||
|
//=============================================================================//
|
||||||
|
|
||||||
|
#include "cbase.h"
|
||||||
|
#include "panelmetaclassmgr.h"
|
||||||
|
#include "VGuiMatSurface/IMatSystemSurface.h"
|
||||||
|
#include <vgui/IInput.h>
|
||||||
|
#include <vgui/IPanel.h>
|
||||||
|
#include <vgui/IVGui.h>
|
||||||
|
#include "ienginevgui.h"
|
||||||
|
#include "c_vguiscreen.h"
|
||||||
|
#include "vgui_bitmapbutton.h"
|
||||||
|
#include "vgui_bitmappanel.h"
|
||||||
|
|
||||||
|
// memdbgon must be the last include file in a .cpp file!!!
|
||||||
|
#include "tier0/memdbgon.h"
|
||||||
|
|
||||||
|
using namespace vgui;
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// vgui_text_display
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
class C_VGuiTextDisplay : public C_BaseEntity
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
DECLARE_CLASS( C_VGuiTextDisplay, C_BaseEntity );
|
||||||
|
DECLARE_CLIENTCLASS();
|
||||||
|
|
||||||
|
C_VGuiTextDisplay();
|
||||||
|
~C_VGuiTextDisplay();
|
||||||
|
|
||||||
|
virtual void PostDataUpdate( DataUpdateType_t updateType );
|
||||||
|
|
||||||
|
bool IsEnabled( void ) const { return m_bEnabled; }
|
||||||
|
|
||||||
|
const char *GetDisplayText( void ) const { return m_szDisplayText; }
|
||||||
|
const char *GetFontName( void ) const { return m_szFont; }
|
||||||
|
int GetResolution( void ) const { return m_iResolution; }
|
||||||
|
vgui::Label::Alignment GetContentAlignment() const { return m_iContentAlignment; }
|
||||||
|
|
||||||
|
bool NeedsTextUpdate() { return m_bTextNeedsUpdate; }
|
||||||
|
void UpdatedText() { m_bTextNeedsUpdate = false; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
bool m_bEnabled;
|
||||||
|
char m_szDisplayText[256];
|
||||||
|
vgui::Label::Alignment m_iContentAlignment;
|
||||||
|
char m_szFont[64];
|
||||||
|
int m_iResolution;
|
||||||
|
|
||||||
|
bool m_bTextNeedsUpdate;
|
||||||
|
};
|
||||||
|
|
||||||
|
IMPLEMENT_CLIENTCLASS_DT( C_VGuiTextDisplay, DT_VGuiTextDisplay, CVGuiTextDisplay )
|
||||||
|
RecvPropBool( RECVINFO( m_bEnabled ) ),
|
||||||
|
RecvPropString( RECVINFO( m_szDisplayText ) ),
|
||||||
|
RecvPropInt( RECVINFO( m_iContentAlignment ) ),
|
||||||
|
RecvPropString( RECVINFO( m_szFont ) ),
|
||||||
|
RecvPropInt( RECVINFO( m_iResolution ) ),
|
||||||
|
END_RECV_TABLE()
|
||||||
|
|
||||||
|
C_VGuiTextDisplay::C_VGuiTextDisplay()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
C_VGuiTextDisplay::~C_VGuiTextDisplay()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void C_VGuiTextDisplay::PostDataUpdate( DataUpdateType_t updateType )
|
||||||
|
{
|
||||||
|
BaseClass::PostDataUpdate( updateType );
|
||||||
|
|
||||||
|
// For now, always update
|
||||||
|
m_bTextNeedsUpdate = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
using namespace vgui;
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Control screen
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
class C_TextDisplayPanel : public CVGuiScreenPanel
|
||||||
|
{
|
||||||
|
DECLARE_CLASS( C_TextDisplayPanel, CVGuiScreenPanel );
|
||||||
|
|
||||||
|
public:
|
||||||
|
C_TextDisplayPanel( vgui::Panel *parent, const char *panelName );
|
||||||
|
~C_TextDisplayPanel( void );
|
||||||
|
|
||||||
|
virtual void ApplySchemeSettings( IScheme *pScheme );
|
||||||
|
|
||||||
|
void UpdateText();
|
||||||
|
|
||||||
|
virtual bool Init( KeyValues* pKeyValues, VGuiScreenInitData_t* pInitData );
|
||||||
|
virtual void OnTick( void );
|
||||||
|
virtual void Paint( void );
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
CHandle<C_VGuiScreen> m_hVGUIScreen;
|
||||||
|
CHandle<C_VGuiTextDisplay> m_hScreenEntity;
|
||||||
|
|
||||||
|
// VGUI specifics
|
||||||
|
Label *m_pDisplayTextLabel;
|
||||||
|
};
|
||||||
|
|
||||||
|
DECLARE_VGUI_SCREEN_FACTORY( C_TextDisplayPanel, "text_display_panel" );
|
||||||
|
|
||||||
|
CUtlVector <C_TextDisplayPanel *> g_TextDisplays;
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Constructor:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
C_TextDisplayPanel::C_TextDisplayPanel( vgui::Panel *parent, const char *panelName )
|
||||||
|
: BaseClass( parent, "C_TextDisplayPanel"/*, vgui::scheme()->LoadSchemeFromFileEx( enginevgui->GetPanel( PANEL_CLIENTDLL ), "resource/WorldTextPanel.res", "WorldTextPanel" )*/ )
|
||||||
|
{
|
||||||
|
// Add ourselves to the global list of movie displays
|
||||||
|
g_TextDisplays.AddToTail( this );
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Clean up the movie
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
C_TextDisplayPanel::~C_TextDisplayPanel( void )
|
||||||
|
{
|
||||||
|
// Remove ourselves from the global list of movie displays
|
||||||
|
g_TextDisplays.FindAndRemove( this );
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Setup our scheme
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void C_TextDisplayPanel::ApplySchemeSettings( IScheme *pScheme )
|
||||||
|
{
|
||||||
|
BaseClass::ApplySchemeSettings( pScheme );
|
||||||
|
|
||||||
|
/*
|
||||||
|
m_pDisplayTextLabel->SetFgColor( Color( 255, 255, 255, 255 ) );
|
||||||
|
m_pDisplayTextLabel->SetText( "" );
|
||||||
|
m_pDisplayTextLabel->SetVisible( false );
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void C_TextDisplayPanel::UpdateText()
|
||||||
|
{
|
||||||
|
color32 clr = m_hScreenEntity->GetRenderColor();
|
||||||
|
|
||||||
|
m_pDisplayTextLabel->SetFgColor( Color( clr.r, clr.g, clr.b, clr.a ) );
|
||||||
|
m_pDisplayTextLabel->SetText( m_hScreenEntity->GetDisplayText() );
|
||||||
|
|
||||||
|
//SetSize( m_hScreenEntity->GetTextSize(), m_hScreenEntity->GetTextSize() );
|
||||||
|
//m_pDisplayTextLabel->SetSize( m_hScreenEntity->GetTextSize(), m_hScreenEntity->GetTextSize() );
|
||||||
|
|
||||||
|
Label::Alignment iAlignment = m_hScreenEntity->GetContentAlignment();
|
||||||
|
|
||||||
|
switch (iAlignment)
|
||||||
|
{
|
||||||
|
// Use a special scaling method when using a south alignment
|
||||||
|
case Label::Alignment::a_southwest:
|
||||||
|
case Label::Alignment::a_south:
|
||||||
|
case Label::Alignment::a_southeast:
|
||||||
|
int lW, lT;
|
||||||
|
m_pDisplayTextLabel->GetContentSize( lW, lT );
|
||||||
|
SetSize( m_hScreenEntity->GetResolution(), lT );
|
||||||
|
m_pDisplayTextLabel->SetSize( m_hScreenEntity->GetResolution(), lT );
|
||||||
|
|
||||||
|
float sW, sT;
|
||||||
|
m_hVGUIScreen->GetSize( sW, sT );
|
||||||
|
//Msg( "Screen width: %f, new height: %f\n", sW, sW * (lT / m_hScreenEntity->GetResolution()) );
|
||||||
|
m_hVGUIScreen->SetHeight( sW * ((float)lT / (float)m_hScreenEntity->GetResolution()) );
|
||||||
|
m_hVGUIScreen->SetPixelHeight( lT );
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
SetSize( m_hScreenEntity->GetResolution(), m_hScreenEntity->GetResolution() );
|
||||||
|
m_pDisplayTextLabel->SetSize( m_hScreenEntity->GetResolution(), m_hScreenEntity->GetResolution() );
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_pDisplayTextLabel->SetContentAlignment( iAlignment );
|
||||||
|
|
||||||
|
bool bWrap = true;
|
||||||
|
bool bCenterWrap = false;
|
||||||
|
switch (iAlignment)
|
||||||
|
{
|
||||||
|
// Center wrap if centered
|
||||||
|
case Label::Alignment::a_north:
|
||||||
|
case Label::Alignment::a_center:
|
||||||
|
case Label::Alignment::a_south:
|
||||||
|
bCenterWrap = true;
|
||||||
|
break;
|
||||||
|
|
||||||
|
// HACKHACK: Don't wrap if using an east alignment
|
||||||
|
case Label::Alignment::a_northeast:
|
||||||
|
case Label::Alignment::a_east:
|
||||||
|
case Label::Alignment::a_southeast:
|
||||||
|
bWrap = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
m_pDisplayTextLabel->SetWrap( bWrap );
|
||||||
|
m_pDisplayTextLabel->SetCenterWrap( bCenterWrap );
|
||||||
|
|
||||||
|
//Msg( "Resolution is %i\n", m_hScreenEntity->GetResolution() );
|
||||||
|
|
||||||
|
const char *pszFontName = m_hScreenEntity->GetFontName();
|
||||||
|
if (pszFontName && pszFontName[0] != '\0')
|
||||||
|
{
|
||||||
|
HFont font = scheme()->GetIScheme( GetScheme() )->GetFont( pszFontName );
|
||||||
|
m_pDisplayTextLabel->SetFont( font );
|
||||||
|
}
|
||||||
|
|
||||||
|
m_pDisplayTextLabel->SetVisible( true );
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Initialization
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
bool C_TextDisplayPanel::Init( KeyValues* pKeyValues, VGuiScreenInitData_t* pInitData )
|
||||||
|
{
|
||||||
|
if ( !BaseClass::Init( pKeyValues, pInitData ) )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// Make sure we get ticked...
|
||||||
|
vgui::ivgui()->AddTickSignal( GetVPanel() );
|
||||||
|
|
||||||
|
m_pDisplayTextLabel = dynamic_cast<vgui::Label*>(FindChildByName( "TextDisplay" ));
|
||||||
|
|
||||||
|
// Save this for simplicity later on
|
||||||
|
m_hVGUIScreen = dynamic_cast<C_VGuiScreen *>( GetEntity() );
|
||||||
|
if ( m_hVGUIScreen != NULL )
|
||||||
|
{
|
||||||
|
// Also get the associated entity
|
||||||
|
m_hScreenEntity = dynamic_cast<C_VGuiTextDisplay *>(m_hVGUIScreen->GetOwnerEntity());
|
||||||
|
UpdateText();
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Update the display string
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void C_TextDisplayPanel::OnTick()
|
||||||
|
{
|
||||||
|
if (m_hScreenEntity->NeedsTextUpdate())
|
||||||
|
{
|
||||||
|
UpdateText();
|
||||||
|
m_hScreenEntity->UpdatedText();
|
||||||
|
}
|
||||||
|
|
||||||
|
BaseClass::OnTick();
|
||||||
|
}
|
||||||
|
|
||||||
|
ConVar r_vguitext_bg( "r_vguitext_bg", "0" );
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Update and draw the frame
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void C_TextDisplayPanel::Paint( void )
|
||||||
|
{
|
||||||
|
// Black out the background (we could omit drawing under the video surface, but this is straight-forward)
|
||||||
|
if ( r_vguitext_bg.GetBool() )
|
||||||
|
{
|
||||||
|
surface()->DrawSetColor( 0, 0, 0, 255 );
|
||||||
|
surface()->DrawFilledRect( 0, 0, GetWide(), GetTall() );
|
||||||
|
|
||||||
|
//surface()->DrawSetColor( 64, 64, 64, 255 );
|
||||||
|
//surface()->DrawFilledRect( 0, 0, m_pDisplayTextLabel->GetWide(), m_pDisplayTextLabel->GetTall() );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Parent's turn
|
||||||
|
BaseClass::Paint();
|
||||||
|
}
|
280
mp/src/game/client/mapbase/mapbase_autocubemap.cpp
Normal file
280
mp/src/game/client/mapbase/mapbase_autocubemap.cpp
Normal file
@ -0,0 +1,280 @@
|
|||||||
|
//========= Mapbase - https://github.com/mapbase-source/source-sdk-2013 ============//
|
||||||
|
//
|
||||||
|
// Purpose: A utility which automatically generates HDR and LDR cubemaps.
|
||||||
|
// This has the following purposes:
|
||||||
|
//
|
||||||
|
// 1. Allow both HDR and LDR cubemaps to be generated automatically after a map is compiled
|
||||||
|
// 2. Have a way to batch build cubemaps for several levels at once
|
||||||
|
//
|
||||||
|
// Author: Blixibon
|
||||||
|
//
|
||||||
|
// $NoKeywords: $
|
||||||
|
//=============================================================================//
|
||||||
|
|
||||||
|
#include "cbase.h"
|
||||||
|
|
||||||
|
#include "tier0/icommandline.h"
|
||||||
|
#include "igamesystem.h"
|
||||||
|
#include "filesystem.h"
|
||||||
|
#include "utlbuffer.h"
|
||||||
|
|
||||||
|
// memdbgon must be the last include file in a .cpp file!!!
|
||||||
|
#include "tier0/memdbgon.h"
|
||||||
|
|
||||||
|
extern const char *g_MapName;
|
||||||
|
|
||||||
|
ConVar autocubemap_hdr_do_both( "autocubemap_hdr_do_both", "1" );
|
||||||
|
ConVar autocubemap_hdr_value( "autocubemap_hdr_value", "2" );
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
class CAutoCubemapSystem : public CAutoGameSystem
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
CAutoCubemapSystem() : CAutoGameSystem( "CAutoCubemapSystem" )
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual bool Init()
|
||||||
|
{
|
||||||
|
const char *pszFile = NULL;
|
||||||
|
if (CommandLine()->CheckParm( "-autocubemap", &pszFile ))
|
||||||
|
{
|
||||||
|
if (!pszFile || pszFile[0] == '\0')
|
||||||
|
{
|
||||||
|
// Assume that we just want to autocubemap the first map we load
|
||||||
|
// (no code here for now)
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
LoadFile( pszFile );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Begin autocubemap with the first level we load
|
||||||
|
m_bAutoCubemapOnFirstLevel = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual void LevelInitPostEntity()
|
||||||
|
{
|
||||||
|
if (m_bAutoCubemapActive)
|
||||||
|
{
|
||||||
|
if (m_bAutoCubemapBuildingCubemaps)
|
||||||
|
{
|
||||||
|
// Check if we need to do the other HDR level
|
||||||
|
if (autocubemap_hdr_do_both.GetBool() && !m_bAutoCubemapDoingBoth)
|
||||||
|
{
|
||||||
|
m_bAutoCubemapBuildingCubemaps = false;
|
||||||
|
m_bAutoCubemapDoingBoth = true;
|
||||||
|
|
||||||
|
// Change the HDR level and restart the map
|
||||||
|
//ConVarRef mat_hdr_level( "mat_hdr_level" );
|
||||||
|
engine->ClientCmd_Unrestricted( VarArgs( "toggle mat_hdr_level 0 %i; restart", autocubemap_hdr_value.GetInt() ) );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Go to the next map
|
||||||
|
m_bAutoCubemapBuildingCubemaps = false;
|
||||||
|
m_bAutoCubemapDoingBoth = false;
|
||||||
|
|
||||||
|
m_AutoCubemapMapsIndex++;
|
||||||
|
if (m_AutoCubemapMapsIndex < m_AutoCubemapMaps.Count())
|
||||||
|
{
|
||||||
|
engine->ClientCmd_Unrestricted( VarArgs( "map %s", m_AutoCubemapMaps[m_AutoCubemapMapsIndex] ) );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// CUBEMAPPER FINISHED
|
||||||
|
m_AutoCubemapMaps.PurgeAndDeleteElements();
|
||||||
|
m_AutoCubemapMapsIndex = 0;
|
||||||
|
m_bAutoCubemapActive = false;
|
||||||
|
|
||||||
|
Msg( "CUBEMAPPER FINISHED\n" );
|
||||||
|
|
||||||
|
if (autocubemap_hdr_do_both.GetBool())
|
||||||
|
{
|
||||||
|
engine->ClientCmd_Unrestricted( VarArgs( "mat_hdr_level %i", m_iAutoCubemapUserHDRLevel ) );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Build cubemaps for this map
|
||||||
|
m_bAutoCubemapBuildingCubemaps = true;
|
||||||
|
engine->ClientCmd_Unrestricted( "exec buildcubemaps_prep; buildcubemaps" );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (m_bAutoCubemapOnFirstLevel)
|
||||||
|
{
|
||||||
|
// Start autocubemap now
|
||||||
|
StartAutoCubemap();
|
||||||
|
m_bAutoCubemapOnFirstLevel = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
void StartAutoCubemap()
|
||||||
|
{
|
||||||
|
if (m_AutoCubemapMaps.Count() <= 0)
|
||||||
|
{
|
||||||
|
//Msg("No maps to cubemap with!\n");
|
||||||
|
//return;
|
||||||
|
|
||||||
|
// Just do this map
|
||||||
|
m_AutoCubemapMaps.AddToTail( strdup( g_MapName ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
if (autocubemap_hdr_do_both.GetBool())
|
||||||
|
{
|
||||||
|
// Save the user's HDR level
|
||||||
|
ConVarRef mat_hdr_level( "mat_hdr_level" );
|
||||||
|
m_iAutoCubemapUserHDRLevel = mat_hdr_level.GetInt();
|
||||||
|
}
|
||||||
|
|
||||||
|
m_bAutoCubemapActive = true;
|
||||||
|
m_AutoCubemapMapsIndex = 0;
|
||||||
|
|
||||||
|
if (FStrEq( m_AutoCubemapMaps[m_AutoCubemapMapsIndex], g_MapName ))
|
||||||
|
{
|
||||||
|
// Build cubemaps right here, right now
|
||||||
|
m_bAutoCubemapBuildingCubemaps = true;
|
||||||
|
engine->ClientCmd_Unrestricted( "exec buildcubemaps_prep; buildcubemaps" );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Go to that map
|
||||||
|
engine->ClientCmd_Unrestricted( VarArgs( "map %s", m_AutoCubemapMaps[m_AutoCubemapMapsIndex] ) );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void LoadFile( const char *pszFile )
|
||||||
|
{
|
||||||
|
KeyValues *pKV = new KeyValues( "AutoCubemap" );
|
||||||
|
|
||||||
|
if ( pKV->LoadFromFile( filesystem, pszFile, NULL ) )
|
||||||
|
{
|
||||||
|
KeyValues *pSubKey = pKV->GetFirstSubKey();
|
||||||
|
|
||||||
|
while ( pSubKey )
|
||||||
|
{
|
||||||
|
m_AutoCubemapMaps.AddToTail( strdup(pSubKey->GetName()) );
|
||||||
|
pSubKey = pSubKey->GetNextKey();
|
||||||
|
}
|
||||||
|
|
||||||
|
Msg( "Initted autocubemap\n" );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Warning( "Unable to load autocubemap file \"%s\"\n", pszFile );
|
||||||
|
}
|
||||||
|
|
||||||
|
pKV->deleteThis();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Clear()
|
||||||
|
{
|
||||||
|
m_bAutoCubemapActive = false;
|
||||||
|
m_bAutoCubemapBuildingCubemaps = false;
|
||||||
|
m_bAutoCubemapDoingBoth = false;
|
||||||
|
|
||||||
|
m_AutoCubemapMaps.PurgeAndDeleteElements();
|
||||||
|
m_AutoCubemapMapsIndex = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void PrintState()
|
||||||
|
{
|
||||||
|
char szCmd[1024] = { 0 };
|
||||||
|
|
||||||
|
if (m_AutoCubemapMaps.Count() > 0)
|
||||||
|
{
|
||||||
|
Q_strncpy( szCmd, "=== CUBEMAPPER MAP LIST ===\n", sizeof( szCmd ) );
|
||||||
|
|
||||||
|
FOR_EACH_VEC( m_AutoCubemapMaps, i )
|
||||||
|
{
|
||||||
|
Q_snprintf( szCmd, sizeof( szCmd ), "%s%s\n", szCmd, m_AutoCubemapMaps[i] );
|
||||||
|
}
|
||||||
|
|
||||||
|
Q_strncat( szCmd, "========================", sizeof( szCmd ), COPY_ALL_CHARACTERS );
|
||||||
|
|
||||||
|
Q_snprintf( szCmd, sizeof( szCmd ), "%s\nNumber of maps: %i (starting at %i)\n", szCmd, m_AutoCubemapMaps.Count(), m_AutoCubemapMapsIndex );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Q_strncat( szCmd, "========================\n", sizeof( szCmd ), COPY_ALL_CHARACTERS );
|
||||||
|
Q_strncat( szCmd, "There are no maps selected. Use 'autocubemap_init' to load a map list.\nIf 'autocubemap_start' is executed while no maps are selected, only the current map will have cubemaps generated.\n", sizeof( szCmd ), COPY_ALL_CHARACTERS );
|
||||||
|
Q_strncat( szCmd, "========================\n", sizeof( szCmd ), COPY_ALL_CHARACTERS );
|
||||||
|
}
|
||||||
|
|
||||||
|
Msg( "%s", szCmd );
|
||||||
|
}
|
||||||
|
|
||||||
|
//-------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
bool m_bAutoCubemapActive = false;
|
||||||
|
bool m_bAutoCubemapBuildingCubemaps = false;
|
||||||
|
bool m_bAutoCubemapDoingBoth = false;
|
||||||
|
int m_iAutoCubemapUserHDRLevel; // For setting the user back to the right HDR level when we're finished
|
||||||
|
|
||||||
|
// Start autocubemap with the first level we load (used for launch parameter)
|
||||||
|
bool m_bAutoCubemapOnFirstLevel = false;
|
||||||
|
|
||||||
|
CUtlVector<const char*> m_AutoCubemapMaps;
|
||||||
|
int m_AutoCubemapMapsIndex;
|
||||||
|
};
|
||||||
|
|
||||||
|
CAutoCubemapSystem g_AutoCubemapSystem;
|
||||||
|
|
||||||
|
CON_COMMAND( autocubemap_init, "Inits autocubemap" )
|
||||||
|
{
|
||||||
|
if (gpGlobals->maxClients > 1)
|
||||||
|
{
|
||||||
|
Msg( "Can't run autocubemap in multiplayer\n" );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (args.ArgC() <= 1)
|
||||||
|
{
|
||||||
|
Msg("Format: autocubemap_init <file name in the 'cfg' folder>\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_AutoCubemapSystem.LoadFile( args.Arg( 1 ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
CON_COMMAND( autocubemap_print, "Prints current autocubemap information" )
|
||||||
|
{
|
||||||
|
if (gpGlobals->maxClients > 1)
|
||||||
|
{
|
||||||
|
Msg("Can't run autocubemap in multiplayer\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_AutoCubemapSystem.PrintState();
|
||||||
|
}
|
||||||
|
|
||||||
|
CON_COMMAND( autocubemap_clear, "Clears autocubemap stuff" )
|
||||||
|
{
|
||||||
|
if (gpGlobals->maxClients > 1)
|
||||||
|
{
|
||||||
|
Msg("Can't run autocubemap in multiplayer\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_AutoCubemapSystem.Clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
CON_COMMAND( autocubemap_start, "Begins the autocubemap (it's recommended to check 'autocubemap_print' before running this command)" )
|
||||||
|
{
|
||||||
|
if (gpGlobals->maxClients > 1)
|
||||||
|
{
|
||||||
|
Msg("Can't run autocubemap in multiplayer\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_AutoCubemapSystem.StartAutoCubemap();
|
||||||
|
}
|
3891
mp/src/game/client/mapbase/vscript_vgui.cpp
Normal file
3891
mp/src/game/client/mapbase/vscript_vgui.cpp
Normal file
File diff suppressed because it is too large
Load Diff
16
mp/src/game/client/mapbase/vscript_vgui.h
Normal file
16
mp/src/game/client/mapbase/vscript_vgui.h
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
//========= Mapbase - https://github.com/mapbase-source/source-sdk-2013 ============//
|
||||||
|
//
|
||||||
|
// Purpose:
|
||||||
|
//
|
||||||
|
// $NoKeywords: $
|
||||||
|
//=============================================================================//
|
||||||
|
|
||||||
|
#ifndef VSCRIPT_VGUI_H
|
||||||
|
#define VSCRIPT_VGUI_H
|
||||||
|
#ifdef _WIN32
|
||||||
|
#pragma once
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void RegisterScriptVGUI();
|
||||||
|
|
||||||
|
#endif
|
394
mp/src/game/client/mapbase/vscript_vgui.nut
Normal file
394
mp/src/game/client/mapbase/vscript_vgui.nut
Normal file
@ -0,0 +1,394 @@
|
|||||||
|
static const char* g_Script_vgui_init = R"script(
|
||||||
|
local DoCreateFont = ISurface.CreateFont;
|
||||||
|
ISurface.CreateFont <- function( name, props )
|
||||||
|
{
|
||||||
|
if ( !("name" in props) || typeof props.name != "string" )
|
||||||
|
throw "invalid parameter 'name'";
|
||||||
|
|
||||||
|
if ( !("tall" in props) || typeof props.tall != "integer" || !props.tall )
|
||||||
|
throw "invalid parameter 'tall'";
|
||||||
|
|
||||||
|
if ( !("weight" in props) || typeof props.weight != "integer" )
|
||||||
|
throw "invalid parameter 'weight'";
|
||||||
|
|
||||||
|
local yres_min = 0, yres_max = 0;
|
||||||
|
|
||||||
|
if ( "yres" in props && typeof props.yres == "string" )
|
||||||
|
{
|
||||||
|
local ss = ::split( props.yres, " " );
|
||||||
|
try
|
||||||
|
{
|
||||||
|
yres_min = ss[0].tointeger();
|
||||||
|
yres_max = ss[1].tointeger();
|
||||||
|
}
|
||||||
|
catch(x)
|
||||||
|
{
|
||||||
|
throw "invalid parameter 'yres'";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ( (!("proportional" in props) || typeof props.proportional != "bool") ) && !yres_min )
|
||||||
|
{
|
||||||
|
throw "parameter 'proportional' or 'yres' not found";
|
||||||
|
}
|
||||||
|
else if ( "proportional" in props && props.proportional && yres_min )
|
||||||
|
{
|
||||||
|
throw "resolution definition on a proportional font"
|
||||||
|
}
|
||||||
|
|
||||||
|
local blur = 0, scanlines = 0, proportional = false, flags = 0;
|
||||||
|
|
||||||
|
if ( "blur" in props && typeof props.blur == "integer" )
|
||||||
|
blur = props.blur;
|
||||||
|
|
||||||
|
if ( "scanlines" in props && typeof props.scanlines == "integer" )
|
||||||
|
scanlines = props.scanlines;
|
||||||
|
|
||||||
|
if ( "proportional" in props && typeof props.proportional == "bool" )
|
||||||
|
proportional = props.proportional;
|
||||||
|
|
||||||
|
if ( "italic" in props && props.italic == true )
|
||||||
|
flags = flags | 0x001;
|
||||||
|
|
||||||
|
if ( "underline" in props && props.underline == true )
|
||||||
|
flags = flags | 0x002;
|
||||||
|
|
||||||
|
if ( "strikeout" in props && props.strikeout == true )
|
||||||
|
flags = flags | 0x004;
|
||||||
|
|
||||||
|
if ( "symbol" in props && props.symbol == true )
|
||||||
|
flags = flags | 0x008;
|
||||||
|
|
||||||
|
if ( "antialias" in props && props.antialias == true )
|
||||||
|
flags = flags | 0x010;
|
||||||
|
|
||||||
|
if ( "gaussianblur" in props && props.gaussianblur == true )
|
||||||
|
flags = flags | 0x020;
|
||||||
|
|
||||||
|
if ( "rotary" in props && props.rotary == true )
|
||||||
|
flags = flags | 0x040;
|
||||||
|
|
||||||
|
if ( "dropshadow" in props && props.dropshadow == true )
|
||||||
|
flags = flags | 0x080;
|
||||||
|
|
||||||
|
if ( "additive" in props && props.additive == true )
|
||||||
|
flags = flags | 0x100;
|
||||||
|
|
||||||
|
if ( "outline" in props && props.outline == true )
|
||||||
|
flags = flags | 0x200;
|
||||||
|
|
||||||
|
if ( "custom" in props && props.custom == true )
|
||||||
|
flags = flags | 0x400;
|
||||||
|
|
||||||
|
if ( "bitmap" in props && props.bitmap == true )
|
||||||
|
flags = flags | 0x800;
|
||||||
|
|
||||||
|
return DoCreateFont( name, props.name, props.tall, props.weight, blur, scanlines, flags, yres_min, yres_max, proportional );
|
||||||
|
}
|
||||||
|
|
||||||
|
local _Schemes = {}
|
||||||
|
local _FontTall = {}
|
||||||
|
local DoGetFont = ISurface.DoGetFont <- ISurface.GetFont;
|
||||||
|
local DoGetFontTall = ISurface.GetFontTall;
|
||||||
|
|
||||||
|
ISurface.GetFont <- function( name, proportional, sch = "" )
|
||||||
|
{
|
||||||
|
if ( sch in _Schemes )
|
||||||
|
{
|
||||||
|
local fonts = _Schemes[sch][proportional.tointeger()];
|
||||||
|
if ( name in fonts )
|
||||||
|
return fonts[name];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if ( typeof sch != "string" )
|
||||||
|
throw "invalid parameter 'scheme'";
|
||||||
|
_Schemes[sch] <- [{}, {}];
|
||||||
|
}
|
||||||
|
|
||||||
|
local id = DoGetFont( name, proportional, sch );
|
||||||
|
if ( id > 0 )
|
||||||
|
_Schemes[sch][proportional.tointeger()][name] <- id;
|
||||||
|
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
ISurface.GetFontTall <- function( id )
|
||||||
|
{
|
||||||
|
if ( id in _FontTall )
|
||||||
|
return _FontTall[id];
|
||||||
|
return _FontTall[id] <- DoGetFontTall( id );
|
||||||
|
}
|
||||||
|
|
||||||
|
local _Textures = {}
|
||||||
|
local DoGetTextureID = ISurface.GetTextureID;
|
||||||
|
local DoValidateTexture = ISurface.ValidateTexture;
|
||||||
|
local DoSetTextureFile = ISurface.SetTextureFile;
|
||||||
|
|
||||||
|
ISurface.ValidateTexture <- function( filename, hardwareFilter, forceReload = false, procedural = false )
|
||||||
|
{
|
||||||
|
return DoValidateTexture( filename, hardwareFilter, forceReload, procedural );
|
||||||
|
}
|
||||||
|
|
||||||
|
ISurface.SetTextureFile <- function( id, filename, hardwareFilter )
|
||||||
|
{
|
||||||
|
if ( filename in _Textures )
|
||||||
|
delete _Textures[filename];
|
||||||
|
|
||||||
|
return DoSetTextureFile( id, filename, hardwareFilter );
|
||||||
|
}
|
||||||
|
|
||||||
|
ISurface.GetTextureID <- function( name )
|
||||||
|
{
|
||||||
|
if ( name in _Textures )
|
||||||
|
return _Textures[name];
|
||||||
|
|
||||||
|
local id = DoGetTextureID( name );
|
||||||
|
if ( id > 0 )
|
||||||
|
_Textures[name] <- id;
|
||||||
|
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Forward compatibility
|
||||||
|
IVGui.GetRootPanel <- function() { return 1000 }
|
||||||
|
//IVGui.GetGameUIRootPanel <- function() { return 1001 }
|
||||||
|
IVGui.GetClientDLLRootPanel <- function() { return 1002 }
|
||||||
|
//IVGui.GetHudViewportPanel <- function() { return 1010 }
|
||||||
|
|
||||||
|
local CreatePanel = IVGui.CreatePanel;
|
||||||
|
IVGui.CreatePanel <- function( type, parent, name )
|
||||||
|
{
|
||||||
|
if ( !parent )
|
||||||
|
throw "invalid parent";
|
||||||
|
|
||||||
|
local root = 0;
|
||||||
|
|
||||||
|
if ( typeof parent == "integer" )
|
||||||
|
{
|
||||||
|
switch ( parent )
|
||||||
|
{
|
||||||
|
case 1000:
|
||||||
|
root = 0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 1002:
|
||||||
|
root = 2;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
throw "invalid parent";
|
||||||
|
}
|
||||||
|
parent = null;
|
||||||
|
}
|
||||||
|
return CreatePanel( type, parent, name, root );
|
||||||
|
}
|
||||||
|
|
||||||
|
ISurface.__OnScreenSizeChanged <- function()
|
||||||
|
{
|
||||||
|
_FontTall.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
// MAX_JOYSTICKS = 1 // ( 1 << MAX_SPLITSCREEN_CLIENT_BITS )
|
||||||
|
// MAX_JOYSTICK_AXES = 6 // X,Y,Z,R,U,V
|
||||||
|
// JOYSTICK_MAX_BUTTON_COUNT = 32
|
||||||
|
// JOYSTICK_POV_BUTTON_COUNT = 4
|
||||||
|
// JOYSTICK_AXIS_BUTTON_COUNT = MAX_JOYSTICK_AXES * 2
|
||||||
|
|
||||||
|
enum ButtonCode
|
||||||
|
{
|
||||||
|
KEY_FIRST = 0
|
||||||
|
KEY_0 = 1
|
||||||
|
KEY_1 = 2
|
||||||
|
KEY_2 = 3
|
||||||
|
KEY_3 = 4
|
||||||
|
KEY_4 = 5
|
||||||
|
KEY_5 = 6
|
||||||
|
KEY_6 = 7
|
||||||
|
KEY_7 = 8
|
||||||
|
KEY_8 = 9
|
||||||
|
KEY_9 = 10
|
||||||
|
KEY_A = 11
|
||||||
|
KEY_B = 12
|
||||||
|
KEY_C = 13
|
||||||
|
KEY_D = 14
|
||||||
|
KEY_E = 15
|
||||||
|
KEY_F = 16
|
||||||
|
KEY_G = 17
|
||||||
|
KEY_H = 18
|
||||||
|
KEY_I = 19
|
||||||
|
KEY_J = 20
|
||||||
|
KEY_K = 21
|
||||||
|
KEY_L = 22
|
||||||
|
KEY_M = 23
|
||||||
|
KEY_N = 24
|
||||||
|
KEY_O = 25
|
||||||
|
KEY_P = 26
|
||||||
|
KEY_Q = 27
|
||||||
|
KEY_R = 28
|
||||||
|
KEY_S = 29
|
||||||
|
KEY_T = 30
|
||||||
|
KEY_U = 31
|
||||||
|
KEY_V = 32
|
||||||
|
KEY_W = 33
|
||||||
|
KEY_X = 34
|
||||||
|
KEY_Y = 35
|
||||||
|
KEY_Z = 36
|
||||||
|
KEY_PAD_0 = 37
|
||||||
|
KEY_PAD_1 = 38
|
||||||
|
KEY_PAD_2 = 39
|
||||||
|
KEY_PAD_3 = 40
|
||||||
|
KEY_PAD_4 = 41
|
||||||
|
KEY_PAD_5 = 42
|
||||||
|
KEY_PAD_6 = 43
|
||||||
|
KEY_PAD_7 = 44
|
||||||
|
KEY_PAD_8 = 45
|
||||||
|
KEY_PAD_9 = 46
|
||||||
|
KEY_PAD_DIVIDE = 47
|
||||||
|
KEY_PAD_MULTIPLY = 48
|
||||||
|
KEY_PAD_MINUS = 49
|
||||||
|
KEY_PAD_PLUS = 50
|
||||||
|
KEY_PAD_ENTER = 51
|
||||||
|
KEY_PAD_DECIMAL = 52
|
||||||
|
KEY_LBRACKET = 53
|
||||||
|
KEY_RBRACKET = 54
|
||||||
|
KEY_SEMICOLON = 55
|
||||||
|
KEY_APOSTROPHE = 56
|
||||||
|
KEY_BACKQUOTE = 57
|
||||||
|
KEY_COMMA = 58
|
||||||
|
KEY_PERIOD = 59
|
||||||
|
KEY_SLASH = 60
|
||||||
|
KEY_BACKSLASH = 61
|
||||||
|
KEY_MINUS = 62
|
||||||
|
KEY_EQUAL = 63
|
||||||
|
KEY_ENTER = 64
|
||||||
|
KEY_SPACE = 65
|
||||||
|
KEY_BACKSPACE = 66
|
||||||
|
KEY_TAB = 67
|
||||||
|
KEY_CAPSLOCK = 68
|
||||||
|
KEY_NUMLOCK = 69
|
||||||
|
KEY_ESCAPE = 70
|
||||||
|
KEY_SCROLLLOCK = 71
|
||||||
|
KEY_INSERT = 72
|
||||||
|
KEY_DELETE = 73
|
||||||
|
KEY_HOME = 74
|
||||||
|
KEY_END = 75
|
||||||
|
KEY_PAGEUP = 76
|
||||||
|
KEY_PAGEDOWN = 77
|
||||||
|
KEY_BREAK = 78
|
||||||
|
KEY_LSHIFT = 79
|
||||||
|
KEY_RSHIFT = 80
|
||||||
|
KEY_LALT = 81
|
||||||
|
KEY_RALT = 82
|
||||||
|
KEY_LCONTROL = 83
|
||||||
|
KEY_RCONTROL = 84
|
||||||
|
KEY_LWIN = 85
|
||||||
|
KEY_RWIN = 86
|
||||||
|
KEY_APP = 87
|
||||||
|
KEY_UP = 88
|
||||||
|
KEY_LEFT = 89
|
||||||
|
KEY_DOWN = 90
|
||||||
|
KEY_RIGHT = 91
|
||||||
|
KEY_F1 = 92
|
||||||
|
KEY_F2 = 93
|
||||||
|
KEY_F3 = 94
|
||||||
|
KEY_F4 = 95
|
||||||
|
KEY_F5 = 96
|
||||||
|
KEY_F6 = 97
|
||||||
|
KEY_F7 = 98
|
||||||
|
KEY_F8 = 99
|
||||||
|
KEY_F9 = 100
|
||||||
|
KEY_F10 = 101
|
||||||
|
KEY_F11 = 102
|
||||||
|
KEY_F12 = 103
|
||||||
|
KEY_CAPSLOCKTOGGLE = 104
|
||||||
|
KEY_NUMLOCKTOGGLE = 105
|
||||||
|
KEY_SCROLLLOCKTOGGLE = 106
|
||||||
|
KEY_LAST = 106
|
||||||
|
|
||||||
|
MOUSE_FIRST = 107
|
||||||
|
MOUSE_LEFT = 107
|
||||||
|
MOUSE_RIGHT = 108
|
||||||
|
MOUSE_MIDDLE = 109
|
||||||
|
MOUSE_4 = 110
|
||||||
|
MOUSE_5 = 111
|
||||||
|
MOUSE_WHEEL_UP = 112
|
||||||
|
MOUSE_WHEEL_DOWN = 113
|
||||||
|
MOUSE_LAST = 113
|
||||||
|
|
||||||
|
JOYSTICK_FIRST = 114
|
||||||
|
JOYSTICK_FIRST_BUTTON = 114
|
||||||
|
JOYSTICK_LAST_BUTTON = 145
|
||||||
|
JOYSTICK_FIRST_POV_BUTTON = 146
|
||||||
|
JOYSTICK_LAST_POV_BUTTON = 149
|
||||||
|
JOYSTICK_FIRST_AXIS_BUTTON = 150
|
||||||
|
JOYSTICK_LAST_AXIS_BUTTON = 161
|
||||||
|
JOYSTICK_LAST = 161
|
||||||
|
}
|
||||||
|
|
||||||
|
enum AnalogCode
|
||||||
|
{
|
||||||
|
MOUSE_X = 0
|
||||||
|
MOUSE_Y = 1
|
||||||
|
MOUSE_XY = 2
|
||||||
|
MOUSE_WHEEL = 3
|
||||||
|
|
||||||
|
JOYSTICK_FIRST_AXIS = 4
|
||||||
|
JOYSTICK_LAST_AXIS = 9
|
||||||
|
}
|
||||||
|
|
||||||
|
enum CursorCode
|
||||||
|
{
|
||||||
|
dc_none = 1
|
||||||
|
dc_arrow = 2
|
||||||
|
dc_ibeam = 3
|
||||||
|
dc_hourglass = 4
|
||||||
|
dc_waitarrow = 5
|
||||||
|
dc_crosshair = 6
|
||||||
|
dc_up = 7
|
||||||
|
dc_sizenwse = 8
|
||||||
|
dc_sizenesw = 9
|
||||||
|
dc_sizewe = 10
|
||||||
|
dc_sizens = 11
|
||||||
|
dc_sizeall = 12
|
||||||
|
dc_no = 13
|
||||||
|
dc_hand = 14
|
||||||
|
dc_blank = 15
|
||||||
|
}
|
||||||
|
|
||||||
|
enum Alignment
|
||||||
|
{
|
||||||
|
northwest = 0
|
||||||
|
north = 1
|
||||||
|
northeast = 2
|
||||||
|
west = 3
|
||||||
|
center = 4
|
||||||
|
east = 5
|
||||||
|
southwest = 6
|
||||||
|
south = 7
|
||||||
|
southeast = 8
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( __Documentation.RegisterHelp != dummy )
|
||||||
|
{
|
||||||
|
local RegEnum = function( e )
|
||||||
|
{
|
||||||
|
local K = getconsttable()[e];
|
||||||
|
__Documentation.RegisterEnumHelp( e, K.len(), "" );
|
||||||
|
e += ".";
|
||||||
|
foreach ( s, v in K )
|
||||||
|
{
|
||||||
|
__Documentation.RegisterConstHelp( e+s, v, "" );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
RegEnum( "ButtonCode" );
|
||||||
|
RegEnum( "AnalogCode" );
|
||||||
|
RegEnum( "CursorCode" );
|
||||||
|
RegEnum( "Alignment" );
|
||||||
|
|
||||||
|
__Documentation.RegisterHelp( "ISurface::CreateFont", "void ISurface::CreateFont(string, handle)", "" );
|
||||||
|
__Documentation.RegisterHelp( "IVGui::CreatePanel", "handle IVGui::CreatePanel(string, handle, string)", "" );
|
||||||
|
__Documentation.RegisterHelp( "IVGui::GetRootPanel", "handle IVGui::GetRootPanel()", "" );
|
||||||
|
__Documentation.RegisterHelp( "IVGui::GetClientDLLRootPanel", "handle IVGui::GetClientDLLRootPanel()", "" );
|
||||||
|
}
|
||||||
|
)script";
|
@ -234,14 +234,6 @@ CPanelMetaClassMgrImp::CPanelMetaClassMgrImp() : m_PanelTypeDict( true, 0, 32 )
|
|||||||
|
|
||||||
CPanelMetaClassMgrImp::~CPanelMetaClassMgrImp()
|
CPanelMetaClassMgrImp::~CPanelMetaClassMgrImp()
|
||||||
{
|
{
|
||||||
#ifdef MAPBASE // VDC Memory Leak Fixes
|
|
||||||
while (m_MetaClassKeyValues.Count()>0)
|
|
||||||
{
|
|
||||||
if (m_MetaClassKeyValues[0])
|
|
||||||
m_MetaClassKeyValues[0]->deleteThis();
|
|
||||||
m_MetaClassKeyValues.RemoveAt(0);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -119,7 +119,7 @@ entities. Each one is useful under different conditions.
|
|||||||
#include "tier0/fasttimer.h"
|
#include "tier0/fasttimer.h"
|
||||||
#include "utllinkedlist.h"
|
#include "utllinkedlist.h"
|
||||||
#include "utldict.h"
|
#include "utldict.h"
|
||||||
#ifdef WIN32
|
#if defined(WIN32) && _MSC_VER < 1900
|
||||||
#include <typeinfo.h>
|
#include <typeinfo.h>
|
||||||
#else
|
#else
|
||||||
#include <typeinfo>
|
#include <typeinfo>
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
//=============================================================================//
|
//=============================================================================//
|
||||||
#include "cbase.h"
|
#include "cbase.h"
|
||||||
#include "c_baseentity.h"
|
#include "c_baseentity.h"
|
||||||
#ifdef WIN32
|
#if defined(WIN32) && _MSC_VER < 1900
|
||||||
#include <typeinfo.h>
|
#include <typeinfo.h>
|
||||||
#endif
|
#endif
|
||||||
#include "tier0/vprof.h"
|
#include "tier0/vprof.h"
|
||||||
|
@ -704,9 +704,157 @@ void C_PhysPropClientside::ParseAllEntities(const char *pMapData)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
CBaseAnimating *BreakModelCreate_Ragdoll( CBaseEntity *pOwnerEnt, breakmodel_t *pModel, const Vector &position, const QAngle &angles, const Vector &velocity, const AngularImpulse &angVelocity )
|
||||||
|
{
|
||||||
|
C_BaseAnimating *pOwner = dynamic_cast<C_BaseAnimating *>( pOwnerEnt );
|
||||||
|
if ( !pOwner )
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
C_ClientRagdoll *pRagdoll = new C_ClientRagdoll( false );
|
||||||
|
if ( pRagdoll == NULL )
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
const char *pModelName = pModel->modelName;
|
||||||
|
if ( pRagdoll->InitializeAsClientEntity( pModelName, RENDER_GROUP_OPAQUE_ENTITY ) == false )
|
||||||
|
{
|
||||||
|
pRagdoll->Release();
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
pRagdoll->SetAbsOrigin( position );
|
||||||
|
pRagdoll->SetAbsAngles( angles );
|
||||||
|
|
||||||
|
matrix3x4_t boneDelta0[MAXSTUDIOBONES];
|
||||||
|
matrix3x4_t boneDelta1[MAXSTUDIOBONES];
|
||||||
|
matrix3x4_t currentBones[MAXSTUDIOBONES];
|
||||||
|
const float boneDt = 0.1f;
|
||||||
|
|
||||||
|
pRagdoll->SetParent( pOwner );
|
||||||
|
pRagdoll->ForceSetupBonesAtTime( boneDelta0, gpGlobals->curtime - boneDt );
|
||||||
|
pRagdoll->ForceSetupBonesAtTime( boneDelta1, gpGlobals->curtime );
|
||||||
|
pRagdoll->ForceSetupBonesAtTime( currentBones, gpGlobals->curtime );
|
||||||
|
pRagdoll->SetParent( NULL );
|
||||||
|
|
||||||
|
// We need to take these from the entity
|
||||||
|
//pRagdoll->SetAbsOrigin( position );
|
||||||
|
//pRagdoll->SetAbsAngles( angles );
|
||||||
|
|
||||||
|
pRagdoll->IgniteRagdoll( pOwner );
|
||||||
|
pRagdoll->TransferDissolveFrom( pOwner );
|
||||||
|
pRagdoll->InitModelEffects();
|
||||||
|
|
||||||
|
if ( pOwner->IsEffectActive( EF_NOSHADOW ) )
|
||||||
|
{
|
||||||
|
pRagdoll->AddEffects( EF_NOSHADOW );
|
||||||
|
}
|
||||||
|
|
||||||
|
pRagdoll->m_nRenderFX = kRenderFxRagdoll;
|
||||||
|
pRagdoll->SetRenderMode( pOwner->GetRenderMode() );
|
||||||
|
pRagdoll->SetRenderColor( pOwner->GetRenderColor().r, pOwner->GetRenderColor().g, pOwner->GetRenderColor().b, pOwner->GetRenderColor().a );
|
||||||
|
//pRagdoll->SetGlobalFadeScale( pOwner->GetGlobalFadeScale() );
|
||||||
|
|
||||||
|
pRagdoll->SetSkin( pOwner->GetSkin() );
|
||||||
|
//pRagdoll->m_vecForce = pOwner->m_vecForce;
|
||||||
|
//pRagdoll->m_nForceBone = 0; //pOwner->m_nForceBone;
|
||||||
|
pRagdoll->SetNextClientThink( CLIENT_THINK_ALWAYS );
|
||||||
|
|
||||||
|
pRagdoll->SetModelName( AllocPooledString( pModelName ) );
|
||||||
|
pRagdoll->ResetSequence( 0 );
|
||||||
|
pRagdoll->SetModelScale( pOwner->GetModelScale() );
|
||||||
|
pRagdoll->SetCollisionGroup( COLLISION_GROUP_DEBRIS );
|
||||||
|
//pRagdoll->m_builtRagdoll = true;
|
||||||
|
|
||||||
|
CStudioHdr *hdr = pRagdoll->GetModelPtr();
|
||||||
|
if ( !hdr )
|
||||||
|
{
|
||||||
|
pRagdoll->Release();
|
||||||
|
Warning( "Couldn't create ragdoll gib for %s (no model pointer)\n", pModel->modelName );
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
pRagdoll->m_pRagdoll = CreateRagdoll(
|
||||||
|
pRagdoll,
|
||||||
|
hdr,
|
||||||
|
vec3_origin,
|
||||||
|
0,
|
||||||
|
boneDelta0,
|
||||||
|
boneDelta1,
|
||||||
|
currentBones,
|
||||||
|
boneDt );
|
||||||
|
|
||||||
|
if ( !pRagdoll->m_pRagdoll )
|
||||||
|
{
|
||||||
|
pRagdoll->Release();
|
||||||
|
Warning( "Couldn't create ragdoll gib for %s\n", pModel->modelName );
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
IPhysicsObject *pPhysicsObject = pRagdoll->VPhysicsGetObject();
|
||||||
|
if ( pPhysicsObject )
|
||||||
|
{
|
||||||
|
// randomize velocity by 5%
|
||||||
|
float rndf = RandomFloat( -0.025, 0.025 );
|
||||||
|
Vector rndVel = velocity + rndf*velocity;
|
||||||
|
|
||||||
|
pPhysicsObject->AddVelocity( &rndVel, &angVelocity );
|
||||||
|
}
|
||||||
|
pRagdoll->ApplyLocalAngularVelocityImpulse( angVelocity );
|
||||||
|
|
||||||
|
if ( pRagdoll->m_pRagdoll )
|
||||||
|
{
|
||||||
|
pRagdoll->m_bImportant = false;
|
||||||
|
pRagdoll->m_flForcedRetireTime = pModel->fadeTime > 0.0f ? gpGlobals->curtime + pModel->fadeTime : 0.0f;
|
||||||
|
s_RagdollLRU.MoveToTopOfLRU( pRagdoll, pRagdoll->m_bImportant, pRagdoll->m_flForcedRetireTime );
|
||||||
|
pRagdoll->m_bFadeOut = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Cause the entity to recompute its shadow type and make a
|
||||||
|
// version which only updates when physics state changes
|
||||||
|
// NOTE: We have to do this after m_pRagdoll is assigned above
|
||||||
|
// because that's what ShadowCastType uses to figure out which type of shadow to use.
|
||||||
|
pRagdoll->DestroyShadow();
|
||||||
|
pRagdoll->CreateShadow();
|
||||||
|
|
||||||
|
pRagdoll->SetAbsOrigin( position );
|
||||||
|
pRagdoll->SetAbsAngles( angles );
|
||||||
|
|
||||||
|
pRagdoll->SetPlaybackRate( 0 );
|
||||||
|
pRagdoll->SetCycle( 0 );
|
||||||
|
|
||||||
|
// put into ACT_DIERAGDOLL if it exists, otherwise use sequence 0
|
||||||
|
int nSequence = pRagdoll->SelectWeightedSequence( ACT_DIERAGDOLL );
|
||||||
|
if ( nSequence < 0 )
|
||||||
|
{
|
||||||
|
pRagdoll->ResetSequence( 0 );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
pRagdoll->ResetSequence( nSequence );
|
||||||
|
}
|
||||||
|
|
||||||
|
pRagdoll->UpdatePartitionListEntry();
|
||||||
|
pRagdoll->MarkRenderHandleDirty();
|
||||||
|
|
||||||
|
NoteRagdollCreationTick( pRagdoll );
|
||||||
|
|
||||||
|
//pRagdoll->InitAsClientRagdoll( boneDelta0, boneDelta1, currentBones, boneDt );
|
||||||
|
|
||||||
|
return pRagdoll;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
CBaseEntity *BreakModelCreateSingle( CBaseEntity *pOwner, breakmodel_t *pModel, const Vector &position,
|
CBaseEntity *BreakModelCreateSingle( CBaseEntity *pOwner, breakmodel_t *pModel, const Vector &position,
|
||||||
const QAngle &angles, const Vector &velocity, const AngularImpulse &angVelocity, int nSkin, const breakablepropparams_t ¶ms )
|
const QAngle &angles, const Vector &velocity, const AngularImpulse &angVelocity, int nSkin, const breakablepropparams_t ¶ms )
|
||||||
{
|
{
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if ( pModel->isRagdoll )
|
||||||
|
{
|
||||||
|
CBaseEntity *pEntity = BreakModelCreate_Ragdoll( pOwner, pModel, position, angles, velocity, angVelocity );
|
||||||
|
return pEntity;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
C_PhysPropClientside *pEntity = C_PhysPropClientside::CreateNew();
|
C_PhysPropClientside *pEntity = C_PhysPropClientside::CreateNew();
|
||||||
|
|
||||||
if ( !pEntity )
|
if ( !pEntity )
|
||||||
@ -778,10 +926,12 @@ CBaseEntity *BreakModelCreateSingle( CBaseEntity *pOwner, breakmodel_t *pModel,
|
|||||||
pEntity->SetFadeMinMax( pModel->fadeMinDist, pModel->fadeMaxDist );
|
pEntity->SetFadeMinMax( pModel->fadeMinDist, pModel->fadeMaxDist );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef MAPBASE
|
||||||
if ( pModel->isRagdoll )
|
if ( pModel->isRagdoll )
|
||||||
{
|
{
|
||||||
DevMsg( "BreakModelCreateSingle: clientside doesn't support ragdoll breakmodels.\n" );
|
DevMsg( "BreakModelCreateSingle: clientside doesn't support ragdoll breakmodels.\n" );
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
IPhysicsObject *pPhysicsObject = pEntity->VPhysicsGetObject();
|
IPhysicsObject *pPhysicsObject = pEntity->VPhysicsGetObject();
|
||||||
|
@ -12,6 +12,9 @@
|
|||||||
#include "materialsystem/imaterialsystem.h"
|
#include "materialsystem/imaterialsystem.h"
|
||||||
#include "functionproxy.h"
|
#include "functionproxy.h"
|
||||||
#include "toolframework_client.h"
|
#include "toolframework_client.h"
|
||||||
|
#ifdef MAPBASE
|
||||||
|
#include "view.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
// memdbgon must be the last include file in a .cpp file!!!
|
// memdbgon must be the last include file in a .cpp file!!!
|
||||||
#include "tier0/memdbgon.h"
|
#include "tier0/memdbgon.h"
|
||||||
@ -521,4 +524,100 @@ void CPlayerLogoOnModelProxy::OnBind( void *pC_BaseEntity )
|
|||||||
}
|
}
|
||||||
|
|
||||||
EXPOSE_INTERFACE( CPlayerLogoOnModelProxy, IMaterialProxy, "PlayerLogoOnModel" IMATERIAL_PROXY_INTERFACE_VERSION );
|
EXPOSE_INTERFACE( CPlayerLogoOnModelProxy, IMaterialProxy, "PlayerLogoOnModel" IMATERIAL_PROXY_INTERFACE_VERSION );
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Returns the proximity of the current view to the entity
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
class CViewProximityProxy : public CResultProxy
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
bool Init( IMaterial *pMaterial, KeyValues *pKeyValues );
|
||||||
|
void OnBind( void *pC_BaseEntity );
|
||||||
|
|
||||||
|
private:
|
||||||
|
float m_Factor;
|
||||||
|
};
|
||||||
|
|
||||||
|
bool CViewProximityProxy::Init( IMaterial *pMaterial, KeyValues *pKeyValues )
|
||||||
|
{
|
||||||
|
if (!CResultProxy::Init( pMaterial, pKeyValues ))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
m_Factor = pKeyValues->GetFloat( "scale", 0.002 );
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CViewProximityProxy::OnBind( void *pC_BaseEntity )
|
||||||
|
{
|
||||||
|
if (!pC_BaseEntity)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Find the distance between the player and this entity....
|
||||||
|
C_BaseEntity *pEntity = BindArgToEntity( pC_BaseEntity );
|
||||||
|
|
||||||
|
Vector delta;
|
||||||
|
VectorSubtract( pEntity->WorldSpaceCenter(), CurrentViewOrigin(), delta );
|
||||||
|
|
||||||
|
Assert( m_pResult );
|
||||||
|
SetFloatResult( delta.Length() * m_Factor );
|
||||||
|
|
||||||
|
if ( ToolsEnabled() )
|
||||||
|
{
|
||||||
|
ToolFramework_RecordMaterialParams( GetMaterial() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
EXPOSE_INTERFACE( CViewProximityProxy, IMaterialProxy, "ViewProximity" IMATERIAL_PROXY_INTERFACE_VERSION );
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Returns the current view direction
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
class CViewDirectionProxy : public CResultProxy
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
bool Init( IMaterial *pMaterial, KeyValues *pKeyValues );
|
||||||
|
void OnBind( void *pC_BaseEntity );
|
||||||
|
|
||||||
|
private:
|
||||||
|
float m_Factor;
|
||||||
|
};
|
||||||
|
|
||||||
|
bool CViewDirectionProxy::Init( IMaterial *pMaterial, KeyValues *pKeyValues )
|
||||||
|
{
|
||||||
|
if (!CResultProxy::Init( pMaterial, pKeyValues ))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
m_Factor = pKeyValues->GetFloat( "scale", 2 );
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CViewDirectionProxy::OnBind( void *pC_BaseEntity )
|
||||||
|
{
|
||||||
|
if (!pC_BaseEntity)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Find the view angle between the player and this entity....
|
||||||
|
C_BaseEntity *pEntity = BindArgToEntity( pC_BaseEntity );
|
||||||
|
|
||||||
|
Vector delta;
|
||||||
|
Vector forward;
|
||||||
|
|
||||||
|
VectorSubtract( pEntity->WorldSpaceCenter(), CurrentViewOrigin(), delta );
|
||||||
|
VectorNormalize( delta );
|
||||||
|
|
||||||
|
forward = CurrentViewForward();
|
||||||
|
|
||||||
|
Assert( m_pResult );
|
||||||
|
SetFloatResult( DotProduct( forward, delta ) * m_Factor );
|
||||||
|
|
||||||
|
if ( ToolsEnabled() )
|
||||||
|
{
|
||||||
|
ToolFramework_RecordMaterialParams( GetMaterial() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
EXPOSE_INTERFACE( CViewDirectionProxy, IMaterialProxy, "ViewDirection" IMATERIAL_PROXY_INTERFACE_VERSION );
|
||||||
|
#endif
|
||||||
|
@ -69,6 +69,16 @@ BEGIN_SIMPLE_DATADESC( CRagdoll )
|
|||||||
DEFINE_RAGDOLL_ELEMENT( 21 ),
|
DEFINE_RAGDOLL_ELEMENT( 21 ),
|
||||||
DEFINE_RAGDOLL_ELEMENT( 22 ),
|
DEFINE_RAGDOLL_ELEMENT( 22 ),
|
||||||
DEFINE_RAGDOLL_ELEMENT( 23 ),
|
DEFINE_RAGDOLL_ELEMENT( 23 ),
|
||||||
|
#ifdef MAPBASE
|
||||||
|
DEFINE_RAGDOLL_ELEMENT( 24 ),
|
||||||
|
DEFINE_RAGDOLL_ELEMENT( 25 ),
|
||||||
|
DEFINE_RAGDOLL_ELEMENT( 26 ),
|
||||||
|
DEFINE_RAGDOLL_ELEMENT( 27 ),
|
||||||
|
DEFINE_RAGDOLL_ELEMENT( 28 ),
|
||||||
|
DEFINE_RAGDOLL_ELEMENT( 29 ),
|
||||||
|
DEFINE_RAGDOLL_ELEMENT( 30 ),
|
||||||
|
DEFINE_RAGDOLL_ELEMENT( 31 ),
|
||||||
|
#endif
|
||||||
|
|
||||||
END_DATADESC()
|
END_DATADESC()
|
||||||
|
|
||||||
@ -477,6 +487,9 @@ int C_ServerRagdoll::InternalDrawModel( int flags )
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
static ConVar g_ragdoll_server_snatch_instance( "g_ragdoll_server_snatch_instance", "1", FCVAR_NONE, "Allows serverside ragdolls to snatch their source entities' model instances in the same way clientside ragdolls do, thereby retaining decals." );
|
||||||
|
#endif
|
||||||
|
|
||||||
CStudioHdr *C_ServerRagdoll::OnNewModel( void )
|
CStudioHdr *C_ServerRagdoll::OnNewModel( void )
|
||||||
{
|
{
|
||||||
@ -499,6 +512,26 @@ CStudioHdr *C_ServerRagdoll::OnNewModel( void )
|
|||||||
m_iv_ragAngles.SetMaxCount( m_elementCount );
|
m_iv_ragAngles.SetMaxCount( m_elementCount );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if ( GetOwnerEntity() )
|
||||||
|
{
|
||||||
|
if (GetOwnerEntity()->GetModelName() == GetModelName())
|
||||||
|
{
|
||||||
|
// TODO: Is there a better place for this?
|
||||||
|
if (GetOwnerEntity()->GetBaseAnimating())
|
||||||
|
GetOwnerEntity()->GetBaseAnimating()->m_pServerRagdoll = this;
|
||||||
|
|
||||||
|
if (g_ragdoll_server_snatch_instance.GetBool())
|
||||||
|
{
|
||||||
|
GetOwnerEntity()->SnatchModelInstance( this );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add server ragdolls to the creation tick list
|
||||||
|
NoteRagdollCreationTick( this );
|
||||||
|
#endif
|
||||||
|
|
||||||
return hdr;
|
return hdr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -121,7 +121,7 @@ char *CHudTextMessage::BufferedLocaliseTextString( const char *msg )
|
|||||||
char *CHudTextMessage::LookupString( const char *msg, int *msg_dest )
|
char *CHudTextMessage::LookupString( const char *msg, int *msg_dest )
|
||||||
{
|
{
|
||||||
if ( !msg )
|
if ( !msg )
|
||||||
return "";
|
return (char*)"";
|
||||||
|
|
||||||
// '#' character indicates this is a reference to a string in titles.txt, and not the string itself
|
// '#' character indicates this is a reference to a string in titles.txt, and not the string itself
|
||||||
if ( msg[0] == '#' )
|
if ( msg[0] == '#' )
|
||||||
|
@ -129,7 +129,7 @@ void CDebugOverlay::Paint()
|
|||||||
{
|
{
|
||||||
float xPos = screenPos[0];
|
float xPos = screenPos[0];
|
||||||
float yPos = screenPos[1]+ (pCurrText->lineOffset*13); // Line spacing;
|
float yPos = screenPos[1]+ (pCurrText->lineOffset*13); // Line spacing;
|
||||||
g_pMatSystemSurface->DrawColoredText( m_hFont, xPos, yPos, r, g, b, a, pCurrText->text );
|
g_pMatSystemSurface->DrawColoredText( m_hFont, xPos, yPos, r, g, b, a, "%s", pCurrText->text );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -138,7 +138,7 @@ void CDebugOverlay::Paint()
|
|||||||
{
|
{
|
||||||
float xPos = screenPos[0];
|
float xPos = screenPos[0];
|
||||||
float yPos = screenPos[1]+ (pCurrText->lineOffset*13); // Line spacing;
|
float yPos = screenPos[1]+ (pCurrText->lineOffset*13); // Line spacing;
|
||||||
g_pMatSystemSurface->DrawColoredText( m_hFont, xPos, yPos, r, g, b, a, pCurrText->text );
|
g_pMatSystemSurface->DrawColoredText( m_hFont, xPos, yPos, r, g, b, a, "%s", pCurrText->text );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
442
mp/src/game/client/vgui_movie_display.cpp
Normal file
442
mp/src/game/client/vgui_movie_display.cpp
Normal file
@ -0,0 +1,442 @@
|
|||||||
|
//========= Copyright © 1996-2009, Valve Corporation, All rights reserved. ============//
|
||||||
|
//
|
||||||
|
// Purpose:
|
||||||
|
//
|
||||||
|
//=====================================================================================//
|
||||||
|
|
||||||
|
#include "cbase.h"
|
||||||
|
#include "c_vguiscreen.h"
|
||||||
|
#include "vgui_controls/Label.h"
|
||||||
|
#include "vgui_bitmappanel.h"
|
||||||
|
#include <vgui/IVGui.h>
|
||||||
|
#include "c_slideshow_display.h"
|
||||||
|
#include "ienginevgui.h"
|
||||||
|
#include "fmtstr.h"
|
||||||
|
#include "vgui_controls/ImagePanel.h"
|
||||||
|
#include <vgui/ISurface.h>
|
||||||
|
#include "video/ivideoservices.h"
|
||||||
|
#include "engine/IEngineSound.h"
|
||||||
|
#include "VGuiMatSurface/IMatSystemSurface.h"
|
||||||
|
#include "c_movie_display.h"
|
||||||
|
|
||||||
|
// NOTE: This has to be the last file included!
|
||||||
|
#include "tier0/memdbgon.h"
|
||||||
|
|
||||||
|
using namespace vgui;
|
||||||
|
|
||||||
|
struct VideoPlaybackInfo_t
|
||||||
|
{
|
||||||
|
VideoPlaybackInfo_t( void ) :
|
||||||
|
m_pMaterial ( NULL ),
|
||||||
|
m_nSourceHeight(0), m_nSourceWidth(0),
|
||||||
|
m_flU(0.0f),m_flV(0.0f) {}
|
||||||
|
|
||||||
|
IMaterial *m_pMaterial;
|
||||||
|
int m_nSourceHeight, m_nSourceWidth; // Source movie's dimensions
|
||||||
|
float m_flU, m_flV; // U,V ranges for video on its sheet
|
||||||
|
};
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Control screen
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
class CMovieDisplayScreen : public CVGuiScreenPanel
|
||||||
|
{
|
||||||
|
DECLARE_CLASS( CMovieDisplayScreen, CVGuiScreenPanel );
|
||||||
|
|
||||||
|
public:
|
||||||
|
CMovieDisplayScreen( vgui::Panel *parent, const char *panelName );
|
||||||
|
~CMovieDisplayScreen( void );
|
||||||
|
|
||||||
|
virtual void ApplySchemeSettings( IScheme *pScheme );
|
||||||
|
|
||||||
|
virtual bool Init( KeyValues* pKeyValues, VGuiScreenInitData_t* pInitData );
|
||||||
|
virtual void OnTick( void );
|
||||||
|
virtual void Paint( void );
|
||||||
|
|
||||||
|
private:
|
||||||
|
bool IsActive( void );
|
||||||
|
|
||||||
|
void SetupMovie( void );
|
||||||
|
void UpdateMovie( void );
|
||||||
|
bool BeginPlayback( const char *pFilename );
|
||||||
|
void CalculatePlaybackDimensions( int nSrcWidth, int nSrcHeight );
|
||||||
|
|
||||||
|
inline void GetPanelPos( int &xpos, int &ypos )
|
||||||
|
{
|
||||||
|
xpos = ( (float) ( GetWide() - m_nPlaybackWidth ) / 2 );
|
||||||
|
ypos = ( (float) ( GetTall() - m_nPlaybackHeight ) / 2 );
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
// BINK playback info
|
||||||
|
IVideoMaterial *m_VideoMaterial;
|
||||||
|
VideoPlaybackInfo_t m_playbackInfo;
|
||||||
|
CHandle<C_VGuiScreen> m_hVGUIScreen;
|
||||||
|
CHandle<C_MovieDisplay> m_hScreenEntity;
|
||||||
|
|
||||||
|
int m_nTextureId;
|
||||||
|
int m_nPlaybackHeight; // Playback dimensions (proper ration adjustments)
|
||||||
|
int m_nPlaybackWidth;
|
||||||
|
bool m_bBlackBackground;
|
||||||
|
bool m_bSlaved;
|
||||||
|
bool m_bInitialized;
|
||||||
|
bool m_bLastActiveState; // HACK: I'd rather get a real callback...
|
||||||
|
|
||||||
|
// VGUI specifics
|
||||||
|
Label *m_pDisplayTextLabel;
|
||||||
|
|
||||||
|
Color m_cDefault;
|
||||||
|
Color m_cInvisible;
|
||||||
|
|
||||||
|
bool bIsAlreadyVisible;
|
||||||
|
};
|
||||||
|
|
||||||
|
DECLARE_VGUI_SCREEN_FACTORY( CMovieDisplayScreen, "movie_display_screen" );
|
||||||
|
|
||||||
|
CUtlVector <CMovieDisplayScreen *> g_MovieDisplays;
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Constructor:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
CMovieDisplayScreen::CMovieDisplayScreen( vgui::Panel *parent, const char *panelName )
|
||||||
|
: BaseClass( parent, "CMovieDisplayScreen", vgui::scheme()->LoadSchemeFromFileEx( enginevgui->GetPanel( PANEL_CLIENTDLL ), "resource/MovieDisplayScreen.res", "MovieDisplayScreen" ) )
|
||||||
|
{
|
||||||
|
m_pDisplayTextLabel = new vgui::Label( this, "NumberDisplay", "testing!");
|
||||||
|
|
||||||
|
m_VideoMaterial = NULL;
|
||||||
|
m_nTextureId = -1;
|
||||||
|
m_bBlackBackground = true;
|
||||||
|
m_bSlaved = false;
|
||||||
|
m_bInitialized = false;
|
||||||
|
// Add ourselves to the global list of movie displays
|
||||||
|
g_MovieDisplays.AddToTail( this );
|
||||||
|
//m_VideoMaterial->SetMuted(true);
|
||||||
|
m_bLastActiveState = IsActive();
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Clean up the movie
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
CMovieDisplayScreen::~CMovieDisplayScreen( void )
|
||||||
|
{
|
||||||
|
if ( g_pVideo != NULL && m_VideoMaterial != NULL )
|
||||||
|
{
|
||||||
|
g_pVideo->DestroyVideoMaterial( m_VideoMaterial );
|
||||||
|
m_VideoMaterial = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Clean up our texture reference
|
||||||
|
g_pMatSystemSurface->DestroyTextureID( m_nTextureId );
|
||||||
|
|
||||||
|
// Remove ourselves from the global list of movie displays
|
||||||
|
g_MovieDisplays.FindAndRemove( this );
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Setup our scheme
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void CMovieDisplayScreen::ApplySchemeSettings( IScheme *pScheme )
|
||||||
|
{
|
||||||
|
assert( pScheme );
|
||||||
|
|
||||||
|
m_cDefault = Color( 255, 255, 255, 255 );
|
||||||
|
m_cInvisible = Color( 0, 0, 0, 0 );
|
||||||
|
|
||||||
|
m_pDisplayTextLabel->SetFgColor( m_cDefault );
|
||||||
|
m_pDisplayTextLabel->SetText( "" );
|
||||||
|
m_pDisplayTextLabel->SetVisible( false );
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Initialization
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
bool CMovieDisplayScreen::Init( KeyValues* pKeyValues, VGuiScreenInitData_t* pInitData )
|
||||||
|
{
|
||||||
|
// Make sure we get ticked...
|
||||||
|
vgui::ivgui()->AddTickSignal( GetVPanel() );
|
||||||
|
|
||||||
|
if ( !BaseClass::Init( pKeyValues, pInitData ) )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// Save this for simplicity later on
|
||||||
|
m_hVGUIScreen = dynamic_cast<C_VGuiScreen *>( GetEntity() );
|
||||||
|
if ( m_hVGUIScreen != NULL )
|
||||||
|
{
|
||||||
|
// Also get the associated entity
|
||||||
|
m_hScreenEntity = dynamic_cast<C_MovieDisplay *>(m_hVGUIScreen->GetOwnerEntity());
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Helper function to check our active state
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
bool CMovieDisplayScreen::IsActive( void )
|
||||||
|
{
|
||||||
|
bool bScreenActive = false;
|
||||||
|
if ( m_hVGUIScreen != NULL )
|
||||||
|
{
|
||||||
|
bScreenActive = m_hVGUIScreen->IsActive();
|
||||||
|
}
|
||||||
|
|
||||||
|
return bScreenActive;
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Either become the master of a group of screens, or become a slave to another
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void CMovieDisplayScreen::SetupMovie( void )
|
||||||
|
{
|
||||||
|
// Only bother if we haven't been setup yet
|
||||||
|
if ( m_bInitialized )
|
||||||
|
return;
|
||||||
|
|
||||||
|
const char *szGroupName = m_hScreenEntity->GetGroupName();
|
||||||
|
|
||||||
|
CMovieDisplayScreen *pMasterScreen = NULL;
|
||||||
|
for ( int i = 0; i < g_MovieDisplays.Count(); i++ )
|
||||||
|
{
|
||||||
|
// Must be valid and not us
|
||||||
|
if ( g_MovieDisplays[i] == NULL || g_MovieDisplays[i] == this )
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// Must have an associated movie entity
|
||||||
|
if ( g_MovieDisplays[i]->m_hScreenEntity == NULL )
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// Must have a group name to care
|
||||||
|
if ( szGroupName[0] == NULL )
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// Group names must match!
|
||||||
|
// FIXME: Use an ID instead?
|
||||||
|
const char *szTestGroupName = g_MovieDisplays[i]->m_hScreenEntity->GetGroupName();
|
||||||
|
if ( Q_strnicmp( szTestGroupName, szGroupName, 128 ) )
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// See if we've found a master display
|
||||||
|
if ( g_MovieDisplays[i]->m_bInitialized && g_MovieDisplays[i]->m_bSlaved == false )
|
||||||
|
{
|
||||||
|
m_bSlaved = true;
|
||||||
|
|
||||||
|
// Share the info from the master
|
||||||
|
m_playbackInfo = g_MovieDisplays[i]->m_playbackInfo;
|
||||||
|
|
||||||
|
// We need to calculate our own playback dimensions as we may be a different size than our parent
|
||||||
|
CalculatePlaybackDimensions( m_playbackInfo.m_nSourceWidth, m_playbackInfo.m_nSourceHeight );
|
||||||
|
|
||||||
|
// Bind our texture
|
||||||
|
m_nTextureId = surface()->CreateNewTextureID( true );
|
||||||
|
g_pMatSystemSurface->DrawSetTextureMaterial( m_nTextureId, m_playbackInfo.m_pMaterial );
|
||||||
|
|
||||||
|
// Hold this as the master screen
|
||||||
|
pMasterScreen = g_MovieDisplays[i];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// We need to try again, we have no screen entity!
|
||||||
|
if ( m_hScreenEntity == NULL )
|
||||||
|
return;
|
||||||
|
|
||||||
|
// No master found, become one
|
||||||
|
if ( pMasterScreen == NULL )
|
||||||
|
{
|
||||||
|
const char *szFilename = m_hScreenEntity->GetMovieFilename();
|
||||||
|
BeginPlayback( szFilename );
|
||||||
|
m_bSlaved = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Done
|
||||||
|
m_bInitialized = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Deal with the details of the video playback
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void CMovieDisplayScreen::UpdateMovie( void )
|
||||||
|
{
|
||||||
|
// Only the master in a group updates the bink file
|
||||||
|
if ( m_bSlaved )
|
||||||
|
return;
|
||||||
|
|
||||||
|
if ( m_VideoMaterial == NULL )
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Get the current activity state of the screen
|
||||||
|
bool bScreenActive = IsActive();
|
||||||
|
|
||||||
|
// Pause if the game has paused
|
||||||
|
if ( engine->IsPaused() || engine->Con_IsVisible() )
|
||||||
|
{
|
||||||
|
bScreenActive = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// See if we've changed our activity state
|
||||||
|
if ( bScreenActive != m_bLastActiveState )
|
||||||
|
{
|
||||||
|
m_VideoMaterial->SetPaused( !bScreenActive );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Updated
|
||||||
|
m_bLastActiveState = bScreenActive;
|
||||||
|
|
||||||
|
// Update the frame if we're currently enabled
|
||||||
|
if ( bScreenActive )
|
||||||
|
{
|
||||||
|
// Update our frame
|
||||||
|
if ( m_VideoMaterial->Update() == false )
|
||||||
|
{
|
||||||
|
// Issue a close command
|
||||||
|
// OnVideoOver();
|
||||||
|
// StopPlayback();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!m_hScreenEntity->IsMuted())
|
||||||
|
{
|
||||||
|
m_VideoMaterial->SetMuted(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Update the display string
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void CMovieDisplayScreen::OnTick()
|
||||||
|
{
|
||||||
|
BaseClass::OnTick();
|
||||||
|
|
||||||
|
// Create our playback or slave to another screen already playing
|
||||||
|
SetupMovie();
|
||||||
|
|
||||||
|
// Now update the movie
|
||||||
|
UpdateMovie();
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Adjust the playback dimensions to properly account for our screen dimensions
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void CMovieDisplayScreen::CalculatePlaybackDimensions( int nSrcWidth, int nSrcHeight )
|
||||||
|
{
|
||||||
|
float flFrameRatio = ( (float) GetWide() / (float) GetTall() );
|
||||||
|
float flVideoRatio = ( (float) nSrcWidth / (float) nSrcHeight );
|
||||||
|
|
||||||
|
if ( flVideoRatio > flFrameRatio )
|
||||||
|
{
|
||||||
|
m_nPlaybackWidth = GetWide();
|
||||||
|
m_nPlaybackHeight = ( GetWide() / flVideoRatio );
|
||||||
|
}
|
||||||
|
else if ( flVideoRatio < flFrameRatio )
|
||||||
|
{
|
||||||
|
m_nPlaybackWidth = ( GetTall() * flVideoRatio );
|
||||||
|
m_nPlaybackHeight = GetTall();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_nPlaybackWidth = GetWide();
|
||||||
|
m_nPlaybackHeight = GetTall();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Begins playback of a movie
|
||||||
|
// Output : Returns true on success, false on failure.
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
bool CMovieDisplayScreen::BeginPlayback( const char *pFilename )
|
||||||
|
{
|
||||||
|
// need working video services
|
||||||
|
if ( g_pVideo == NULL )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// Create a new video material
|
||||||
|
if ( m_VideoMaterial != NULL )
|
||||||
|
{
|
||||||
|
g_pVideo->DestroyVideoMaterial( m_VideoMaterial );
|
||||||
|
m_VideoMaterial = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create a globally unique name for this material
|
||||||
|
char szMaterialName[256];
|
||||||
|
|
||||||
|
// Append our group name if we have one
|
||||||
|
const char *szGroupName = m_hScreenEntity->GetGroupName();
|
||||||
|
if ( szGroupName[0] != NULL )
|
||||||
|
{
|
||||||
|
Q_snprintf( szMaterialName, sizeof(szMaterialName), "%s_%s", pFilename, szGroupName );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Q_snprintf( szMaterialName, sizeof(szMaterialName), "%s_%s", pFilename, m_hScreenEntity->GetEntityName() );
|
||||||
|
}
|
||||||
|
|
||||||
|
m_VideoMaterial = g_pVideo->CreateVideoMaterial( szMaterialName, pFilename, "GAME",
|
||||||
|
VideoPlaybackFlags::DEFAULT_MATERIAL_OPTIONS,
|
||||||
|
VideoSystem::DETERMINE_FROM_FILE_EXTENSION/*, m_bAllowAlternateMedia*/ );
|
||||||
|
|
||||||
|
if ( m_VideoMaterial == NULL )
|
||||||
|
return false;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
m_VideoMaterial->SetMuted(true); // FIXME: Allow?
|
||||||
|
|
||||||
|
|
||||||
|
if ( m_hScreenEntity->IsLooping() )
|
||||||
|
{
|
||||||
|
m_VideoMaterial->SetLooping( true );
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( m_VideoMaterial->HasAudio())
|
||||||
|
{
|
||||||
|
// We want to be the sole audio source
|
||||||
|
enginesound->NotifyBeginMoviePlayback();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get our basic info from the movie
|
||||||
|
m_VideoMaterial->GetVideoImageSize( &m_playbackInfo.m_nSourceWidth, &m_playbackInfo.m_nSourceHeight );
|
||||||
|
m_VideoMaterial->GetVideoTexCoordRange( &m_playbackInfo.m_flU, &m_playbackInfo.m_flV );
|
||||||
|
m_playbackInfo.m_pMaterial = m_VideoMaterial->GetMaterial();
|
||||||
|
|
||||||
|
// Get our playback dimensions
|
||||||
|
CalculatePlaybackDimensions( m_playbackInfo.m_nSourceWidth, m_playbackInfo.m_nSourceHeight );
|
||||||
|
|
||||||
|
// Bind our texture
|
||||||
|
m_nTextureId = surface()->CreateNewTextureID( true );
|
||||||
|
g_pMatSystemSurface->DrawSetTextureMaterial( m_nTextureId, m_playbackInfo.m_pMaterial );
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Update and draw the frame
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void CMovieDisplayScreen::Paint( void )
|
||||||
|
{
|
||||||
|
// Masters must keep the video updated
|
||||||
|
if ( m_bSlaved == false && m_VideoMaterial == NULL )
|
||||||
|
{
|
||||||
|
BaseClass::Paint();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Sit in the "center"
|
||||||
|
int xpos, ypos;
|
||||||
|
GetPanelPos( xpos, ypos );
|
||||||
|
|
||||||
|
// Black out the background (we could omit drawing under the video surface, but this is straight-forward)
|
||||||
|
if ( m_bBlackBackground )
|
||||||
|
{
|
||||||
|
surface()->DrawSetColor( 0, 0, 0, 255 );
|
||||||
|
surface()->DrawFilledRect( 0, 0, GetWide(), GetTall() );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Draw it
|
||||||
|
surface()->DrawSetTexture( m_nTextureId );
|
||||||
|
surface()->DrawSetColor( 255, 255, 255, 255 );
|
||||||
|
surface()->DrawTexturedSubRect( xpos, ypos, xpos+m_nPlaybackWidth, ypos+m_nPlaybackHeight, 0.0f, 0.0f, m_playbackInfo.m_flU, m_playbackInfo.m_flV );
|
||||||
|
|
||||||
|
// Parent's turn
|
||||||
|
BaseClass::Paint();
|
||||||
|
}
|
@ -16,20 +16,59 @@
|
|||||||
// memdbgon must be the last include file in a .cpp file!!!
|
// memdbgon must be the last include file in a .cpp file!!!
|
||||||
#include "tier0/memdbgon.h"
|
#include "tier0/memdbgon.h"
|
||||||
|
|
||||||
|
using namespace vgui;
|
||||||
|
|
||||||
|
static CUtlVector< VideoPanel * > g_vecVideoPanels;
|
||||||
|
|
||||||
|
// Thiis is a hack due to the fact that the user can type quit with the video panel up, but it's parented to the GameUI dll root panel, which is already gone so
|
||||||
|
// we would crash in the destructor
|
||||||
|
void VGui_ClearVideoPanels()
|
||||||
|
{
|
||||||
|
for ( int i = g_vecVideoPanels.Count() - 1; i >= 0; --i )
|
||||||
|
{
|
||||||
|
if ( g_vecVideoPanels[ i ] )
|
||||||
|
{
|
||||||
|
delete g_vecVideoPanels[ i ];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
g_vecVideoPanels.RemoveAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
struct VideoPanelParms_t
|
||||||
|
{
|
||||||
|
VideoPanelParms_t( bool _interrupt = true, bool _loop = false, bool _mute = false )
|
||||||
|
{
|
||||||
|
bAllowInterrupt = _interrupt;
|
||||||
|
bLoop = _loop;
|
||||||
|
bMute = _mute;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool bAllowInterrupt;
|
||||||
|
bool bLoop;
|
||||||
|
bool bMute;
|
||||||
|
|
||||||
|
//float flFadeIn;
|
||||||
|
//float flFadeOut;
|
||||||
|
};
|
||||||
|
|
||||||
VideoPanel::VideoPanel( unsigned int nXPos, unsigned int nYPos, unsigned int nHeight, unsigned int nWidth, bool allowAlternateMedia ) :
|
VideoPanel::VideoPanel( unsigned int nXPos, unsigned int nYPos, unsigned int nHeight, unsigned int nWidth, bool allowAlternateMedia ) :
|
||||||
BaseClass( NULL, "VideoPanel" ),
|
BaseClass( NULL, "VideoPanel" ),
|
||||||
m_VideoMaterial( NULL ),
|
m_VideoMaterial( NULL ),
|
||||||
m_nPlaybackWidth( 0 ),
|
m_nPlaybackWidth( 0 ),
|
||||||
m_nPlaybackHeight( 0 ),
|
m_nPlaybackHeight( 0 ),
|
||||||
m_bAllowAlternateMedia( allowAlternateMedia )
|
m_nShutdownCount( 0 ),
|
||||||
|
m_bLooping( false ),
|
||||||
|
m_bStopAllSounds( true ),
|
||||||
|
m_bAllowInterruption( true ),
|
||||||
|
m_bAllowAlternateMedia( allowAlternateMedia ),
|
||||||
|
m_bStarted( false )
|
||||||
{
|
{
|
||||||
|
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
vgui::VPANEL pParent = enginevgui->GetPanel( PANEL_ROOT );
|
vgui::VPANEL pParent = enginevgui->GetPanel( PANEL_ROOT );
|
||||||
#else
|
#else
|
||||||
vgui::VPANEL pParent = enginevgui->GetPanel( PANEL_GAMEUIDLL );
|
vgui::VPANEL pParent = enginevgui->GetPanel( PANEL_GAMEUIDLL );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
SetParent( pParent );
|
SetParent( pParent );
|
||||||
SetVisible( false );
|
SetVisible( false );
|
||||||
|
|
||||||
@ -53,6 +92,11 @@ VideoPanel::VideoPanel( unsigned int nXPos, unsigned int nYPos, unsigned int nHe
|
|||||||
|
|
||||||
SetScheme(vgui::scheme()->LoadSchemeFromFile( "resource/VideoPanelScheme.res", "VideoPanelScheme"));
|
SetScheme(vgui::scheme()->LoadSchemeFromFile( "resource/VideoPanelScheme.res", "VideoPanelScheme"));
|
||||||
LoadControlSettings("resource/UI/VideoPanel.res");
|
LoadControlSettings("resource/UI/VideoPanel.res");
|
||||||
|
|
||||||
|
// Let us update
|
||||||
|
vgui::ivgui()->AddTickSignal( GetVPanel() );
|
||||||
|
|
||||||
|
g_vecVideoPanels.AddToTail( this );
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -60,6 +104,8 @@ VideoPanel::VideoPanel( unsigned int nXPos, unsigned int nYPos, unsigned int nHe
|
|||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
VideoPanel::~VideoPanel( void )
|
VideoPanel::~VideoPanel( void )
|
||||||
{
|
{
|
||||||
|
g_vecVideoPanels.FindAndRemove( this );
|
||||||
|
|
||||||
SetParent( (vgui::Panel *) NULL );
|
SetParent( (vgui::Panel *) NULL );
|
||||||
|
|
||||||
// Shut down this video, destroy the video material
|
// Shut down this video, destroy the video material
|
||||||
@ -70,13 +116,39 @@ VideoPanel::~VideoPanel( void )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Keeps a tab on when the movie is ending and allows a frame to pass to prevent threading issues
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void VideoPanel::OnTick( void )
|
||||||
|
{
|
||||||
|
if ( m_nShutdownCount > 0 )
|
||||||
|
{
|
||||||
|
m_nShutdownCount++;
|
||||||
|
|
||||||
|
if ( m_nShutdownCount > 10 )
|
||||||
|
{
|
||||||
|
OnClose();
|
||||||
|
m_nShutdownCount = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
BaseClass::OnTick();
|
||||||
|
}
|
||||||
|
|
||||||
|
void VideoPanel::OnVideoOver()
|
||||||
|
{
|
||||||
|
StopPlayback();
|
||||||
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose: Begins playback of a movie
|
// Purpose: Begins playback of a movie
|
||||||
// Output : Returns true on success, false on failure.
|
// Output : Returns true on success, false on failure.
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
bool VideoPanel::BeginPlayback( const char *pFilename )
|
bool VideoPanel::BeginPlayback( const char *pFilename )
|
||||||
{
|
{
|
||||||
// Who the heck hacked this in?
|
if ( !pFilename || pFilename[ 0 ] == '\0' )
|
||||||
|
return false;
|
||||||
|
|
||||||
#ifdef _X360
|
#ifdef _X360
|
||||||
XVIDEO_MODE videoMode;
|
XVIDEO_MODE videoMode;
|
||||||
XGetVideoMode( &videoMode );
|
XGetVideoMode( &videoMode );
|
||||||
@ -106,9 +178,25 @@ bool VideoPanel::BeginPlayback( const char *pFilename )
|
|||||||
if ( m_VideoMaterial == NULL )
|
if ( m_VideoMaterial == NULL )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
if ( m_bLooping )
|
||||||
|
{
|
||||||
|
m_VideoMaterial->SetLooping( true );
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if ( m_bMuted )
|
||||||
|
{
|
||||||
|
m_VideoMaterial->SetMuted( true );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
m_bStarted = true;
|
||||||
|
|
||||||
// We want to be the sole audio source
|
// We want to be the sole audio source
|
||||||
// FIXME: This may not always be true!
|
if ( m_bStopAllSounds )
|
||||||
enginesound->NotifyBeginMoviePlayback();
|
{
|
||||||
|
enginesound->NotifyBeginMoviePlayback();
|
||||||
|
}
|
||||||
|
|
||||||
int nWidth, nHeight;
|
int nWidth, nHeight;
|
||||||
m_VideoMaterial->GetVideoImageSize( &nWidth, &nHeight );
|
m_VideoMaterial->GetVideoImageSize( &nWidth, &nHeight );
|
||||||
@ -168,9 +256,10 @@ void VideoPanel::DoModal( void )
|
|||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
void VideoPanel::OnKeyCodeTyped( vgui::KeyCode code )
|
void VideoPanel::OnKeyCodeTyped( vgui::KeyCode code )
|
||||||
{
|
{
|
||||||
if ( code == KEY_ESCAPE )
|
bool bInterruptKeyPressed = ( code == KEY_ESCAPE );
|
||||||
|
if ( m_bAllowInterruption && bInterruptKeyPressed )
|
||||||
{
|
{
|
||||||
OnClose();
|
StopPlayback();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -181,34 +270,54 @@ void VideoPanel::OnKeyCodeTyped( vgui::KeyCode code )
|
|||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose: Handle keys that should cause us to close
|
// Purpose: Handle keys that should cause us to close
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
void VideoPanel::OnKeyCodePressed( vgui::KeyCode code )
|
void VideoPanel::OnKeyCodePressed( vgui::KeyCode keycode )
|
||||||
{
|
{
|
||||||
|
vgui::KeyCode code = GetBaseButtonCode( keycode );
|
||||||
|
|
||||||
|
// All these keys will interrupt playback
|
||||||
|
bool bInterruptKeyPressed = ( code == KEY_ESCAPE ||
|
||||||
|
code == KEY_BACKQUOTE ||
|
||||||
|
code == KEY_SPACE ||
|
||||||
|
code == KEY_ENTER ||
|
||||||
|
code == KEY_XBUTTON_A ||
|
||||||
|
code == KEY_XBUTTON_B ||
|
||||||
|
code == KEY_XBUTTON_X ||
|
||||||
|
code == KEY_XBUTTON_Y ||
|
||||||
|
code == KEY_XBUTTON_START ||
|
||||||
|
code == KEY_XBUTTON_BACK );
|
||||||
|
|
||||||
// These keys cause the panel to shutdown
|
// These keys cause the panel to shutdown
|
||||||
if ( code == KEY_ESCAPE ||
|
if ( m_bAllowInterruption && bInterruptKeyPressed )
|
||||||
code == KEY_BACKQUOTE ||
|
|
||||||
code == KEY_SPACE ||
|
|
||||||
code == KEY_ENTER ||
|
|
||||||
code == KEY_XBUTTON_A ||
|
|
||||||
code == KEY_XBUTTON_B ||
|
|
||||||
code == KEY_XBUTTON_X ||
|
|
||||||
code == KEY_XBUTTON_Y ||
|
|
||||||
code == KEY_XBUTTON_START ||
|
|
||||||
code == KEY_XBUTTON_BACK )
|
|
||||||
{
|
{
|
||||||
OnClose();
|
StopPlayback();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
BaseClass::OnKeyCodePressed( code );
|
BaseClass::OnKeyCodePressed( keycode );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose:
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void VideoPanel::StopPlayback( void )
|
||||||
|
{
|
||||||
|
SetVisible( false );
|
||||||
|
|
||||||
|
// Start the deferred shutdown process
|
||||||
|
m_nShutdownCount = 1;
|
||||||
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose:
|
// Purpose:
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
void VideoPanel::OnClose( void )
|
void VideoPanel::OnClose( void )
|
||||||
{
|
{
|
||||||
enginesound->NotifyEndMoviePlayback();
|
if ( m_bStopAllSounds )
|
||||||
|
{
|
||||||
|
enginesound->NotifyEndMoviePlayback();
|
||||||
|
}
|
||||||
|
|
||||||
BaseClass::OnClose();
|
BaseClass::OnClose();
|
||||||
|
|
||||||
if ( vgui::input()->GetAppModalSurface() == GetVPanel() )
|
if ( vgui::input()->GetAppModalSurface() == GetVPanel() )
|
||||||
@ -224,7 +333,6 @@ void VideoPanel::OnClose( void )
|
|||||||
engine->ClientCmd( m_szExitCommand );
|
engine->ClientCmd( m_szExitCommand );
|
||||||
}
|
}
|
||||||
|
|
||||||
SetVisible( false );
|
|
||||||
MarkForDeletion();
|
MarkForDeletion();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -247,26 +355,52 @@ void VideoPanel::Paint( void )
|
|||||||
if ( m_VideoMaterial == NULL )
|
if ( m_VideoMaterial == NULL )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
float alpha = ((float)GetFgColor()[3]/255.0f);
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if (m_flFadeIn != 0.0f || m_flFadeOut != 0.0f)
|
||||||
|
{
|
||||||
|
// GetCurrentVideoTime() and GetVideoDuration() are borked
|
||||||
|
float flFrameCount = m_VideoMaterial->GetFrameCount();
|
||||||
|
float flEnd = flFrameCount / m_VideoMaterial->GetVideoFrameRate().GetFPS();
|
||||||
|
float flTime = ((float)(m_VideoMaterial->GetCurrentFrame()) / flFrameCount) * flEnd;
|
||||||
|
float flFadeOutDelta = (flEnd - m_flFadeOut);
|
||||||
|
|
||||||
|
if (flTime <= m_flFadeIn)
|
||||||
|
{
|
||||||
|
alpha = (flTime / m_flFadeIn);
|
||||||
|
}
|
||||||
|
else if (flTime >= flFadeOutDelta)
|
||||||
|
{
|
||||||
|
alpha = (1.0f - ((flTime - flFadeOutDelta) / m_flFadeOut));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
if ( m_VideoMaterial->Update() == false )
|
if ( m_VideoMaterial->Update() == false )
|
||||||
{
|
{
|
||||||
// Issue a close command
|
// Issue a close command
|
||||||
OnVideoOver();
|
OnVideoOver();
|
||||||
OnClose();
|
//OnClose();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Sit in the "center"
|
// Sit in the "center"
|
||||||
int xpos, ypos;
|
int xpos, ypos;
|
||||||
GetPanelPos( xpos, ypos );
|
GetPanelPos( xpos, ypos );
|
||||||
|
LocalToScreen( xpos, ypos );
|
||||||
|
|
||||||
// Black out the background (we could omit drawing under the video surface, but this is straight-forward)
|
// Black out the background (we could omit drawing under the video surface, but this is straight-forward)
|
||||||
if ( m_bBlackBackground )
|
if ( m_bBlackBackground )
|
||||||
{
|
{
|
||||||
vgui::surface()->DrawSetColor( 0, 0, 0, 255 );
|
vgui::surface()->DrawSetColor( 0, 0, 0, alpha * 255.0f );
|
||||||
vgui::surface()->DrawFilledRect( 0, 0, GetWide(), GetTall() );
|
vgui::surface()->DrawFilledRect( 0, 0, GetWide(), GetTall() );
|
||||||
}
|
}
|
||||||
|
|
||||||
// Draw the polys to draw this out
|
// Draw the polys to draw this out
|
||||||
CMatRenderContextPtr pRenderContext( materials );
|
CMatRenderContextPtr pRenderContext( materials );
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
pRenderContext->ClearColor4ub( 255, 255, 255, alpha * 255.0f );
|
||||||
|
#endif
|
||||||
|
|
||||||
pRenderContext->MatrixMode( MATERIAL_VIEW );
|
pRenderContext->MatrixMode( MATERIAL_VIEW );
|
||||||
pRenderContext->PushMatrix();
|
pRenderContext->PushMatrix();
|
||||||
@ -306,8 +440,6 @@ void VideoPanel::Paint( void )
|
|||||||
flTopY = FLerp( 1, -1, 0, vh ,flTopY );
|
flTopY = FLerp( 1, -1, 0, vh ,flTopY );
|
||||||
flBottomY = FLerp( 1, -1, 0, vh, flBottomY );
|
flBottomY = FLerp( 1, -1, 0, vh, flBottomY );
|
||||||
|
|
||||||
float alpha = ((float)GetFgColor()[3]/255.0f);
|
|
||||||
|
|
||||||
for ( int corner=0; corner<4; corner++ )
|
for ( int corner=0; corner<4; corner++ )
|
||||||
{
|
{
|
||||||
bool bLeft = (corner==0) || (corner==3);
|
bool bLeft = (corner==0) || (corner==3);
|
||||||
@ -340,16 +472,37 @@ void VideoPanel::Paint( void )
|
|||||||
bool VideoPanel_Create( unsigned int nXPos, unsigned int nYPos,
|
bool VideoPanel_Create( unsigned int nXPos, unsigned int nYPos,
|
||||||
unsigned int nWidth, unsigned int nHeight,
|
unsigned int nWidth, unsigned int nHeight,
|
||||||
const char *pVideoFilename,
|
const char *pVideoFilename,
|
||||||
const char *pExitCommand /*= NULL*/)
|
const char *pExitCommand /*= NULL*/,
|
||||||
|
const VideoPanelParms_t &parms )
|
||||||
{
|
{
|
||||||
// Create the base video panel
|
// Create the base video panel
|
||||||
VideoPanel *pVideoPanel = new VideoPanel( nXPos, nYPos, nHeight, nWidth, false );
|
VideoPanel *pVideoPanel = new VideoPanel( nXPos, nYPos, nHeight, nWidth );
|
||||||
if ( pVideoPanel == NULL )
|
if ( pVideoPanel == NULL )
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
// Toggle if we want the panel to allow interruption
|
||||||
|
pVideoPanel->SetAllowInterrupt( parms.bAllowInterrupt );
|
||||||
|
|
||||||
// Set the command we'll call (if any) when the video is interrupted or completes
|
// Set the command we'll call (if any) when the video is interrupted or completes
|
||||||
pVideoPanel->SetExitCommand( pExitCommand );
|
pVideoPanel->SetExitCommand( pExitCommand );
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
// Toggle if we want the panel to loop (inspired by Portal 2)
|
||||||
|
pVideoPanel->SetLooping( parms.bLoop );
|
||||||
|
|
||||||
|
// Toggle if we want the panel to be muted
|
||||||
|
pVideoPanel->SetMuted( parms.bMute );
|
||||||
|
|
||||||
|
// TODO: Unique "Stop All Sounds" parameter
|
||||||
|
if (parms.bMute)
|
||||||
|
{
|
||||||
|
pVideoPanel->SetStopAllSounds( false );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Fade parameters (unfinished)
|
||||||
|
//pVideoPanel->SetFade( parms.flFadeIn, parms.flFadeOut );
|
||||||
|
#endif
|
||||||
|
|
||||||
// Start it going
|
// Start it going
|
||||||
if ( pVideoPanel->BeginPlayback( pVideoFilename ) == false )
|
if ( pVideoPanel->BeginPlayback( pVideoFilename ) == false )
|
||||||
{
|
{
|
||||||
@ -365,8 +518,29 @@ bool VideoPanel_Create( unsigned int nXPos, unsigned int nYPos,
|
|||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose: Used to launch a video playback (Debug) -
|
// Purpose: Create a video panel with the supplied commands
|
||||||
// user must include file extension
|
//-----------------------------------------------------------------------------
|
||||||
|
void CreateVideoPanel( const char *lpszFilename, const char *lpszExitCommand, int nWidth, int nHeight, VideoPanelParms_t &parms )
|
||||||
|
{
|
||||||
|
char strFullpath[MAX_PATH];
|
||||||
|
Q_strncpy( strFullpath, "media/", MAX_PATH ); // Assume we must play out of the media directory
|
||||||
|
char strFilename[MAX_PATH];
|
||||||
|
Q_StripExtension( lpszFilename, strFilename, MAX_PATH );
|
||||||
|
Q_strncat( strFullpath, lpszFilename, MAX_PATH );
|
||||||
|
|
||||||
|
// Use the full screen size if they haven't specified an override
|
||||||
|
unsigned int nScreenWidth = ( nWidth != 0 ) ? nWidth : ScreenWidth();
|
||||||
|
unsigned int nScreenHeight = ( nHeight != 0 ) ? nHeight : ScreenHeight();
|
||||||
|
|
||||||
|
// Create the panel and go!
|
||||||
|
if ( VideoPanel_Create( 0, 0, nScreenWidth, nScreenHeight, strFullpath, lpszExitCommand, parms ) == false )
|
||||||
|
{
|
||||||
|
Warning( "Unable to play video: %s\n", strFullpath );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Used to launch a video playback
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
CON_COMMAND( playvideo, "Plays a video: <filename> [width height]" )
|
CON_COMMAND( playvideo, "Plays a video: <filename> [width height]" )
|
||||||
@ -376,30 +550,32 @@ CON_COMMAND( playvideo, "Plays a video: <filename> [width height]" )
|
|||||||
|
|
||||||
unsigned int nScreenWidth = Q_atoi( args[2] );
|
unsigned int nScreenWidth = Q_atoi( args[2] );
|
||||||
unsigned int nScreenHeight = Q_atoi( args[3] );
|
unsigned int nScreenHeight = Q_atoi( args[3] );
|
||||||
|
|
||||||
char strFullpath[MAX_PATH];
|
|
||||||
Q_strncpy( strFullpath, "media/", MAX_PATH ); // Assume we must play out of the media directory
|
|
||||||
char strFilename[MAX_PATH];
|
|
||||||
Q_StripExtension( args[1], strFilename, MAX_PATH );
|
|
||||||
Q_strncat( strFullpath, args[1], MAX_PATH );
|
|
||||||
|
|
||||||
if ( nScreenWidth == 0 )
|
|
||||||
{
|
|
||||||
nScreenWidth = ScreenWidth();
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( nScreenHeight == 0 )
|
|
||||||
{
|
|
||||||
nScreenHeight = ScreenHeight();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create the panel and go!
|
// New struct; functionally identical
|
||||||
if ( VideoPanel_Create( 0, 0, nScreenWidth, nScreenHeight, strFullpath ) == false )
|
VideoPanelParms_t parms;
|
||||||
{
|
|
||||||
Warning( "Unable to play video: %s\n", strFullpath );
|
CreateVideoPanel( args[1], NULL, nScreenWidth, nScreenHeight, parms );
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Used to launch a video playback
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
CON_COMMAND( playvideo_nointerrupt, "Plays a video without ability to skip: <filename> [width height]" )
|
||||||
|
{
|
||||||
|
if ( args.ArgC() < 2 )
|
||||||
|
return;
|
||||||
|
|
||||||
|
unsigned int nScreenWidth = Q_atoi( args[2] );
|
||||||
|
unsigned int nScreenHeight = Q_atoi( args[3] );
|
||||||
|
|
||||||
|
// New struct; functionally identical
|
||||||
|
VideoPanelParms_t parms( false );
|
||||||
|
|
||||||
|
CreateVideoPanel( args[1], NULL, nScreenWidth, nScreenHeight, parms );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose: Used to launch a video playback and fire a command on completion
|
// Purpose: Used to launch a video playback and fire a command on completion
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -409,21 +585,78 @@ CON_COMMAND( playvideo_exitcommand, "Plays a video and fires and exit command wh
|
|||||||
if ( args.ArgC() < 2 )
|
if ( args.ArgC() < 2 )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
unsigned int nScreenWidth = ScreenWidth();
|
// Pull out the exit command we want to use
|
||||||
unsigned int nScreenHeight = ScreenHeight();
|
|
||||||
|
|
||||||
char strFullpath[MAX_PATH];
|
|
||||||
Q_strncpy( strFullpath, "media/", MAX_PATH ); // Assume we must play out of the media directory
|
|
||||||
char strFilename[MAX_PATH];
|
|
||||||
Q_StripExtension( args[1], strFilename, MAX_PATH );
|
|
||||||
Q_strncat( strFullpath, args[1], MAX_PATH );
|
|
||||||
|
|
||||||
char *pExitCommand = Q_strstr( args.GetCommandString(), args[2] );
|
char *pExitCommand = Q_strstr( args.GetCommandString(), args[2] );
|
||||||
|
|
||||||
// Create the panel and go!
|
// New struct; functionally identical
|
||||||
if ( VideoPanel_Create( 0, 0, nScreenWidth, nScreenHeight, strFullpath, pExitCommand ) == false )
|
VideoPanelParms_t parms;
|
||||||
|
|
||||||
|
CreateVideoPanel( args[1], pExitCommand, 0, 0, parms );
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Used to launch a video playback and fire a command on completion
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
CON_COMMAND( playvideo_exitcommand_nointerrupt, "Plays a video (without interruption) and fires and exit command when it is stopped or finishes: <filename> <exit command>" )
|
||||||
|
{
|
||||||
|
if ( args.ArgC() < 2 )
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Pull out the exit command we want to use
|
||||||
|
char *pExitCommand = Q_strstr( args.GetCommandString(), args[2] );
|
||||||
|
|
||||||
|
// New struct; functionally identical
|
||||||
|
VideoPanelParms_t parms( false );
|
||||||
|
|
||||||
|
CreateVideoPanel( args[1], pExitCommand, 0, 0, parms );
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Cause all playback to stop
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
CON_COMMAND( stopvideos, "Stops all videos playing to the screen" )
|
||||||
|
{
|
||||||
|
FOR_EACH_VEC( g_vecVideoPanels, itr )
|
||||||
{
|
{
|
||||||
Warning( "Unable to play video: %s\n", strFullpath );
|
g_vecVideoPanels[itr]->StopPlayback();
|
||||||
engine->ClientCmd( pExitCommand );
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Used to launch a video playback and fire a command on completion
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
CON_COMMAND( playvideo_complex, "Plays a video with various parameters to simplify logic_playmovie: <filename> <exit command> <no interrupt> <looping> <fade in> <fade out>" )
|
||||||
|
{
|
||||||
|
if ( args.ArgC() < 2 )
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Pull out the exit command we want to use
|
||||||
|
char *pExitCommand = Q_strstr( args.GetCommandString(), args[2] );
|
||||||
|
|
||||||
|
// Parameters
|
||||||
|
VideoPanelParms_t parms;
|
||||||
|
|
||||||
|
if (args.ArgC() >= 3)
|
||||||
|
parms.bAllowInterrupt = atoi( args[3] ) != 0;
|
||||||
|
if (args.ArgC() >= 4)
|
||||||
|
parms.bLoop = atoi( args[4] ) != 0;
|
||||||
|
if (args.ArgC() >= 5)
|
||||||
|
parms.bMute = atoi( args[5] ) != 0;
|
||||||
|
|
||||||
|
//if (args.ArgC() >= 5)
|
||||||
|
// parms.flFadeIn = atof( args[5] );
|
||||||
|
//if (args.ArgC() >= 6)
|
||||||
|
// parms.flFadeOut = atof( args[6] );
|
||||||
|
|
||||||
|
// Stop a softlock
|
||||||
|
if (parms.bAllowInterrupt == false && parms.bLoop)
|
||||||
|
{
|
||||||
|
Warning( "WARNING: Tried to play video set to be uninterruptible and looping. This would cause a softlock because the video loops forever and there's no way to stop it.\n" );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
CreateVideoPanel( args[1], pExitCommand, 0, 0, parms );
|
||||||
|
}
|
||||||
|
@ -45,14 +45,22 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool BeginPlayback( const char *pFilename );
|
bool BeginPlayback( const char *pFilename );
|
||||||
|
void StopPlayback( void );
|
||||||
|
|
||||||
void SetBlackBackground( bool bBlack ){ m_bBlackBackground = bBlack; }
|
void SetBlackBackground( bool bBlack ){ m_bBlackBackground = bBlack; }
|
||||||
|
void SetAllowInterrupt( bool bAllowInterrupt ) { m_bAllowInterruption = bAllowInterrupt; }
|
||||||
|
void SetStopAllSounds( bool bStopAllSounds ) { m_bStopAllSounds = bStopAllSounds; }
|
||||||
|
#ifdef MAPBASE
|
||||||
|
void SetLooping( bool bLooping ) { m_bLooping = bLooping; }
|
||||||
|
void SetMuted( bool bMuted ) { m_bMuted = bMuted; }
|
||||||
|
void SetFade( float flStartFade, float flEndFade ) { m_flFadeIn = flStartFade; m_flFadeOut = flEndFade; }
|
||||||
|
#endif
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
virtual void OnTick( void ) { BaseClass::OnTick(); }
|
virtual void OnTick( void );
|
||||||
virtual void OnCommand( const char *pcCommand ) { BaseClass::OnCommand( pcCommand ); }
|
virtual void OnCommand( const char *pcCommand ) { BaseClass::OnCommand( pcCommand ); }
|
||||||
virtual void OnVideoOver(){}
|
virtual void OnVideoOver();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
IVideoMaterial *m_VideoMaterial;
|
IVideoMaterial *m_VideoMaterial;
|
||||||
@ -65,8 +73,19 @@ protected:
|
|||||||
float m_flU; // U,V ranges for video on its sheet
|
float m_flU; // U,V ranges for video on its sheet
|
||||||
float m_flV;
|
float m_flV;
|
||||||
|
|
||||||
|
bool m_bLooping;
|
||||||
|
#ifdef MAPBASE
|
||||||
|
float m_flFadeIn;
|
||||||
|
float m_flFadeOut;
|
||||||
|
bool m_bMuted;
|
||||||
|
#endif
|
||||||
|
bool m_bStopAllSounds;
|
||||||
|
bool m_bAllowInterruption;
|
||||||
bool m_bBlackBackground;
|
bool m_bBlackBackground;
|
||||||
bool m_bAllowAlternateMedia;
|
bool m_bAllowAlternateMedia;
|
||||||
|
int m_nShutdownCount;
|
||||||
|
|
||||||
|
bool m_bStarted;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -107,10 +107,11 @@ extern ConVar cl_forwardspeed;
|
|||||||
static ConVar v_centermove( "v_centermove", "0.15");
|
static ConVar v_centermove( "v_centermove", "0.15");
|
||||||
static ConVar v_centerspeed( "v_centerspeed","500" );
|
static ConVar v_centerspeed( "v_centerspeed","500" );
|
||||||
|
|
||||||
#ifdef TF_CLIENT_DLL
|
#if defined(TF_CLIENT_DLL) || defined(MAPBASE)
|
||||||
// 54 degrees approximates a 35mm camera - we determined that this makes the viewmodels
|
// 54 degrees approximates a 35mm camera - we determined that this makes the viewmodels
|
||||||
// and motions look the most natural.
|
// and motions look the most natural.
|
||||||
ConVar v_viewmodel_fov( "viewmodel_fov", "54", FCVAR_ARCHIVE, "Sets the field-of-view for the viewmodel.", true, 0.1, true, 179.9 );
|
ConVar v_viewmodel_fov( "viewmodel_fov", "54", FCVAR_ARCHIVE, "Sets the field-of-view for the viewmodel.", true, 0.1, true, 179.9 );
|
||||||
|
ConVar v_viewmodel_fov_script_override( "viewmodel_fov_script_override", "0", FCVAR_NONE, "If nonzero, overrides the viewmodel FOV of weapon scripts which override the viewmodel FOV." );
|
||||||
#else
|
#else
|
||||||
ConVar v_viewmodel_fov( "viewmodel_fov", "54", FCVAR_CHEAT, "Sets the field-of-view for the viewmodel.", true, 0.1, true, 179.9 );
|
ConVar v_viewmodel_fov( "viewmodel_fov", "54", FCVAR_CHEAT, "Sets the field-of-view for the viewmodel.", true, 0.1, true, 179.9 );
|
||||||
#endif
|
#endif
|
||||||
@ -675,6 +676,10 @@ void CViewRender::SetUpViews()
|
|||||||
Vector ViewModelOrigin;
|
Vector ViewModelOrigin;
|
||||||
QAngle ViewModelAngles;
|
QAngle ViewModelAngles;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
view.fovViewmodel = g_pClientMode->GetViewModelFOV();
|
||||||
|
#endif
|
||||||
|
|
||||||
if ( engine->IsHLTV() )
|
if ( engine->IsHLTV() )
|
||||||
{
|
{
|
||||||
HLTVCamera()->CalcView( view.origin, view.angles, view.fov );
|
HLTVCamera()->CalcView( view.origin, view.angles, view.fov );
|
||||||
@ -710,6 +715,18 @@ void CViewRender::SetUpViews()
|
|||||||
bCalcViewModelView = true;
|
bCalcViewModelView = true;
|
||||||
ViewModelOrigin = view.origin;
|
ViewModelOrigin = view.origin;
|
||||||
ViewModelAngles = view.angles;
|
ViewModelAngles = view.angles;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
// Allow weapons to override viewmodel FOV
|
||||||
|
C_BaseCombatWeapon *pWeapon = pPlayer->GetActiveWeapon();
|
||||||
|
if (pWeapon && pWeapon->GetViewmodelFOVOverride() != 0.0f)
|
||||||
|
{
|
||||||
|
if (v_viewmodel_fov_script_override.GetFloat() > 0.0f)
|
||||||
|
view.fovViewmodel = v_viewmodel_fov_script_override.GetFloat();
|
||||||
|
else
|
||||||
|
view.fovViewmodel = pWeapon->GetViewmodelFOVOverride();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -745,7 +762,7 @@ void CViewRender::SetUpViews()
|
|||||||
|
|
||||||
//Adjust the viewmodel's FOV to move with any FOV offsets on the viewer's end
|
//Adjust the viewmodel's FOV to move with any FOV offsets on the viewer's end
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
view.fovViewmodel = fabs(g_pClientMode->GetViewModelFOV()) - flFOVOffset;
|
view.fovViewmodel = max(0.001f, view.fovViewmodel - flFOVOffset);
|
||||||
#else
|
#else
|
||||||
view.fovViewmodel = g_pClientMode->GetViewModelFOV() - flFOVOffset;
|
view.fovViewmodel = g_pClientMode->GetViewModelFOV() - flFOVOffset;
|
||||||
#endif
|
#endif
|
||||||
|
@ -29,6 +29,9 @@ static ConVar mat_wateroverlaysize( "mat_wateroverlaysize", "256" );
|
|||||||
static ConVar mat_showframebuffertexture( "mat_showframebuffertexture", "0", FCVAR_CHEAT );
|
static ConVar mat_showframebuffertexture( "mat_showframebuffertexture", "0", FCVAR_CHEAT );
|
||||||
static ConVar mat_framebuffercopyoverlaysize( "mat_framebuffercopyoverlaysize", "256" );
|
static ConVar mat_framebuffercopyoverlaysize( "mat_framebuffercopyoverlaysize", "256" );
|
||||||
static ConVar mat_showcamerarendertarget( "mat_showcamerarendertarget", "0", FCVAR_CHEAT );
|
static ConVar mat_showcamerarendertarget( "mat_showcamerarendertarget", "0", FCVAR_CHEAT );
|
||||||
|
#ifdef MAPBASE
|
||||||
|
static ConVar mat_showcamerarendertarget_all( "mat_showcamerarendertarget_all", "0", FCVAR_CHEAT );
|
||||||
|
#endif
|
||||||
static ConVar mat_camerarendertargetoverlaysize( "mat_camerarendertargetoverlaysize", "256", FCVAR_CHEAT );
|
static ConVar mat_camerarendertargetoverlaysize( "mat_camerarendertargetoverlaysize", "256", FCVAR_CHEAT );
|
||||||
static ConVar mat_hsv( "mat_hsv", "0", FCVAR_CHEAT );
|
static ConVar mat_hsv( "mat_hsv", "0", FCVAR_CHEAT );
|
||||||
static ConVar mat_yuv( "mat_yuv", "0", FCVAR_CHEAT );
|
static ConVar mat_yuv( "mat_yuv", "0", FCVAR_CHEAT );
|
||||||
@ -178,6 +181,11 @@ void OverlayCameraRenderTarget( const char *pszMaterialName, float flX, float fl
|
|||||||
pMaterial = materials->FindMaterial( pszMaterialName, TEXTURE_GROUP_OTHER, true );
|
pMaterial = materials->FindMaterial( pszMaterialName, TEXTURE_GROUP_OTHER, true );
|
||||||
if( !IsErrorMaterial( pMaterial ) )
|
if( !IsErrorMaterial( pMaterial ) )
|
||||||
{
|
{
|
||||||
|
#ifdef MAPBASE
|
||||||
|
// HACKHACK
|
||||||
|
pMaterial->IncrementReferenceCount();
|
||||||
|
#endif
|
||||||
|
|
||||||
CMatRenderContextPtr pRenderContext( materials );
|
CMatRenderContextPtr pRenderContext( materials );
|
||||||
pRenderContext->Bind( pMaterial );
|
pRenderContext->Bind( pMaterial );
|
||||||
IMesh* pMesh = pRenderContext->GetDynamicMesh( true );
|
IMesh* pMesh = pRenderContext->GetDynamicMesh( true );
|
||||||
@ -203,6 +211,11 @@ void OverlayCameraRenderTarget( const char *pszMaterialName, float flX, float fl
|
|||||||
|
|
||||||
meshBuilder.End();
|
meshBuilder.End();
|
||||||
pMesh->Draw();
|
pMesh->Draw();
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
// HACKHACK
|
||||||
|
pMaterial->DecrementReferenceCount();
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -214,7 +227,11 @@ static void OverlayFrameBufferTexture( int nFrameBufferIndex )
|
|||||||
IMaterial *pMaterial;
|
IMaterial *pMaterial;
|
||||||
char buf[MAX_PATH];
|
char buf[MAX_PATH];
|
||||||
Q_snprintf( buf, MAX_PATH, "debug/debugfbtexture%d", nFrameBufferIndex );
|
Q_snprintf( buf, MAX_PATH, "debug/debugfbtexture%d", nFrameBufferIndex );
|
||||||
|
#ifdef MAPBASE
|
||||||
|
pMaterial = materials->FindMaterial( buf, NULL, true );
|
||||||
|
#else
|
||||||
pMaterial = materials->FindMaterial( buf, TEXTURE_GROUP_OTHER, true );
|
pMaterial = materials->FindMaterial( buf, TEXTURE_GROUP_OTHER, true );
|
||||||
|
#endif
|
||||||
if( !IsErrorMaterial( pMaterial ) )
|
if( !IsErrorMaterial( pMaterial ) )
|
||||||
{
|
{
|
||||||
CMatRenderContextPtr pRenderContext( materials );
|
CMatRenderContextPtr pRenderContext( materials );
|
||||||
@ -586,12 +603,52 @@ void CDebugViewRender::Draw2DDebuggingInfo( const CViewSetup &view )
|
|||||||
|
|
||||||
if ( mat_showcamerarendertarget.GetBool() )
|
if ( mat_showcamerarendertarget.GetBool() )
|
||||||
{
|
{
|
||||||
|
#ifdef MAPBASE
|
||||||
|
float w = mat_camerarendertargetoverlaysize.GetFloat();
|
||||||
|
float h = mat_camerarendertargetoverlaysize.GetFloat();
|
||||||
|
#else
|
||||||
float w = mat_wateroverlaysize.GetFloat();
|
float w = mat_wateroverlaysize.GetFloat();
|
||||||
float h = mat_wateroverlaysize.GetFloat();
|
float h = mat_wateroverlaysize.GetFloat();
|
||||||
|
#endif
|
||||||
#ifdef PORTAL
|
#ifdef PORTAL
|
||||||
g_pPortalRender->OverlayPortalRenderTargets( w, h );
|
g_pPortalRender->OverlayPortalRenderTargets( w, h );
|
||||||
#else
|
#else
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
int iCameraNum = mat_showcamerarendertarget.GetInt();
|
||||||
|
|
||||||
|
if (iCameraNum == 1) // Display the default camera
|
||||||
|
{
|
||||||
|
OverlayCameraRenderTarget( "debug/debugcamerarendertarget", 0, 0, w, h );
|
||||||
|
}
|
||||||
|
else if (mat_showcamerarendertarget_all.GetBool()) // Display all cameras
|
||||||
|
{
|
||||||
|
OverlayCameraRenderTarget( "debug/debugcamerarendertarget", 0, 0, w, h );
|
||||||
|
|
||||||
|
// Already showed one camera
|
||||||
|
iCameraNum--;
|
||||||
|
|
||||||
|
// Show Mapbase's cameras
|
||||||
|
char szTextureName[48];
|
||||||
|
for (int i = 0; i < iCameraNum; i++)
|
||||||
|
{
|
||||||
|
V_snprintf( szTextureName, sizeof( szTextureName ), "debug/debugcamerarendertarget_camera%i", i );
|
||||||
|
|
||||||
|
// Show them vertically if the cvar is set to 2
|
||||||
|
if (mat_showcamerarendertarget_all.GetInt() == 2)
|
||||||
|
OverlayCameraRenderTarget( szTextureName, 0, h * (i + 1), w, h );
|
||||||
|
else
|
||||||
|
OverlayCameraRenderTarget( szTextureName, w * (i + 1), 0, w, h );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else // Display one of the new cameras
|
||||||
|
{
|
||||||
|
OverlayCameraRenderTarget( VarArgs( "debug/debugcamerarendertarget_camera%i", iCameraNum-2 ), 0, 0, w, h );
|
||||||
|
}
|
||||||
|
#else
|
||||||
OverlayCameraRenderTarget( "debug/debugcamerarendertarget", 0, 0, w, h );
|
OverlayCameraRenderTarget( "debug/debugcamerarendertarget", 0, 0, w, h );
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -655,6 +712,57 @@ CON_COMMAND_F( r_screenoverlay, "Draw specified material as an overlay", FCVAR_C
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// The same as above, but using the new indexed overlays
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
CON_COMMAND_F( r_screenoverlay_indexed, "Draw specified material as an overlay in the specified index", FCVAR_CHEAT|FCVAR_SERVER_CAN_EXECUTE )
|
||||||
|
{
|
||||||
|
if( args.ArgC() == 3 )
|
||||||
|
{
|
||||||
|
int index = atoi( args[1] );
|
||||||
|
if (index < 0 || index >= MAX_SCREEN_OVERLAYS)
|
||||||
|
{
|
||||||
|
Warning( "r_screenoverlay_indexed: '%i' is out of range (should be 0-9)\n", index );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( !Q_stricmp( "off", args[2] ) )
|
||||||
|
{
|
||||||
|
view->SetIndexedScreenOverlayMaterial( index, NULL );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
IMaterial *pMaterial = materials->FindMaterial( args[2], TEXTURE_GROUP_OTHER, false );
|
||||||
|
if ( !IsErrorMaterial( pMaterial ) )
|
||||||
|
{
|
||||||
|
view->SetIndexedScreenOverlayMaterial( index, pMaterial );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
view->SetIndexedScreenOverlayMaterial( index, NULL );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if ( args.ArgC() == 2 )
|
||||||
|
{
|
||||||
|
int index = atoi( args[1] );
|
||||||
|
if (index < 0 || index >= MAX_SCREEN_OVERLAYS)
|
||||||
|
{
|
||||||
|
Warning( "r_screenoverlay_indexed: '%i' is out of range (should be 0-9)\n", index );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
IMaterial *pMaterial = view->GetIndexedScreenOverlayMaterial( index );
|
||||||
|
Warning( "r_screenoverlay_indexed %i: %s\n", index, pMaterial ? pMaterial->GetName() : "off" );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Warning( "Format: r_screenoverlay_indexed <index> [<material>]\n" );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
// Used to verify frame syncing.
|
// Used to verify frame syncing.
|
||||||
void CDebugViewRender::GenerateOverdrawForTesting()
|
void CDebugViewRender::GenerateOverdrawForTesting()
|
||||||
{
|
{
|
||||||
|
@ -76,6 +76,7 @@
|
|||||||
|
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
#include "mapbase/c_func_fake_worldportal.h"
|
#include "mapbase/c_func_fake_worldportal.h"
|
||||||
|
#include "colorcorrectionmgr.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Projective textures
|
// Projective textures
|
||||||
@ -408,10 +409,6 @@ protected:
|
|||||||
void Enable3dSkyboxFog( void );
|
void Enable3dSkyboxFog( void );
|
||||||
void DrawInternal( view_id_t iSkyBoxViewID, bool bInvokePreAndPostRender, ITexture *pRenderTarget, ITexture *pDepthTarget );
|
void DrawInternal( view_id_t iSkyBoxViewID, bool bInvokePreAndPostRender, ITexture *pRenderTarget, ITexture *pDepthTarget );
|
||||||
|
|
||||||
#ifdef MAPBASE
|
|
||||||
void CalculateSkyAngles( const QAngle &angAngles );
|
|
||||||
#endif
|
|
||||||
|
|
||||||
sky3dparams_t * PreRender3dSkyboxWorld( SkyboxVisibility_t nSkyboxVisible );
|
sky3dparams_t * PreRender3dSkyboxWorld( SkyboxVisibility_t nSkyboxVisible );
|
||||||
|
|
||||||
sky3dparams_t *m_pSky3dParams;
|
sky3dparams_t *m_pSky3dParams;
|
||||||
@ -1218,6 +1215,73 @@ IMaterial *CViewRender::GetScreenOverlayMaterial( )
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
// Purpose: Sets the screen space effect material (can't be done during rendering)
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void CViewRender::SetIndexedScreenOverlayMaterial( int i, IMaterial *pMaterial )
|
||||||
|
{
|
||||||
|
if (i < 0 || i >= MAX_SCREEN_OVERLAYS)
|
||||||
|
return;
|
||||||
|
|
||||||
|
m_IndexedScreenOverlayMaterials[i].Init( pMaterial );
|
||||||
|
|
||||||
|
if (pMaterial == NULL)
|
||||||
|
{
|
||||||
|
// Check if we should set to false
|
||||||
|
int i;
|
||||||
|
for (i = 0; i < MAX_SCREEN_OVERLAYS; i++)
|
||||||
|
{
|
||||||
|
if (m_IndexedScreenOverlayMaterials[i] != NULL)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (i == MAX_SCREEN_OVERLAYS)
|
||||||
|
m_bUsingIndexedScreenOverlays = false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_bUsingIndexedScreenOverlays = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
IMaterial *CViewRender::GetIndexedScreenOverlayMaterial( int i )
|
||||||
|
{
|
||||||
|
if (i < 0 || i >= MAX_SCREEN_OVERLAYS)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
return m_IndexedScreenOverlayMaterials[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
void CViewRender::ResetIndexedScreenOverlays()
|
||||||
|
{
|
||||||
|
for (int i = 0; i < MAX_SCREEN_OVERLAYS; i++)
|
||||||
|
{
|
||||||
|
m_IndexedScreenOverlayMaterials[i].Init( NULL );
|
||||||
|
}
|
||||||
|
|
||||||
|
m_bUsingIndexedScreenOverlays = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
//-----------------------------------------------------------------------------
|
||||||
|
int CViewRender::GetMaxIndexedScreenOverlays( ) const
|
||||||
|
{
|
||||||
|
return MAX_SCREEN_OVERLAYS;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose: Performs screen space effects, if any
|
// Purpose: Performs screen space effects, if any
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -1254,6 +1318,44 @@ void CViewRender::PerformScreenOverlay( int x, int y, int w, int h )
|
|||||||
render->ViewDrawFade( color, m_ScreenOverlayMaterial );
|
render->ViewDrawFade( color, m_ScreenOverlayMaterial );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if (m_bUsingIndexedScreenOverlays)
|
||||||
|
{
|
||||||
|
for (int i = 0; i < MAX_SCREEN_OVERLAYS; i++)
|
||||||
|
{
|
||||||
|
if (!m_IndexedScreenOverlayMaterials[i])
|
||||||
|
continue;
|
||||||
|
|
||||||
|
tmZone( TELEMETRY_LEVEL0, TMZF_NONE, "%s", __FUNCTION__ );
|
||||||
|
|
||||||
|
if ( m_IndexedScreenOverlayMaterials[i]->NeedsFullFrameBufferTexture() )
|
||||||
|
{
|
||||||
|
// FIXME: check with multi/sub-rect renders. Should this be 0,0,w,h instead?
|
||||||
|
DrawScreenEffectMaterial( m_IndexedScreenOverlayMaterials[i], x, y, w, h );
|
||||||
|
}
|
||||||
|
else if ( m_IndexedScreenOverlayMaterials[i]->NeedsPowerOfTwoFrameBufferTexture() )
|
||||||
|
{
|
||||||
|
// First copy the FB off to the offscreen texture
|
||||||
|
UpdateRefractTexture( x, y, w, h, true );
|
||||||
|
|
||||||
|
// Now draw the entire screen using the material...
|
||||||
|
CMatRenderContextPtr pRenderContext( materials );
|
||||||
|
ITexture *pTexture = GetPowerOfTwoFrameBufferTexture( );
|
||||||
|
int sw = pTexture->GetActualWidth();
|
||||||
|
int sh = pTexture->GetActualHeight();
|
||||||
|
// Note - don't offset by x,y - already done by the viewport.
|
||||||
|
pRenderContext->DrawScreenSpaceRectangle( m_IndexedScreenOverlayMaterials[i], 0, 0, w, h,
|
||||||
|
0, 0, sw-1, sh-1, sw, sh );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
byte color[4] = { 255, 255, 255, 255 };
|
||||||
|
render->ViewDrawFade( color, m_IndexedScreenOverlayMaterials[i] );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void CViewRender::DrawUnderwaterOverlay( void )
|
void CViewRender::DrawUnderwaterOverlay( void )
|
||||||
@ -2004,19 +2106,18 @@ void CViewRender::RenderView( const CViewSetup &view, int nClearFlags, int whatT
|
|||||||
Frustum_t frustum;
|
Frustum_t frustum;
|
||||||
GeneratePerspectiveFrustum( view.origin, view.angles, view.zNear, view.zFar, view.fov, view.m_flAspectRatio, frustum );
|
GeneratePerspectiveFrustum( view.origin, view.angles, view.zNear, view.zFar, view.fov, view.m_flAspectRatio, frustum );
|
||||||
|
|
||||||
cplane_t portalPlane;
|
Vector vecAbsPlaneNormal;
|
||||||
//C_FuncFakeWorldPortal *pPortalEnt = IsFakeWorldPortalInView( view, portalPlane );
|
float flLocalPlaneDist;
|
||||||
//if ( pPortalEnt )
|
C_FuncFakeWorldPortal *pPortalEnt = NextFakeWorldPortal( NULL, view, vecAbsPlaneNormal, flLocalPlaneDist, frustum );
|
||||||
C_FuncFakeWorldPortal *pPortalEnt = NextFakeWorldPortal( NULL, view, portalPlane, frustum );
|
|
||||||
while ( pPortalEnt != NULL )
|
while ( pPortalEnt != NULL )
|
||||||
{
|
{
|
||||||
ITexture *pCameraTarget = pPortalEnt->RenderTarget();
|
ITexture *pCameraTarget = pPortalEnt->RenderTarget();
|
||||||
int width = pCameraTarget->GetActualWidth();
|
int width = pCameraTarget->GetActualWidth();
|
||||||
int height = pCameraTarget->GetActualHeight();
|
int height = pCameraTarget->GetActualHeight();
|
||||||
|
|
||||||
DrawFakeWorldPortal( pCameraTarget, pPortalEnt, viewMiddle, C_BasePlayer::GetLocalPlayer(), 0, 0, width, height, view, portalPlane );
|
DrawFakeWorldPortal( pCameraTarget, pPortalEnt, viewMiddle, C_BasePlayer::GetLocalPlayer(), 0, 0, width, height, view, vecAbsPlaneNormal, flLocalPlaneDist );
|
||||||
|
|
||||||
pPortalEnt = NextFakeWorldPortal( pPortalEnt, view, portalPlane, frustum );
|
pPortalEnt = NextFakeWorldPortal( pPortalEnt, view, vecAbsPlaneNormal, flLocalPlaneDist, frustum );
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@ -2027,6 +2128,10 @@ void CViewRender::RenderView( const CViewSetup &view, int nClearFlags, int whatT
|
|||||||
// Must be first
|
// Must be first
|
||||||
render->SceneBegin();
|
render->SceneBegin();
|
||||||
|
|
||||||
|
#ifdef MAPBASE // From Alien Swarm SDK
|
||||||
|
g_pColorCorrectionMgr->UpdateColorCorrection();
|
||||||
|
#endif
|
||||||
|
|
||||||
pRenderContext.GetFrom( materials );
|
pRenderContext.GetFrom( materials );
|
||||||
pRenderContext->TurnOnToneMapping();
|
pRenderContext->TurnOnToneMapping();
|
||||||
pRenderContext.SafeRelease();
|
pRenderContext.SafeRelease();
|
||||||
@ -3430,12 +3535,9 @@ bool CViewRender::DrawOneMonitor( ITexture *pRenderTarget, int cameraNum, C_Poin
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
ConVar r_fakeworldportal_debug("r_fakeworldportal_debug", "0");
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose: Sets up scene and renders WIP fake world portal view.
|
// Purpose: Sets up scene and renders WIP fake world portal view.
|
||||||
// Based on code from monitors, mirrors, and 3D skyboxes.
|
// Based on code from monitors, mirrors, and logic_measure_movement.
|
||||||
// It's also terrible right now.
|
|
||||||
//
|
//
|
||||||
// Input : cameraNum -
|
// Input : cameraNum -
|
||||||
// &cameraView
|
// &cameraView
|
||||||
@ -3449,7 +3551,7 @@ ConVar r_fakeworldportal_debug("r_fakeworldportal_debug", "0");
|
|||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
bool CViewRender::DrawFakeWorldPortal( ITexture *pRenderTarget, C_FuncFakeWorldPortal *pCameraEnt, const CViewSetup &cameraView, C_BasePlayer *localPlayer,
|
bool CViewRender::DrawFakeWorldPortal( ITexture *pRenderTarget, C_FuncFakeWorldPortal *pCameraEnt, const CViewSetup &cameraView, C_BasePlayer *localPlayer,
|
||||||
int x, int y, int width, int height,
|
int x, int y, int width, int height,
|
||||||
const CViewSetup &mainView, cplane_t &ourPlane )
|
const CViewSetup &mainView, const Vector &vecAbsPlaneNormal, float flLocalPlaneDist )
|
||||||
{
|
{
|
||||||
#ifdef USE_MONITORS
|
#ifdef USE_MONITORS
|
||||||
VPROF_INCREMENT_COUNTER( "cameras rendered", 1 );
|
VPROF_INCREMENT_COUNTER( "cameras rendered", 1 );
|
||||||
@ -3480,105 +3582,64 @@ bool CViewRender::DrawFakeWorldPortal( ITexture *pRenderTarget, C_FuncFakeWorldP
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
monitorView.width = width;
|
|
||||||
monitorView.height = height;
|
|
||||||
monitorView.x = x;
|
monitorView.x = x;
|
||||||
monitorView.y = y;
|
monitorView.y = y;
|
||||||
|
monitorView.width = width;
|
||||||
monitorView.origin = mainView.origin;
|
monitorView.height = height;
|
||||||
monitorView.angles = mainView.angles;
|
monitorView.m_bOrtho = mainView.m_bOrtho;
|
||||||
|
|
||||||
// Temporary debug stuff
|
|
||||||
static float flLastDebugTime = 0.0f;
|
|
||||||
bool bDebug = r_fakeworldportal_debug.GetBool() && gpGlobals->curtime > flLastDebugTime;
|
|
||||||
|
|
||||||
QAngle angTargetAngles = pCameraEnt->m_hTargetPlane->GetAbsAngles() + pCameraEnt->m_PlaneAngles;
|
|
||||||
|
|
||||||
// RED - First origin
|
|
||||||
if (bDebug)
|
|
||||||
debugoverlay->AddBoxOverlay( monitorView.origin, Vector(-32,-32,-32), Vector(32,32,32), monitorView.angles, 255, 0, 0, 128, 10.0f );
|
|
||||||
|
|
||||||
// Make sure the origin and angles are relative to the target plane
|
|
||||||
monitorView.origin -= pCameraEnt->GetAbsOrigin();
|
|
||||||
|
|
||||||
// scale origin by sky scale
|
|
||||||
if ( pCameraEnt->m_flScale > 0 )
|
|
||||||
{
|
|
||||||
float scale = 1.0f / pCameraEnt->m_flScale;
|
|
||||||
VectorScale( monitorView.origin, scale, monitorView.origin );
|
|
||||||
}
|
|
||||||
|
|
||||||
// YELLOW - Main origin
|
|
||||||
if (bDebug)
|
|
||||||
debugoverlay->AddBoxOverlay( pCameraEnt->GetAbsOrigin(), Vector(-32,-32,-32), Vector(32,32,32), monitorView.angles, 255, 224, 0, 128, 10.0f );
|
|
||||||
|
|
||||||
// Make sure our angles are relative to the main plane, just like the origin
|
|
||||||
QAngle angOurAngles;
|
|
||||||
VectorAngles( ourPlane.normal * -1, angOurAngles );
|
|
||||||
//angles -= angOurAngles;
|
|
||||||
|
|
||||||
// First, create a matrix for the sky's angles.
|
|
||||||
matrix3x4_t matSkyAngles;
|
|
||||||
AngleMatrix( angTargetAngles - angOurAngles, matSkyAngles );
|
|
||||||
|
|
||||||
Vector vecSkyForward, vecSkyRight, vecSkyUp;
|
|
||||||
|
|
||||||
// Get vectors from our original angles.
|
|
||||||
Vector vPlayerForward, vPlayerRight, vPlayerUp;
|
|
||||||
AngleVectors( monitorView.angles, &vPlayerForward, &vPlayerRight, &vPlayerUp );
|
|
||||||
|
|
||||||
VectorTransform( vPlayerForward, matSkyAngles, vecSkyForward );
|
|
||||||
VectorTransform( vPlayerRight, matSkyAngles, vecSkyRight );
|
|
||||||
VectorTransform( vPlayerUp, matSkyAngles, vecSkyUp );
|
|
||||||
|
|
||||||
// Normalize them.
|
|
||||||
VectorNormalize( vecSkyForward );
|
|
||||||
VectorNormalize( vecSkyRight );
|
|
||||||
VectorNormalize( vecSkyUp );
|
|
||||||
|
|
||||||
Quaternion quat;
|
|
||||||
BasisToQuaternion( vecSkyForward, vecSkyRight, vecSkyUp, quat );
|
|
||||||
QuaternionAngles( quat, monitorView.angles );
|
|
||||||
|
|
||||||
// End of code mostly lifted from projected texture screenspace stuff
|
|
||||||
// ----------------------------------------------------------------------
|
|
||||||
|
|
||||||
// Now just rotate our origin with that matrix.
|
|
||||||
// We create a copy of the origin since VectorRotate doesn't want in1 to be the same variable as the destination.
|
|
||||||
VectorRotate(Vector(monitorView.origin), matSkyAngles, monitorView.origin);
|
|
||||||
|
|
||||||
// BLUE - Target origin
|
|
||||||
if (bDebug)
|
|
||||||
debugoverlay->AddBoxOverlay( pCameraEnt->m_hTargetPlane->GetAbsOrigin(), Vector(-32,-32,-32), Vector(32,32,32), monitorView.angles, 0, 0, 255, 128, 10.0f );
|
|
||||||
|
|
||||||
monitorView.origin += pCameraEnt->m_hTargetPlane->GetAbsOrigin();
|
|
||||||
|
|
||||||
// GREEN - Final origin
|
|
||||||
if (bDebug)
|
|
||||||
{
|
|
||||||
debugoverlay->AddBoxOverlay( monitorView.origin, Vector(-32,-32,-32), Vector(32,32,32), monitorView.angles, 0, 255, 0, 128, 10.0f );
|
|
||||||
|
|
||||||
flLastDebugTime = gpGlobals->curtime + 5.0f;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
monitorView.fov = mainView.fov;
|
monitorView.fov = mainView.fov;
|
||||||
monitorView.m_bOrtho = false;
|
monitorView.m_flAspectRatio = mainView.m_flAspectRatio;
|
||||||
monitorView.m_flAspectRatio = 0.0f;
|
|
||||||
monitorView.m_bViewToProjectionOverride = false;
|
monitorView.m_bViewToProjectionOverride = false;
|
||||||
|
|
||||||
|
matrix3x4_t worldToView;
|
||||||
|
AngleIMatrix( mainView.angles, mainView.origin, worldToView );
|
||||||
|
|
||||||
|
matrix3x4_t targetToWorld;
|
||||||
|
{
|
||||||
|
// NOTE: m_PlaneAngles is angle offset
|
||||||
|
QAngle targetAngles = pCameraEnt->m_hTargetPlane->GetAbsAngles() - pCameraEnt->m_PlaneAngles;
|
||||||
|
AngleMatrix( targetAngles, pCameraEnt->m_hTargetPlane->GetAbsOrigin(), targetToWorld );
|
||||||
|
}
|
||||||
|
|
||||||
|
matrix3x4_t portalToWorld;
|
||||||
|
{
|
||||||
|
Vector left, up;
|
||||||
|
VectorVectors( vecAbsPlaneNormal, left, up );
|
||||||
|
VectorNegate( left );
|
||||||
|
portalToWorld.Init( vecAbsPlaneNormal, left, up, pCameraEnt->GetAbsOrigin() );
|
||||||
|
}
|
||||||
|
|
||||||
|
matrix3x4_t portalToView;
|
||||||
|
ConcatTransforms( worldToView, portalToWorld, portalToView );
|
||||||
|
|
||||||
|
if ( pCameraEnt->m_flScale > 0.0f )
|
||||||
|
{
|
||||||
|
portalToView[0][3] /= pCameraEnt->m_flScale;
|
||||||
|
portalToView[1][3] /= pCameraEnt->m_flScale;
|
||||||
|
portalToView[2][3] /= pCameraEnt->m_flScale;
|
||||||
|
}
|
||||||
|
|
||||||
|
matrix3x4_t viewToPortal;
|
||||||
|
MatrixInvert( portalToView, viewToPortal );
|
||||||
|
|
||||||
|
matrix3x4_t newViewToWorld;
|
||||||
|
ConcatTransforms( targetToWorld, viewToPortal, newViewToWorld );
|
||||||
|
|
||||||
|
MatrixAngles( newViewToWorld, monitorView.angles, monitorView.origin );
|
||||||
|
|
||||||
|
|
||||||
// @MULTICORE (toml 8/11/2006): this should be a renderer....
|
// @MULTICORE (toml 8/11/2006): this should be a renderer....
|
||||||
int nClearFlags = (VIEW_CLEAR_DEPTH | VIEW_CLEAR_COLOR | VIEW_CLEAR_OBEY_STENCIL);
|
int nClearFlags = (VIEW_CLEAR_DEPTH | VIEW_CLEAR_COLOR | VIEW_CLEAR_OBEY_STENCIL);
|
||||||
bool bDrew3dSkybox = false;
|
bool bDrew3dSkybox = false;
|
||||||
SkyboxVisibility_t nSkyMode = pCameraEnt->SkyMode();
|
|
||||||
|
|
||||||
Frustum frustum;
|
Frustum frustum;
|
||||||
render->Push3DView( monitorView, nClearFlags, pRenderTarget, (VPlane *)frustum );
|
render->Push3DView( monitorView, nClearFlags, pRenderTarget, (VPlane *)frustum );
|
||||||
|
|
||||||
//
|
//
|
||||||
// Monitor sky handling
|
// Sky handling
|
||||||
//
|
//
|
||||||
if ( pCameraEnt->SkyMode() == SKYBOX_3DSKYBOX_VISIBLE )
|
SkyboxVisibility_t nSkyMode = pCameraEnt->SkyMode();
|
||||||
|
if ( nSkyMode == SKYBOX_3DSKYBOX_VISIBLE )
|
||||||
{
|
{
|
||||||
// if the 3d skybox world is drawn, then don't draw the normal skybox
|
// if the 3d skybox world is drawn, then don't draw the normal skybox
|
||||||
CSkyboxView *pSkyView = new CSkyboxView( this );
|
CSkyboxView *pSkyView = new CSkyboxView( this );
|
||||||
@ -3591,14 +3652,15 @@ bool CViewRender::DrawFakeWorldPortal( ITexture *pRenderTarget, C_FuncFakeWorldP
|
|||||||
|
|
||||||
Vector4D plane;
|
Vector4D plane;
|
||||||
|
|
||||||
// Combine the target angles and the plane angles
|
// target direction
|
||||||
Vector vecAnglesNormal( angTargetAngles.x, angTargetAngles.y, angTargetAngles.z );
|
MatrixGetColumn( targetToWorld, 0, plane.AsVector3D() );
|
||||||
VectorNormalize( vecAnglesNormal );
|
VectorNormalize( plane.AsVector3D() );
|
||||||
VectorCopy( vecAnglesNormal, plane.AsVector3D() );
|
VectorNegate( plane.AsVector3D() );
|
||||||
|
|
||||||
// TODO: How do we get a good value for this!?!?
|
plane.w =
|
||||||
//plane.w = m_OurPlane.dist + 0.1f;
|
MatrixColumnDotProduct( targetToWorld, 3, plane.AsVector3D() ) // target clip plane distance
|
||||||
plane.w = -32.0f + 0.1f;
|
- flLocalPlaneDist // portal plane distance on the brush. This distance needs to be accounted for while placing the exit target
|
||||||
|
- 0.1;
|
||||||
|
|
||||||
CMatRenderContextPtr pRenderContext( materials );
|
CMatRenderContextPtr pRenderContext( materials );
|
||||||
pRenderContext->PushCustomClipPlane( plane.Base() );
|
pRenderContext->PushCustomClipPlane( plane.Base() );
|
||||||
@ -5293,10 +5355,16 @@ void CSkyboxView::DrawInternal( view_id_t iSkyBoxViewID, bool bInvokePreAndPostR
|
|||||||
// Re-use the x coordinate to determine if we shuld do this with angles
|
// Re-use the x coordinate to determine if we shuld do this with angles
|
||||||
if (m_pSky3dParams->angles.GetX() != 0)
|
if (m_pSky3dParams->angles.GetX() != 0)
|
||||||
{
|
{
|
||||||
CalculateSkyAngles( m_pSky3dParams->skycamera->GetAbsAngles() );
|
const matrix3x4_t &matSky = m_pSky3dParams->skycamera->EntityToWorldTransform();
|
||||||
|
matrix3x4_t matView;
|
||||||
|
AngleMatrix( angles, origin, matView );
|
||||||
|
ConcatTransforms( matSky, matView, matView );
|
||||||
|
MatrixAngles( matView, angles, origin );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
VectorAdd( origin, m_pSky3dParams->skycamera->GetAbsOrigin(), origin );
|
||||||
}
|
}
|
||||||
|
|
||||||
VectorAdd( origin, m_pSky3dParams->skycamera->GetAbsOrigin(), origin );
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -5304,10 +5372,16 @@ void CSkyboxView::DrawInternal( view_id_t iSkyBoxViewID, bool bInvokePreAndPostR
|
|||||||
m_pSky3dParams->angles.GetY() != 0 ||
|
m_pSky3dParams->angles.GetY() != 0 ||
|
||||||
m_pSky3dParams->angles.GetZ() != 0)
|
m_pSky3dParams->angles.GetZ() != 0)
|
||||||
{
|
{
|
||||||
CalculateSkyAngles( m_pSky3dParams->angles.Get() );
|
matrix3x4_t matSky, matView;
|
||||||
|
AngleMatrix( m_pSky3dParams->angles, m_pSky3dParams->origin, matSky );
|
||||||
|
AngleMatrix( angles, origin, matView );
|
||||||
|
ConcatTransforms( matSky, matView, matView );
|
||||||
|
MatrixAngles( matView, angles, origin );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
VectorAdd( origin, m_pSky3dParams->origin, origin );
|
||||||
}
|
}
|
||||||
|
|
||||||
VectorAdd( origin, m_pSky3dParams->origin, origin );
|
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
VectorAdd( origin, m_pSky3dParams->origin, origin );
|
VectorAdd( origin, m_pSky3dParams->origin, origin );
|
||||||
@ -5424,55 +5498,6 @@ void CSkyboxView::DrawInternal( view_id_t iSkyBoxViewID, bool bInvokePreAndPostR
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef MAPBASE
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
//
|
|
||||||
//-----------------------------------------------------------------------------
|
|
||||||
void CSkyboxView::CalculateSkyAngles( const QAngle &angAngles )
|
|
||||||
{
|
|
||||||
// Unfortunately, it's not as simple as "angles += m_pSky3dParams->angles".
|
|
||||||
// This stuff took a long time to figure out. I'm glad I got it working.
|
|
||||||
|
|
||||||
// First, create a matrix for the sky's angles.
|
|
||||||
matrix3x4_t matSkyAngles;
|
|
||||||
AngleMatrix( angAngles, matSkyAngles );
|
|
||||||
|
|
||||||
// The code in between the lines below was mostly lifted from projected texture screenspace code and was a huge lifesaver.
|
|
||||||
// The comments are my attempt at explaining the little I understand of what's going on here.
|
|
||||||
// ----------------------------------------------------------------------
|
|
||||||
|
|
||||||
// These are the vectors that would eventually become our final angle directions.
|
|
||||||
Vector vecSkyForward, vecSkyRight, vecSkyUp;
|
|
||||||
|
|
||||||
// Get vectors from our original angles.
|
|
||||||
Vector vPlayerForward, vPlayerRight, vPlayerUp;
|
|
||||||
AngleVectors( angles, &vPlayerForward, &vPlayerRight, &vPlayerUp );
|
|
||||||
|
|
||||||
// Transform them from our sky angles matrix and put the results in those vectors we declared earlier.
|
|
||||||
VectorTransform( vPlayerForward, matSkyAngles, vecSkyForward );
|
|
||||||
VectorTransform( vPlayerRight, matSkyAngles, vecSkyRight );
|
|
||||||
VectorTransform( vPlayerUp, matSkyAngles, vecSkyUp );
|
|
||||||
|
|
||||||
// Normalize them.
|
|
||||||
VectorNormalize( vecSkyForward );
|
|
||||||
VectorNormalize( vecSkyRight );
|
|
||||||
VectorNormalize( vecSkyUp );
|
|
||||||
|
|
||||||
// Now do a bit of quaternion magic and apply that to our original angles.
|
|
||||||
// This works perfectly, so I'm not gonna touch it.
|
|
||||||
Quaternion quat;
|
|
||||||
BasisToQuaternion( vecSkyForward, vecSkyRight, vecSkyUp, quat );
|
|
||||||
QuaternionAngles( quat, angles );
|
|
||||||
|
|
||||||
// End of code mostly lifted from projected texture screenspace stuff
|
|
||||||
// ----------------------------------------------------------------------
|
|
||||||
|
|
||||||
// Now just rotate our origin with that matrix.
|
|
||||||
// We create a copy of the origin since VectorRotate doesn't want in1 to be the same variable as the destination.
|
|
||||||
VectorRotate(Vector(origin), matSkyAngles, origin);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
//
|
//
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
@ -458,7 +458,7 @@ private:
|
|||||||
#ifdef MAPBASE
|
#ifdef MAPBASE
|
||||||
bool DrawFakeWorldPortal( ITexture *pRenderTarget, C_FuncFakeWorldPortal *pCameraEnt, const CViewSetup &cameraView, C_BasePlayer *localPlayer,
|
bool DrawFakeWorldPortal( ITexture *pRenderTarget, C_FuncFakeWorldPortal *pCameraEnt, const CViewSetup &cameraView, C_BasePlayer *localPlayer,
|
||||||
int x, int y, int width, int height,
|
int x, int y, int width, int height,
|
||||||
const CViewSetup &mainView, cplane_t &ourPlane );
|
const CViewSetup &mainView, const Vector &vecAbsPlaneNormal, float flLocalPlaneDist );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Drawing primitives
|
// Drawing primitives
|
||||||
@ -472,6 +472,13 @@ private:
|
|||||||
IMaterial *GetScreenOverlayMaterial( );
|
IMaterial *GetScreenOverlayMaterial( );
|
||||||
void PerformScreenOverlay( int x, int y, int w, int h );
|
void PerformScreenOverlay( int x, int y, int w, int h );
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
void SetIndexedScreenOverlayMaterial( int i, IMaterial *pMaterial );
|
||||||
|
IMaterial *GetIndexedScreenOverlayMaterial( int i );
|
||||||
|
void ResetIndexedScreenOverlays();
|
||||||
|
int GetMaxIndexedScreenOverlays() const;
|
||||||
|
#endif
|
||||||
|
|
||||||
void DrawUnderwaterOverlay( void );
|
void DrawUnderwaterOverlay( void );
|
||||||
|
|
||||||
// Water-related methods
|
// Water-related methods
|
||||||
@ -515,6 +522,10 @@ private:
|
|||||||
CMaterialReference m_TranslucentSingleColor;
|
CMaterialReference m_TranslucentSingleColor;
|
||||||
CMaterialReference m_ModulateSingleColor;
|
CMaterialReference m_ModulateSingleColor;
|
||||||
CMaterialReference m_ScreenOverlayMaterial;
|
CMaterialReference m_ScreenOverlayMaterial;
|
||||||
|
#ifdef MAPBASE
|
||||||
|
CMaterialReference m_IndexedScreenOverlayMaterials[MAX_SCREEN_OVERLAYS];
|
||||||
|
bool m_bUsingIndexedScreenOverlays;
|
||||||
|
#endif
|
||||||
CMaterialReference m_UnderWaterOverlayMaterial;
|
CMaterialReference m_UnderWaterOverlayMaterial;
|
||||||
|
|
||||||
Vector m_vecLastFacing;
|
Vector m_vecLastFacing;
|
||||||
|
@ -15,11 +15,14 @@
|
|||||||
#include "gamerules.h"
|
#include "gamerules.h"
|
||||||
#include "vscript_client.nut"
|
#include "vscript_client.nut"
|
||||||
#ifdef MAPBASE_VSCRIPT
|
#ifdef MAPBASE_VSCRIPT
|
||||||
#include "mapbase/matchers.h"
|
#include "view.h"
|
||||||
#include "c_world.h"
|
#include "c_world.h"
|
||||||
#include "proxyentity.h"
|
#include "proxyentity.h"
|
||||||
#include "materialsystem/imaterial.h"
|
#include "materialsystem/imaterial.h"
|
||||||
#include "materialsystem/imaterialvar.h"
|
#include "materialsystem/imaterialvar.h"
|
||||||
|
#include "mapbase/matchers.h"
|
||||||
|
#include "mapbase/vscript_singletons.h"
|
||||||
|
#include "mapbase/vscript_vgui.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern IScriptManager *scriptmanager;
|
extern IScriptManager *scriptmanager;
|
||||||
@ -40,12 +43,20 @@ extern ScriptClassDesc_t * GetScriptDesc( CBaseEntity * );
|
|||||||
#endif // VMPROFILE
|
#endif // VMPROFILE
|
||||||
|
|
||||||
#ifdef MAPBASE_VSCRIPT
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
static ScriptHook_t g_Hook_OnEntityCreated;
|
||||||
|
static ScriptHook_t g_Hook_OnEntityDeleted;
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Purpose: A clientside variant of CScriptEntityIterator.
|
// Purpose: A clientside variant of CScriptEntityIterator.
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
class CScriptClientEntityIterator
|
class CScriptClientEntityIterator : public IClientEntityListener
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
HSCRIPT GetLocalPlayer()
|
||||||
|
{
|
||||||
|
return ToHScript( C_BasePlayer::GetLocalPlayer() );
|
||||||
|
}
|
||||||
|
|
||||||
HSCRIPT First() { return Next(NULL); }
|
HSCRIPT First() { return Next(NULL); }
|
||||||
|
|
||||||
HSCRIPT Next( HSCRIPT hStartEntity )
|
HSCRIPT Next( HSCRIPT hStartEntity )
|
||||||
@ -90,15 +101,59 @@ public:
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void EnableEntityListening()
|
||||||
|
{
|
||||||
|
// Start getting entity updates!
|
||||||
|
ClientEntityList().AddListenerEntity( this );
|
||||||
|
}
|
||||||
|
|
||||||
|
void DisableEntityListening()
|
||||||
|
{
|
||||||
|
// Stop getting entity updates!
|
||||||
|
ClientEntityList().RemoveListenerEntity( this );
|
||||||
|
}
|
||||||
|
|
||||||
|
void OnEntityCreated( CBaseEntity *pEntity )
|
||||||
|
{
|
||||||
|
if ( g_pScriptVM && GetScriptHookManager().IsEventHooked( "OnEntityCreated" ) )
|
||||||
|
{
|
||||||
|
// entity
|
||||||
|
ScriptVariant_t args[] = { ScriptVariant_t( pEntity->GetScriptInstance() ) };
|
||||||
|
g_Hook_OnEntityCreated.Call( NULL, NULL, args );
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
void OnEntityDeleted( CBaseEntity *pEntity )
|
||||||
|
{
|
||||||
|
if ( g_pScriptVM && GetScriptHookManager().IsEventHooked( "OnEntityDeleted" ) )
|
||||||
|
{
|
||||||
|
// entity
|
||||||
|
ScriptVariant_t args[] = { ScriptVariant_t( pEntity->GetScriptInstance() ) };
|
||||||
|
g_Hook_OnEntityDeleted.Call( NULL, NULL, args );
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
private:
|
private:
|
||||||
} g_ScriptEntityIterator;
|
} g_ScriptEntityIterator;
|
||||||
|
|
||||||
BEGIN_SCRIPTDESC_ROOT_NAMED( CScriptClientEntityIterator, "CEntities", SCRIPT_SINGLETON "The global list of entities" )
|
BEGIN_SCRIPTDESC_ROOT_NAMED( CScriptClientEntityIterator, "CEntities", SCRIPT_SINGLETON "The global list of entities" )
|
||||||
|
DEFINE_SCRIPTFUNC( GetLocalPlayer, "Get local player" )
|
||||||
DEFINE_SCRIPTFUNC( First, "Begin an iteration over the list of entities" )
|
DEFINE_SCRIPTFUNC( First, "Begin an iteration over the list of entities" )
|
||||||
DEFINE_SCRIPTFUNC( Next, "Continue an iteration over the list of entities, providing reference to a previously found entity" )
|
DEFINE_SCRIPTFUNC( Next, "Continue an iteration over the list of entities, providing reference to a previously found entity" )
|
||||||
DEFINE_SCRIPTFUNC( CreateByClassname, "Creates an entity by classname" )
|
DEFINE_SCRIPTFUNC( CreateByClassname, "Creates an entity by classname" )
|
||||||
DEFINE_SCRIPTFUNC( FindByClassname, "Find entities by class name. Pass 'null' to start an iteration, or reference to a previously found entity to continue a search" )
|
DEFINE_SCRIPTFUNC( FindByClassname, "Find entities by class name. Pass 'null' to start an iteration, or reference to a previously found entity to continue a search" )
|
||||||
DEFINE_SCRIPTFUNC( FindByName, "Find entities by name. Pass 'null' to start an iteration, or reference to a previously found entity to continue a search" )
|
DEFINE_SCRIPTFUNC( FindByName, "Find entities by name. Pass 'null' to start an iteration, or reference to a previously found entity to continue a search" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( EnableEntityListening, "Enables the 'OnEntity' hooks. This function must be called before using them." )
|
||||||
|
DEFINE_SCRIPTFUNC( DisableEntityListening, "Disables the 'OnEntity' hooks." )
|
||||||
|
|
||||||
|
BEGIN_SCRIPTHOOK( g_Hook_OnEntityCreated, "OnEntityCreated", FIELD_VOID, "Called when an entity is created. Requires EnableEntityListening() to be fired beforehand." )
|
||||||
|
DEFINE_SCRIPTHOOK_PARAM( "entity", FIELD_HSCRIPT )
|
||||||
|
END_SCRIPTHOOK()
|
||||||
|
|
||||||
|
BEGIN_SCRIPTHOOK( g_Hook_OnEntityDeleted, "OnEntityDeleted", FIELD_VOID, "Called when an entity is deleted. Requires EnableEntityListening() to be fired beforehand." )
|
||||||
|
DEFINE_SCRIPTHOOK_PARAM( "entity", FIELD_HSCRIPT )
|
||||||
|
END_SCRIPTHOOK()
|
||||||
END_SCRIPTDESC();
|
END_SCRIPTDESC();
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -158,6 +213,8 @@ public:
|
|||||||
void SetVarFloat( int i, float value );
|
void SetVarFloat( int i, float value );
|
||||||
void SetVarVector( int i, const Vector &value );
|
void SetVarVector( int i, const Vector &value );
|
||||||
|
|
||||||
|
const char *GetVarName( int i );
|
||||||
|
|
||||||
private:
|
private:
|
||||||
IMaterialVar *m_MaterialVars[SCRIPT_MAT_PROXY_MAX_VARS];
|
IMaterialVar *m_MaterialVars[SCRIPT_MAT_PROXY_MAX_VARS];
|
||||||
|
|
||||||
@ -169,7 +226,16 @@ private:
|
|||||||
HSCRIPT m_hFuncOnBind;
|
HSCRIPT m_hFuncOnBind;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class CMaterialProxyScriptInstanceHelper : public IScriptInstanceHelper
|
||||||
|
{
|
||||||
|
bool ToString( void *p, char *pBuf, int bufSize );
|
||||||
|
void *BindOnRead( HSCRIPT hInstance, void *pOld, const char *pszId );
|
||||||
|
};
|
||||||
|
|
||||||
|
CMaterialProxyScriptInstanceHelper g_MaterialProxyScriptInstanceHelper;
|
||||||
|
|
||||||
BEGIN_SCRIPTDESC_ROOT_NAMED( CScriptMaterialProxy, "CScriptMaterialProxy", "Material proxy for VScript" )
|
BEGIN_SCRIPTDESC_ROOT_NAMED( CScriptMaterialProxy, "CScriptMaterialProxy", "Material proxy for VScript" )
|
||||||
|
DEFINE_SCRIPT_INSTANCE_HELPER( &g_MaterialProxyScriptInstanceHelper )
|
||||||
DEFINE_SCRIPTFUNC( GetVarString, "Gets a material var's string value" )
|
DEFINE_SCRIPTFUNC( GetVarString, "Gets a material var's string value" )
|
||||||
DEFINE_SCRIPTFUNC( GetVarInt, "Gets a material var's int value" )
|
DEFINE_SCRIPTFUNC( GetVarInt, "Gets a material var's int value" )
|
||||||
DEFINE_SCRIPTFUNC( GetVarFloat, "Gets a material var's float value" )
|
DEFINE_SCRIPTFUNC( GetVarFloat, "Gets a material var's float value" )
|
||||||
@ -178,12 +244,16 @@ BEGIN_SCRIPTDESC_ROOT_NAMED( CScriptMaterialProxy, "CScriptMaterialProxy", "Mate
|
|||||||
DEFINE_SCRIPTFUNC( SetVarInt, "Sets a material var's int value" )
|
DEFINE_SCRIPTFUNC( SetVarInt, "Sets a material var's int value" )
|
||||||
DEFINE_SCRIPTFUNC( SetVarFloat, "Sets a material var's float value" )
|
DEFINE_SCRIPTFUNC( SetVarFloat, "Sets a material var's float value" )
|
||||||
DEFINE_SCRIPTFUNC( SetVarVector, "Sets a material var's vector value" )
|
DEFINE_SCRIPTFUNC( SetVarVector, "Sets a material var's vector value" )
|
||||||
|
|
||||||
|
DEFINE_SCRIPTFUNC( GetVarName, "Gets a material var's name" )
|
||||||
END_SCRIPTDESC();
|
END_SCRIPTDESC();
|
||||||
|
|
||||||
CScriptMaterialProxy::CScriptMaterialProxy()
|
CScriptMaterialProxy::CScriptMaterialProxy()
|
||||||
{
|
{
|
||||||
m_hScriptInstance = NULL;
|
m_hScriptInstance = NULL;
|
||||||
m_hFuncOnBind = NULL;
|
m_hFuncOnBind = NULL;
|
||||||
|
|
||||||
|
V_memset( m_MaterialVars, 0, sizeof(m_MaterialVars) );
|
||||||
}
|
}
|
||||||
|
|
||||||
CScriptMaterialProxy::~CScriptMaterialProxy()
|
CScriptMaterialProxy::~CScriptMaterialProxy()
|
||||||
@ -300,26 +370,25 @@ void CScriptMaterialProxy::TermScript()
|
|||||||
|
|
||||||
void CScriptMaterialProxy::OnBind( void *pRenderable )
|
void CScriptMaterialProxy::OnBind( void *pRenderable )
|
||||||
{
|
{
|
||||||
if( !pRenderable )
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (m_hFuncOnBind != NULL)
|
if (m_hFuncOnBind != NULL)
|
||||||
{
|
{
|
||||||
IClientRenderable *pRend = ( IClientRenderable* )pRenderable;
|
C_BaseEntity *pEnt = NULL;
|
||||||
C_BaseEntity *pEnt = pRend->GetIClientUnknown()->GetBaseEntity();
|
if (pRenderable)
|
||||||
if ( pEnt )
|
|
||||||
{
|
{
|
||||||
g_pScriptVM->SetValue( m_ScriptScope, "entity", pEnt->GetScriptInstance() );
|
IClientRenderable *pRend = (IClientRenderable*)pRenderable;
|
||||||
|
pEnt = pRend->GetIClientUnknown()->GetBaseEntity();
|
||||||
|
if ( pEnt )
|
||||||
|
{
|
||||||
|
g_pScriptVM->SetValue( m_ScriptScope, "entity", pEnt->GetScriptInstance() );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
|
||||||
|
if (!pEnt)
|
||||||
{
|
{
|
||||||
// Needs to register as a null value so the script doesn't break if it looks for an entity
|
|
||||||
g_pScriptVM->SetValue( m_ScriptScope, "entity", SCRIPT_VARIANT_NULL );
|
g_pScriptVM->SetValue( m_ScriptScope, "entity", SCRIPT_VARIANT_NULL );
|
||||||
}
|
}
|
||||||
|
|
||||||
m_ScriptScope.Call( m_hFuncOnBind, NULL );
|
m_ScriptScope.Call( m_hFuncOnBind, NULL );
|
||||||
|
|
||||||
g_pScriptVM->ClearValue( m_ScriptScope, "entity" );
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -398,8 +467,29 @@ void CScriptMaterialProxy::SetVarVector( int i, const Vector &value )
|
|||||||
return m_MaterialVars[i]->SetVecValue( value.Base(), 3 );
|
return m_MaterialVars[i]->SetVecValue( value.Base(), 3 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const char *CScriptMaterialProxy::GetVarName( int i )
|
||||||
|
{
|
||||||
|
if (!ValidateIndex( i ) || !m_MaterialVars[i])
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
return m_MaterialVars[i]->GetName();
|
||||||
|
}
|
||||||
|
|
||||||
EXPOSE_INTERFACE( CScriptMaterialProxy, IMaterialProxy, "VScriptProxy" IMATERIAL_PROXY_INTERFACE_VERSION );
|
EXPOSE_INTERFACE( CScriptMaterialProxy, IMaterialProxy, "VScriptProxy" IMATERIAL_PROXY_INTERFACE_VERSION );
|
||||||
#endif
|
|
||||||
|
bool CMaterialProxyScriptInstanceHelper::ToString( void *p, char *pBuf, int bufSize )
|
||||||
|
{
|
||||||
|
CScriptMaterialProxy *pProxy = (CScriptMaterialProxy *)p;
|
||||||
|
V_snprintf( pBuf, bufSize, "(proxy: %s)", pProxy->GetMaterial() != NULL ? pProxy->GetMaterial()->GetName() : "<no material>" );
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void *CMaterialProxyScriptInstanceHelper::BindOnRead( HSCRIPT hInstance, void *pOld, const char *pszId )
|
||||||
|
{
|
||||||
|
// TODO: Material proxy save/restore?
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
#endif // MAPBASE_VSCRIPT
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
//
|
//
|
||||||
@ -431,6 +521,53 @@ bool DoIncludeScript( const char *pszScript, HSCRIPT hScope )
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
int ScriptScreenWidth();
|
||||||
|
int ScriptScreenHeight();
|
||||||
|
|
||||||
|
static float FrameTime()
|
||||||
|
{
|
||||||
|
return gpGlobals->frametime;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool Con_IsVisible()
|
||||||
|
{
|
||||||
|
return engine->Con_IsVisible();
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool IsWindowedMode()
|
||||||
|
{
|
||||||
|
return engine->IsWindowedMode();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Creates a client-side prop
|
||||||
|
HSCRIPT CreateProp( const char *pszEntityName, const Vector &vOrigin, const char *pszModelName, int iAnim )
|
||||||
|
{
|
||||||
|
C_BaseAnimating *pBaseEntity = (C_BaseAnimating *)CreateEntityByName( pszEntityName );
|
||||||
|
if (!pBaseEntity)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
pBaseEntity->SetAbsOrigin( vOrigin );
|
||||||
|
pBaseEntity->SetModelName( pszModelName );
|
||||||
|
if (!pBaseEntity->InitializeAsClientEntity( pszModelName, RENDER_GROUP_OPAQUE_ENTITY ))
|
||||||
|
{
|
||||||
|
Warning("Can't initialize %s as client entity\n", pszEntityName);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
pBaseEntity->SetPlaybackRate( 1.0f );
|
||||||
|
|
||||||
|
int iSequence = pBaseEntity->SelectWeightedSequence( (Activity)iAnim );
|
||||||
|
|
||||||
|
if ( iSequence != -1 )
|
||||||
|
{
|
||||||
|
pBaseEntity->SetSequence( iSequence );
|
||||||
|
}
|
||||||
|
|
||||||
|
return ToHScript( pBaseEntity );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
bool VScriptClientInit()
|
bool VScriptClientInit()
|
||||||
{
|
{
|
||||||
VMPROF_START
|
VMPROF_START
|
||||||
@ -491,10 +628,40 @@ bool VScriptClientInit()
|
|||||||
#else
|
#else
|
||||||
Log( "VSCRIPT: Started VScript virtual machine using script language '%s'\n", g_pScriptVM->GetLanguageName() );
|
Log( "VSCRIPT: Started VScript virtual machine using script language '%s'\n", g_pScriptVM->GetLanguageName() );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
GetScriptHookManager().OnInit();
|
||||||
|
#endif
|
||||||
|
|
||||||
ScriptRegisterFunction( g_pScriptVM, GetMapName, "Get the name of the map.");
|
ScriptRegisterFunction( g_pScriptVM, GetMapName, "Get the name of the map.");
|
||||||
ScriptRegisterFunction( g_pScriptVM, Time, "Get the current server time" );
|
ScriptRegisterFunction( g_pScriptVM, Time, "Get the current server time" );
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, DoUniqueString, SCRIPT_ALIAS( "UniqueString", "Generate a string guaranteed to be unique across the life of the script VM, with an optional root string." ) );
|
||||||
ScriptRegisterFunction( g_pScriptVM, DoIncludeScript, "Execute a script (internal)" );
|
ScriptRegisterFunction( g_pScriptVM, DoIncludeScript, "Execute a script (internal)" );
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, FrameTime, "Get the time spent on the client in the last frame" );
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, Con_IsVisible, "Returns true if the console is visible" );
|
||||||
|
ScriptRegisterFunctionNamed( g_pScriptVM, ScriptScreenWidth, "ScreenWidth", "Width of the screen in pixels" );
|
||||||
|
ScriptRegisterFunctionNamed( g_pScriptVM, ScriptScreenHeight, "ScreenHeight", "Height of the screen in pixels" );
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, IsWindowedMode, "" );
|
||||||
|
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, MainViewOrigin, "" );
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, MainViewAngles, "" );
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, PrevMainViewOrigin, "" );
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, PrevMainViewAngles, "" );
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, MainViewForward, "" );
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, MainViewRight, "" );
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, MainViewUp, "" );
|
||||||
|
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, CurrentViewOrigin, "" );
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, CurrentViewAngles, "" );
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, CurrentViewForward, "" );
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, CurrentViewRight, "" );
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, CurrentViewUp, "" );
|
||||||
|
|
||||||
|
ScriptRegisterFunction( g_pScriptVM, CreateProp, "Create an animating prop" );
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
if ( GameRules() )
|
if ( GameRules() )
|
||||||
{
|
{
|
||||||
GameRules()->RegisterScriptFunctions();
|
GameRules()->RegisterScriptFunctions();
|
||||||
@ -510,6 +677,7 @@ bool VScriptClientInit()
|
|||||||
|
|
||||||
RegisterSharedScriptConstants();
|
RegisterSharedScriptConstants();
|
||||||
RegisterSharedScriptFunctions();
|
RegisterSharedScriptFunctions();
|
||||||
|
RegisterScriptVGUI();
|
||||||
#else
|
#else
|
||||||
//g_pScriptVM->RegisterInstance( &g_ScriptEntityIterator, "Entities" );
|
//g_pScriptVM->RegisterInstance( &g_ScriptEntityIterator, "Entities" );
|
||||||
#endif
|
#endif
|
||||||
@ -519,8 +687,13 @@ bool VScriptClientInit()
|
|||||||
g_pScriptVM->Run( g_Script_vscript_client );
|
g_pScriptVM->Run( g_Script_vscript_client );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
VScriptRunScript( "vscript_client", true );
|
||||||
VScriptRunScript( "mapspawn", false );
|
VScriptRunScript( "mapspawn", false );
|
||||||
|
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
RunAddonScripts();
|
||||||
|
#endif
|
||||||
|
|
||||||
VMPROF_SHOW( pszScriptLanguage, "virtual machine startup" );
|
VMPROF_SHOW( pszScriptLanguage, "virtual machine startup" );
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
@ -530,6 +703,12 @@ bool VScriptClientInit()
|
|||||||
CGWarning( 1, CON_GROUP_VSCRIPT, "VM Did not start!\n" );
|
CGWarning( 1, CON_GROUP_VSCRIPT, "VM Did not start!\n" );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
else
|
||||||
|
{
|
||||||
|
CGMsg( 0, CON_GROUP_VSCRIPT, "VSCRIPT CLIENT: Not starting because language is set to 'none'\n" );
|
||||||
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -571,28 +750,21 @@ public:
|
|||||||
virtual void LevelInitPreEntity( void )
|
virtual void LevelInitPreEntity( void )
|
||||||
{
|
{
|
||||||
m_bAllowEntityCreationInScripts = true;
|
m_bAllowEntityCreationInScripts = true;
|
||||||
#ifndef MAPBASE_VSCRIPT // Now initted in C_World
|
|
||||||
VScriptClientInit();
|
VScriptClientInit();
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void LevelInitPostEntity( void )
|
virtual void LevelInitPostEntity( void )
|
||||||
{
|
{
|
||||||
m_bAllowEntityCreationInScripts = false;
|
m_bAllowEntityCreationInScripts = false;
|
||||||
#ifdef MAPBASE_VSCRIPT
|
|
||||||
if (g_pScriptVM)
|
|
||||||
{
|
|
||||||
C_BasePlayer *pPlayer = C_BasePlayer::GetLocalPlayer();
|
|
||||||
if (pPlayer)
|
|
||||||
{
|
|
||||||
g_pScriptVM->SetValue( "player", pPlayer->GetScriptInstance() );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void LevelShutdownPostEntity( void )
|
virtual void LevelShutdownPostEntity( void )
|
||||||
{
|
{
|
||||||
|
#ifdef MAPBASE_VSCRIPT
|
||||||
|
g_ScriptNetMsg->LevelShutdownPreVM();
|
||||||
|
|
||||||
|
GetScriptHookManager().OnShutdown();
|
||||||
|
#endif
|
||||||
VScriptClientTerm();
|
VScriptClientTerm();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5,18 +5,32 @@ static char g_Script_vscript_client[] = R"vscript(
|
|||||||
//
|
//
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
|
|
||||||
|
local DoUniqueString = DoUniqueString
|
||||||
|
local DoDispatchParticleEffect = DoDispatchParticleEffect
|
||||||
|
|
||||||
function UniqueString( string = "" )
|
function UniqueString( string = "" )
|
||||||
{
|
{
|
||||||
return DoUniqueString( string.tostring() );
|
return DoUniqueString( "" + string );
|
||||||
}
|
}
|
||||||
|
|
||||||
function IncludeScript( name, scope = null )
|
function IncludeScript( name, scope = null )
|
||||||
{
|
{
|
||||||
if ( scope == null )
|
if ( !scope )
|
||||||
{
|
{
|
||||||
scope = this;
|
scope = this;
|
||||||
}
|
}
|
||||||
return ::DoIncludeScript( name, scope );
|
return ::DoIncludeScript( name, scope );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function DispatchParticleEffect( particleName, origin, angles, entity = null )
|
||||||
|
{
|
||||||
|
return DoDispatchParticleEffect( particleName, origin, angles, entity );
|
||||||
|
}
|
||||||
|
|
||||||
|
function ImpulseScale( flTargetMass, flDesiredSpeed )
|
||||||
|
{
|
||||||
|
return flTargetMass * flDesiredSpeed;
|
||||||
|
}
|
||||||
|
__Documentation.RegisterHelp( "ImpulseScale", "float ImpulseScale(float, float)", "Returns an impulse scale required to push an object." );
|
||||||
|
|
||||||
)vscript";
|
)vscript";
|
@ -27,6 +27,10 @@
|
|||||||
|
|
||||||
static IVEngineServer *g_pEngineServer = NULL;
|
static IVEngineServer *g_pEngineServer = NULL;
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
ConVar cl_worldlight_use_new_method("cl_worldlight_use_new_method", "1", FCVAR_NONE, "Uses the new world light iteration method which splits lights into multiple lists for each cluster.");
|
||||||
|
#endif
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
// Singleton exposure
|
// Singleton exposure
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -192,6 +196,83 @@ void CWorldLights::LevelInitPreEntity()
|
|||||||
g_pFullFileSystem->Close(hFile);
|
g_pFullFileSystem->Close(hFile);
|
||||||
|
|
||||||
DevMsg("CWorldLights: load successful (%d lights at 0x%p)\n", m_nWorldLights, m_pWorldLights);
|
DevMsg("CWorldLights: load successful (%d lights at 0x%p)\n", m_nWorldLights, m_pWorldLights);
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
// Now that the lights have been gathered, begin separating them into lists for each PVS cluster.
|
||||||
|
// This code is adapted from the soundscape cluster list code (see soundscape_system.cpp) and is intended to
|
||||||
|
// reduce frame drops in large maps which use dynamic RTT shadow angles.
|
||||||
|
CUtlVector<bbox_t> clusterbounds;
|
||||||
|
int clusterCount = g_pEngineServer->GetClusterCount();
|
||||||
|
clusterbounds.SetCount( clusterCount );
|
||||||
|
g_pEngineServer->GetAllClusterBounds( clusterbounds.Base(), clusterCount );
|
||||||
|
m_WorldLightsInCluster.SetCount(clusterCount);
|
||||||
|
for ( int i = 0; i < clusterCount; i++ )
|
||||||
|
{
|
||||||
|
m_WorldLightsInCluster[i].lightCount = 0;
|
||||||
|
m_WorldLightsInCluster[i].firstLight = 0;
|
||||||
|
}
|
||||||
|
unsigned char myPVS[16 * 1024];
|
||||||
|
CUtlVector<short> clusterIndexList;
|
||||||
|
CUtlVector<short> lightIndexList;
|
||||||
|
|
||||||
|
// Find the clusters visible from each light, then add it to those clusters' light lists
|
||||||
|
// (Also try to clip for radius if possible)
|
||||||
|
for (int i = 0; i < m_nWorldLights; ++i)
|
||||||
|
{
|
||||||
|
dworldlight_t *light = &m_pWorldLights[i];
|
||||||
|
|
||||||
|
// Assign the sun to its own pointer
|
||||||
|
if (light->type == emit_skylight)
|
||||||
|
{
|
||||||
|
m_iSunIndex = i;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
float radiusSq = light->radius * light->radius;
|
||||||
|
if (radiusSq == 0.0f)
|
||||||
|
{
|
||||||
|
// TODO: Use intensity instead?
|
||||||
|
radiusSq = FLT_MAX;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_pEngineServer->GetPVSForCluster( light->cluster, sizeof( myPVS ), myPVS );
|
||||||
|
for ( int j = 0; j < clusterCount; j++ )
|
||||||
|
{
|
||||||
|
if ( myPVS[ j >> 3 ] & (1<<(j&7)) )
|
||||||
|
{
|
||||||
|
float distSq = CalcSqrDistanceToAABB( clusterbounds[j].mins, clusterbounds[j].maxs, light->origin );
|
||||||
|
if ( distSq < radiusSq )
|
||||||
|
{
|
||||||
|
m_WorldLightsInCluster[j].lightCount++;
|
||||||
|
clusterIndexList.AddToTail(j);
|
||||||
|
lightIndexList.AddToTail(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
m_WorldLightsIndexList.SetCount(lightIndexList.Count());
|
||||||
|
|
||||||
|
// Compute the starting index of each cluster
|
||||||
|
int firstLight = 0;
|
||||||
|
for ( int i = 0; i < clusterCount; i++ )
|
||||||
|
{
|
||||||
|
m_WorldLightsInCluster[i].firstLight = firstLight;
|
||||||
|
firstLight += m_WorldLightsInCluster[i].lightCount;
|
||||||
|
m_WorldLightsInCluster[i].lightCount = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Now add each light index to the appropriate cluster's list
|
||||||
|
for ( int i = 0; i < lightIndexList.Count(); i++ )
|
||||||
|
{
|
||||||
|
int cluster = clusterIndexList[i];
|
||||||
|
int outIndex = m_WorldLightsInCluster[cluster].lightCount + m_WorldLightsInCluster[cluster].firstLight;
|
||||||
|
m_WorldLightsInCluster[cluster].lightCount++;
|
||||||
|
m_WorldLightsIndexList[outIndex] = lightIndexList[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
//DevMsg( "CWorldLights: Light clusters list has %i elements; Light index list has %i\n", m_WorldLightsInCluster.Count(), m_WorldLightsIndexList.Count() );
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
@ -208,6 +289,25 @@ bool CWorldLights::GetBrightestLightSource(const Vector &vecPosition, Vector &ve
|
|||||||
|
|
||||||
// Find the size of the PVS for our current position
|
// Find the size of the PVS for our current position
|
||||||
int nCluster = g_pEngineServer->GetClusterForOrigin(vecPosition);
|
int nCluster = g_pEngineServer->GetClusterForOrigin(vecPosition);
|
||||||
|
|
||||||
|
#ifdef MAPBASE
|
||||||
|
if (cl_worldlight_use_new_method.GetBool())
|
||||||
|
{
|
||||||
|
FindBrightestLightSourceNew( vecPosition, vecLightPos, vecLightBrightness, nCluster );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
FindBrightestLightSourceOld( vecPosition, vecLightPos, vecLightBrightness, nCluster );
|
||||||
|
}
|
||||||
|
|
||||||
|
//engine->Con_NPrintf(m_nWorldLights, "result: %d", !vecLightBrightness.IsZero());
|
||||||
|
return !vecLightBrightness.IsZero();
|
||||||
|
}
|
||||||
|
|
||||||
|
void CWorldLights::FindBrightestLightSourceOld( const Vector &vecPosition, Vector &vecLightPos, Vector &vecLightBrightness, int nCluster )
|
||||||
|
{
|
||||||
|
// Find the size of the PVS for our current position
|
||||||
int nPVSSize = g_pEngineServer->GetPVSForCluster(nCluster, 0, NULL);
|
int nPVSSize = g_pEngineServer->GetPVSForCluster(nCluster, 0, NULL);
|
||||||
|
|
||||||
// Get the PVS at our position
|
// Get the PVS at our position
|
||||||
@ -257,7 +357,7 @@ bool CWorldLights::GetBrightestLightSource(const Vector &vecPosition, Vector &ve
|
|||||||
|
|
||||||
delete[] pvs;
|
delete[] pvs;
|
||||||
|
|
||||||
return false;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Calculate square distance to this worldlight
|
// Calculate square distance to this worldlight
|
||||||
@ -308,7 +408,87 @@ bool CWorldLights::GetBrightestLightSource(const Vector &vecPosition, Vector &ve
|
|||||||
}
|
}
|
||||||
|
|
||||||
delete[] pvs;
|
delete[] pvs;
|
||||||
|
}
|
||||||
|
|
||||||
//engine->Con_NPrintf(m_nWorldLights, "result: %d", !vecLightBrightness.IsZero());
|
#ifdef MAPBASE
|
||||||
return !vecLightBrightness.IsZero();
|
void CWorldLights::FindBrightestLightSourceNew( const Vector &vecPosition, Vector &vecLightPos, Vector &vecLightBrightness, int nCluster )
|
||||||
}
|
{
|
||||||
|
// Handle sun
|
||||||
|
if (m_iSunIndex != -1)
|
||||||
|
{
|
||||||
|
dworldlight_t *light = &m_pWorldLights[m_iSunIndex];
|
||||||
|
|
||||||
|
// Calculate sun position
|
||||||
|
Vector vecAbsStart = vecPosition + Vector(0,0,30);
|
||||||
|
Vector vecAbsEnd = vecAbsStart - (light->normal * MAX_TRACE_LENGTH);
|
||||||
|
|
||||||
|
trace_t tr;
|
||||||
|
UTIL_TraceLine(vecPosition, vecAbsEnd, MASK_OPAQUE, NULL, COLLISION_GROUP_NONE, &tr);
|
||||||
|
|
||||||
|
// If we didn't hit anything then we have a problem
|
||||||
|
if(tr.DidHit())
|
||||||
|
{
|
||||||
|
// If we did hit something, and it wasn't the skybox, then skip
|
||||||
|
// this worldlight
|
||||||
|
if((tr.surface.flags & SURF_SKY) && (tr.surface.flags & SURF_SKY2D))
|
||||||
|
{
|
||||||
|
// Act like we didn't find any valid worldlights, so the shadow
|
||||||
|
// manager uses the default shadow direction instead (should be the
|
||||||
|
// sun direction)
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Iterate through all the worldlights
|
||||||
|
if ( nCluster >= 0 && nCluster < m_WorldLightsInCluster.Count() )
|
||||||
|
{
|
||||||
|
// find all soundscapes that could possibly attach to this player and update them
|
||||||
|
for ( int j = 0; j < m_WorldLightsInCluster[nCluster].lightCount; j++ )
|
||||||
|
{
|
||||||
|
int ssIndex = m_WorldLightsIndexList[m_WorldLightsInCluster[nCluster].firstLight + j];
|
||||||
|
dworldlight_t *light = &m_pWorldLights[ssIndex];
|
||||||
|
|
||||||
|
// Calculate square distance to this worldlight
|
||||||
|
Vector vecDelta = light->origin - vecPosition;
|
||||||
|
float flDistSqr = vecDelta.LengthSqr();
|
||||||
|
float flRadiusSqr = light->radius * light->radius;
|
||||||
|
|
||||||
|
// Skip lights that are out of our radius
|
||||||
|
if(flRadiusSqr > 0 && flDistSqr >= flRadiusSqr)
|
||||||
|
{
|
||||||
|
//engine->Con_NPrintf(i, "%d: out-of-radius (dist: %d, radius: %d)", i, sqrt(flDistSqr), light->radius);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Calculate intensity at our position
|
||||||
|
float flRatio = Engine_WorldLightDistanceFalloff(light, vecDelta);
|
||||||
|
Vector vecIntensity = light->intensity * flRatio;
|
||||||
|
|
||||||
|
// Is this light more intense than the one we already found?
|
||||||
|
if(vecIntensity.LengthSqr() <= vecLightBrightness.LengthSqr())
|
||||||
|
{
|
||||||
|
//engine->Con_NPrintf(i, "%d: too dim", i);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Can we see the light?
|
||||||
|
trace_t tr;
|
||||||
|
Vector vecAbsStart = vecPosition + Vector(0,0,30);
|
||||||
|
UTIL_TraceLine(vecAbsStart, light->origin, MASK_OPAQUE, NULL, COLLISION_GROUP_NONE, &tr);
|
||||||
|
|
||||||
|
if(tr.DidHit())
|
||||||
|
{
|
||||||
|
//engine->Con_NPrintf(i, "%d: trace failed", i);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
vecLightPos = light->origin;
|
||||||
|
vecLightBrightness = vecIntensity;
|
||||||
|
|
||||||
|
//engine->Con_NPrintf(i, "%d: set (%.2f)", i, vecIntensity.Length());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user