|
|
(189 intermediate revisions by 2 users not shown) |
Line 1: |
Line 1: |
− | __TOC__
| + | __NOTOC__ |
− | ===Contributions=== | + | ==Wiki== |
− | :*[[UE2:Using_the_UT2004_mod_system|Using the UT2004 Mod System]] | + | ====General==== |
| + | :[[User:00zX/Setting_Up_Your_UScript_Environment|Setting Up Your UScript Environment]] |
| + | ====UE3==== |
| + | :[[User:00zX/Using_The_Unreal_Engine_3_Preprocessor|Using The Unreal Engine 3 Preprocessor]] |
| + | ====UE2.5==== |
| + | :[[UE2:Using_the_UT2004_mod_system|Using The UT2004 Mod System]] |
| + | ====Rants==== |
| + | [[User:00zX/Rants|Rants]] |
| | | |
− | ===Contact Me=== | + | ==Work== |
− | ======IRC====== | + | ====Unreal Development Kit==== |
− | _00zX on [irc://irc.enterthegame.com EnterTheGame]
| + | :[[User:00zX/Plugin_(UDK)|UDK: ReDeX]] ''Status:'' '''Testing''' |
− | ;* [irc://irc.enterthegame.com/unrealscript #unrealscript on EnterTheGame]
| + | :''Description:'' PC Framework for UDK, its a combination of a framework and macros along with associated parser functionality. |
− | ;* [irc://irc.enterthegame.com/unrealwiki #unrealwiki on EnterTheGame]
| + | ::''GamedGFx:''' Scaleform interface along with object saving/loading. |
− | ;* [irc://irc.enterthegame.com/unrealed #unrealed on EnterTheGame]
| + | ::'''GamedEx:''' GPAK Game framework built using Redux, support for many features; round based play, archetype systems, additions to particles, materials, etc. |
− | ;* [irc://irc.enterthegame.com/chaoticdreams #chaoticdreams on EnterTheGame]
| + | ::'''GamedCaster:''' First Person Multiplayer PvP. |
− | ;* [irc://irc.enterthegame.com/ausgamers #ausgamers on EnterTheGame]
| + | |
− | | + | |
− | ======Other/Profiles======
| + | |
− | [[Special:Emailuser/00zX|E-mail 00zX]] or on
| + | |
− | ;* [http://delicious.com/00zX delicious]
| + | |
− | ;* [http://photobucket.com/00zX Photobucket]
| + | |
− | | + | |
− | --------<br><br><br><br>
| + | |
− | ==Proposal - Noir theme with highlighter adjustments==
| + | |
− | | + | |
− | ===Code Noir Redex===
| + | |
− | :stylish - userstyle -[[User:00zX|00zX]] 20:41, 29 March 2009 (UTC) | + | |
− | <source lang=css>
| + | |
− | @-moz-document domain(wiki.beyondunreal.com) {
| + | |
− | | + | |
− | /*================================================================================*/
| + | |
− | /** 00zX_CODENOIR.CSS */
| + | |
− | /*================================================================================*/
| + | |
− | /* #bcb936 - UC3 Gold */
| + | |
− | /* #66bcd9 - UnrealEd Blue */
| + | |
− | /* #62613a - ol'crash */
| + | |
− | /* #b8b634 - ol'guard */
| + | |
− | /* #bfbe97 - paste */
| + | |
− | /* #00c000 - Comment Green */
| + | |
− | | + | |
− | /* #090909 - Noir */
| + | |
− | /* #151515 - Full Moon */
| + | |
− | /* #8f8f8f - Grey Metal */
| + | |
− | /* #575757 - Dark Metal */
| + | |
− | | + | |
− | /* #adcc63 - light green */
| + | |
− | /* #99aadd - light blue metal / lilac */
| + | |
− | /* #59939c - greyish blue light / teal */
| + | |
− | /* #494949 - midish grey metal */
| + | |
− | /* #7b749b - purple metal*/
| + | |
− | | + | |
− | /* #257ec2 - shell beach */
| + | |
− | /* #fd3e1c - oraed */
| + | |
− | /* #ffcc00 - yellow ambox */
| + | |
− | /* #0a44aa - H2 blue deep */
| + | |
− | /* #c4bfb2 - orange off white*/
| + | |
− | | + | |
− | /* #b8b634 - welloy */
| + | |
− | /* #222222 - vert */
| + | |
− | /* #ff6600 - orange */
| + | |
− | /* #c3c3c3 - grey */
| + | |
− | /* #257ec2 - moire blue*/
| + | |
− | /*================================================================================*/
| + | |
− | | + | |
− | /* UE1 namespace content */
| + | |
− | .ns-102 #content, .ns-103 #content {
| + | |
− | /*background: #eff7ff url(/w/images/UE1Background.png) top right no-repeat;*/
| + | |
− | border-color: #66bcd9 !important; border-width: 1px !important;
| + | |
− | }
| + | |
− | .ns-102 h1, .ns-103 h1 {
| + | |
− | color: #62613a !important; border-bottom: #66bcd9 solid 1px !important;
| + | |
− | }
| + | |
− | .ns-102 h4, .ns-103 h4 {
| + | |
− | color: #66bcd9 !important;
| + | |
− | }
| + | |
− | .ns-102 #highlighted-source, .ns-103 #highlighted-source{
| + | |
− | border: #494949 dashed 1px !important;
| + | |
− | }
| + | |
− | span.kw10{}
| + | |
− | | + | |
− | /* UE2 namespace content */
| + | |
− | .ns-104 #content, .ns-105 #content {
| + | |
− | border-color: #257ec2 !important; border-width: 1px !important;
| + | |
− | }
| + | |
− | .ns-104 h1, .ns-105 h1 {
| + | |
− | color:#62613a !important; border-bottom: #257ec2 solid 1px !important;
| + | |
− | }
| + | |
− | .ns-104 #portlet a:visited, .ns-105 #portlet a:visited{
| + | |
− | background: inherit !important; border-color: #257ec2 !important;
| + | |
− | }
| + | |
− | .ns-104 #highlighted-source, .ns-105 #highlighted-source{
| + | |
− | border: #257ec2 dashed 1px !important;
| + | |
− | }
| + | |
− | span.kw10{}
| + | |
− | | + | |
− | /* UE3 namespace content */ /* #fd3e1c - Old Red */
| + | |
− | .ns-106 #content, .ns-107 #content {
| + | |
− | border-color: #bcb936 !important; border-width: 1px !important;
| + | |
− | }
| + | |
− | .ns-106 h1, .ns-107 h1 {
| + | |
− | color:#62613a !important; border-bottom: #bcb936 solid 1px !important;
| + | |
− | }
| + | |
− | #portlet a:visited, #portlet a:visited{
| + | |
− | background: inherit !important; border-color: #bcb936 !important;
| + | |
− | }
| + | |
− | .ns-106 #highlighted-source, .ns-107 #highlighted-source{
| + | |
− | border: #bcb936 dashed 1px !important;
| + | |
− | }
| + | |
− | span.kw10{}
| + | |
− | | + | |
− | /* Legacy namespace content */
| + | |
− | .ns-100 #content, .ns-101 #content {
| + | |
− | border-color: #7b749b !important; border-width: 1px !important;
| + | |
− | }
| + | |
− | .ns-100 h1, .ns-101 h1 {
| + | |
− | color:#62613a !important; border-bottom: #7b749b solid 1px !important;
| + | |
− | }
| + | |
− | .ns-100 h4, .ns-101 h4 {
| + | |
− | color: #7b749b !important;
| + | |
− | }
| + | |
− | .ns-100 #highlighted-source, .ns-101 #highlighted-source{
| + | |
− | border: #7b749b dashed 1px !important;
| + | |
− | }
| + | |
− | span.kw10{}
| + | |
− | | + | |
− | tbody tr table tbody tr td ul li:hover{ text-decoration: none !important; }
| + | |
− | | + | |
− | #siteNotice,
| + | |
− | #siteNotice a{ background: inherit !important; }
| + | |
− | | + | |
− | #recent-edits,
| + | |
− | #recent-edits tbody,
| + | |
− | #recent-edits tbody tr,
| + | |
− | #recent-edits tbody tr th{
| + | |
− | background: #494949 !important;
| + | |
− | }
| + | |
− | #recent-edits tbody tr th{
| + | |
− | color:#090909 !important;
| + | |
− | font-family: arial, trebuchet !important;
| + | |
− | font: 100 normal 130%/100% "Arial Narrow", sans-serif !important;
| + | |
− | }
| + | |
− | | + | |
− | span.editsection,
| + | |
− | h3 #editsection, h4 #editsection{display: none !important;}
| + | |
− | | + | |
− | /* (codenoir) */
| + | |
− | div#bodyContent pre{
| + | |
− | border: #494949 dotted 1px !important; background: #090909 !important;
| + | |
− | color: #ffffff !important;
| + | |
− | }
| + | |
− | div.source-uscript pre{
| + | |
− | border: white solid 0px !important; background: none !important;
| + | |
− | color: #ffffff !important;
| + | |
− | }
| + | |
− | | + | |
− | /* .code{ padding-left: -0.025em !important; background: none !important; border: #222222 dotted 1px !important;
| + | |
− | color: #222222 !important;
| + | |
− | }*/
| + | |
− | | + | |
− | code{ border: none !important;/* background: inherit !important;*/
| + | |
− | background: none !important;
| + | |
− | color: white !important;/*#000000*/
| + | |
− | font: 100 normal 10pt "Segeo UI", sans-serif !important;
| + | |
− | }
| + | |
− | | + | |
− | #highlighted-source{
| + | |
− | border: #494949 dashed 1px !important;
| + | |
− | background: #575757 !important; color:#ffffff !important;
| + | |
− | }
| + | |
− | | + | |
− | /* Uscript Highlighter */
| + | |
− | /* span.kw9{} kw = keyword */
| + | |
− | /* span.co1{} co = comment */
| + | |
− | span.kw1{color: #66bcd9 !important;}
| + | |
− | span.kw4{color: #66bcd9 !important;}
| + | |
− | span.kw5{color: #66bcd9 !important;}/*const*/
| + | |
− | span.kw6{color: #257ec2 !important; font-style: italic !important;}
| + | |
− | span.kw8{color: white !important;}
| + | |
− | span.kw9{color: white !important;}
| + | |
− | span.br0{color: white !important;}
| + | |
− | span.co1{color: #00c000 !important;}
| + | |
− | span.co2{color: #8f8f8f !important; font-weight: bolder !important;}
| + | |
− | span.colMULTI{color: #00c000 !important;}
| + | |
− | span.sy0{color: #ff6600 !important;}
| + | |
− | span.me1{color: #66bcd9 !important;}
| + | |
− | span.kw10{color: white !important;} /* */
| + | |
− | | + | |
− | html > div#bodyContent > div.highlighted-source > div.source-uscript pre{
| + | |
− | border: none !important;
| + | |
− | }
| + | |
− | | + | |
− | /* CSS Highlighter */
| + | |
− | span.re0{}
| + | |
− | span.re2{color: #8f8f8f !important; font-style: italic !important;}
| + | |
− | span.re3{color: #ff6600 !important;}
| + | |
− | | + | |
− | div#bodyContent table.list tbody{background: none !important; }
| + | |
− | tbody, table.list { background: none !important; }
| + | |
− | div#bodyContent,
| + | |
− | div#bodyContent div { background: none !important; }
| + | |
− | /*================================================================================*/
| + | |
− | /** MONOBOOK-COMMON-NOIR.CSS */
| + | |
− | /*================================================================================*/
| + | |
− | a:link{ color: #99c9ff !important; text-decoration: none !important;
| + | |
− | background: none !important; line-height: 0.6em !important;
| + | |
− | }
| + | |
− | a:visited{ color: #959595 !important; font-style: italic !important;}
| + | |
− | a:hover{ color: #59939c !important;
| + | |
− | text-decoration: none !important; line-height: 0.6em !important;
| + | |
− | }
| + | |
− | b { color:#c4bfb2 !important; font-weight: 500 !important;}/*bolder*/
| + | |
− | div { color: white !important; background: #090909 !important; }
| + | |
− | table { color: white !important; background: inherit !important; }
| + | |
− | body { font-size-adjust:none !important;
| + | |
− | font-style:normal !important;
| + | |
− | font-variant:normal !important;
| + | |
− | font-weight: 150 !important;/*normal*/
| + | |
− | line-height:normal !important;
| + | |
− | }
| + | |
− | | + | |
− | #pbody,#pbody a{ background: inherit !important; }
| + | |
− | #pbody a{ border: 1px solid #99aadd !important; }
| + | |
− | | + | |
− | /*__TOC__*/
| + | |
− | #toc { background-color: #494949 !important; border: 1px solid #59939c !important; }
| + | |
− | #toctitle{ background: none !important; font-weight: 350 !important;
| + | |
− | text-decoration: none !important;
| + | |
− | }
| + | |
− | | + | |
− | #div.toctitle h2{background: inherit !important; text-decoration: none !important;}
| + | |
− | | + | |
− | #content { background: #151515 !important;
| + | |
− | font-family: arial, trebuchet !important;
| + | |
− | font-size: 11pt !important;/*10*/
| + | |
− | /*border: 0 !important;*/
| + | |
− | }
| + | |
− | | + | |
− | #contentSub, #bodyContent,
| + | |
− | div.content div,
| + | |
− | div.bodyContent div{ background: none !important;}
| + | |
− | div.thumb{ background: inherit !important; }
| + | |
− | div.plainlinks,
| + | |
− | div.noprint{ background: #494949 !important; }
| + | |
− | | + | |
− | dt{ color: #bfbe97 !important;}
| + | |
− | dl dt{}
| + | |
− | dd b{ color: #59939c !important;}
| + | |
− | | + | |
− | #navbox-header{background: #494949 !important;}
| + | |
− | | + | |
− | /* mediawiki */
| + | |
− | /* tabs? */
| + | |
− | #p-cactions li.selected, #p-cactions li.selected a,
| + | |
− | #p-cactions li a:hover,
| + | |
− | #p-cactions li a:visited{background: none !important;}
| + | |
− | | + | |
− | ul#preftoc{}
| + | |
− | | + | |
− | #mw-headline { background: inherit !important; }
| + | |
− | h4 span.mwheadline{ text-indent: 0.1em !important;}
| + | |
− | | + | |
− | div.searchresult,
| + | |
− | div.mw-search-result-data,
| + | |
− | div#bodyContent ul.mw-searchresults{ background: inherit !important; }
| + | |
− | | + | |
− | table.ambox { color: #c4bfb2 !important;background: inherit !important; }
| + | |
− | #infobox{ border: #090909 solid 3px !important;}
| + | |
− | table.infobox, div.infobox {
| + | |
− | /* background: #494949 !important;*/
| + | |
− | border: 1px solid white !important;
| + | |
− | padding: 1em;
| + | |
− | }
| + | |
− | | + | |
− | h1, h2, h3, h4 {
| + | |
− | background: none !important; /*background: #151515 !important;*/
| + | |
− | font-family: arial, trebuchet !important;
| + | |
− | font: 100 normal 130%/100% "Arial Narrow", sans-serif !important;
| + | |
− | border-bottom: none !important;
| + | |
− | }
| + | |
− | | + | |
− | h1 { color: #7b749b !important; border-bottom: #7b749b solid 1px !important;
| + | |
− | font: 500 normal 160%/180% "Arial Narrow", sans-serif !important;
| + | |
− | }
| + | |
− | h2 { color:#99aadd !important; border-bottom: 1px solid #99aadd !important;
| + | |
− | font: 300 normal 140%/120% "Arial Narrow", sans-serif !important;
| + | |
− | /* line-height: 0.6em !important;
| + | |
− | letter-spacing: 0.025em !important; word-spacing: 0.4em !important;*/
| + | |
− | }
| + | |
− | h3, h4 { padding-left: 0.24em;/*text-indent: 0.2em !important;*/
| + | |
− | }
| + | |
− | h4 { color: #257ec2 !important;
| + | |
− | font: 100 normal 110%/100% "Arial Narrow", sans-serif !important;
| + | |
− | }
| + | |
− | h6 { color: white !important;}
| + | |
− | hr { background: #151515 !important; color: #909;
| + | |
− | margin-top: 1em; margin-bottom: 1em;
| + | |
− | }
| + | |
− | li,
| + | |
− | ul { background: inherit !important;
| + | |
− | }
| + | |
− | | + | |
− | /*================================================================================*/
| + | |
− | /**make a few corners round, only supported by moz/firefox/other gecko browsers for now */
| + | |
− | /*================================================================================*/
| + | |
− | #content {
| + | |
− | -moz-border-radius-topleft: 0.5em !important;
| + | |
− | -moz-border-radius-bottomleft: 0.5em !important;
| + | |
− | }
| + | |
− | /* div#bodyContent pre, */
| + | |
− | table.infobox, div.infobox, #catlinks, #toc, .ambox {
| + | |
− | -moz-border-radius: 6px !important;
| + | |
− | }
| + | |
− | }
| + | |
− | </source>
| + | |
− | <br><br>
| + | |
− | <br><br>
| + | |
− | ==Proposal - Replication==
| + | |
| | | |
− | ===Replication=== | + | :[[User:00zX/Project Silky_(UDK)|UDK: Project Silky]] ''Status:'' '''Alpha''' (on hold) |
− | -[[User:00zX|00zX]] 06:24, 31 March 2009 (UTC)<br>
| + | ====Unreal Tournament 3==== |
− | :[[Replication]]/[[Replication_(computer_science)]] | + | :[[User:00zX/GameDex Framework_(UT3)|UT3: GameDex Framework]] ''Status:'' '''Beta''' (on hold) |
− | ::''Declaring Replication'' using the[[Legacy:Replication_Block|Replication Block]]
| + | ::[[User:00zX/GameDex_Framework_(UT3)#Newtators (Mutator pack)|Newtators-v1.9e]] ''Status:'' '''Point Release''' |
− | ::''Function Replication'' using the replication block?
| + | ::[[User:00zX/GameDex_Framework_(UT3)#Attrition (Gametype)|Attrition-v0.5pb]] ''Status:'' '''Public Beta''' |
− | :: Booleans Declared in actor that are useful in replication | + | ====Unreal Tournament 2004==== |
− | http://wiki.beyondunreal.com/Introduction_to_replication# | + | :[[User:00zX/UC2004_(UT2004)|UT2004: Unreal Championship 2004]] ''Status:'' '''Beta''' (dissolved) |
| + | :[http://www.divshare.com/download/16967446-918|UT2004: Turbo Instagib] ''Status:'' '''Beta''' |
| + | :[http://www.divshare.com/download/16967454-2c0|UT2004: CrapLink]] ''Status:'' '''Beta''' |
| <br> | | <br> |
| | | |
− | :Concept of servers and clients.
| + | ==Highlighters== |
− | | + | |
− | ===Replication Block=== | + | |
− | [[UE3:Actor_(UT3)]] - link to replication block<br>
| + | |
− | Previously in UT200x '''Reliable''' and '''Unreliable''' were used as part of the [[Legacy:Replication_Block|replication block]] as of [[Unreal Engine 3]] this is no longer the case with the keywords becoming [[Functions#Network_modifiers|function modifiers]].
| + | |
− | | + | |
− | '''UT200x'''
| + | |
− | | + | |
− | '''replication'''
| + | |
− | '''{'''
| + | |
− | ''reliable/unreliable'' '''if (''' ''replication condition'' ''')'''
| + | |
− | ''identifiers'';
| + | |
− | '''}'''
| + | |
− | | + | |
− | '''UT3'''
| + | |
− | | + | |
− | '''replication'''
| + | |
− | '''{'''
| + | |
− | '''if (''' ''replication condition'' ''')'''
| + | |
− | ''identifiers'';
| + | |
− | '''}'''
| + | |
− | | + | |
− | : ''Identifiers'' can be of many types, certain types however arnt allowed like dynamic arrays.
| + | |
− | | + | |
− | '''Explain Why'''
| + | |
− | can loose sync! it is possible to crosscheck dynamic arrays but it would come at a cost.
| + | |
− | | + | |
− | ====Using the Replication Block====
| + | |
− | | + | |
− | | + | |
− | =====Actor Replication=====
| + | |
− | | + | |
− | =====Variable Value Replication=====
| + | |
− | | + | |
− | <uscript>
| + | |
− | var() float NewEquipTime;
| + | |
− | var() float NewPutDownTime;
| + | |
− | | + | |
− | replication
| + | |
− | {
| + | |
− | if(bNetDirty && (Role == ROLE_Authority) && bNetInitial)
| + | |
− | NewEquipTime, NewPutDownTime;
| + | |
− | }
| + | |
− | </uscript>
| + | |
− | | + | |
− | **Repnotify
| + | |
− | | + | |
− | *Function call replication*
| + | |
− | : Like replicated variables, the replication of a function call can be tied to certain conditions. In Unreal Engine 1 and 2 this condition is specified via the replication block and typically involves comparing the actor's Role to the value ROLE_Authority, Unreal Engine 3 provides the special function modifiers client and server instead.
| + | |
− | | + | |
− | * Using [[Functions#Network_modifiers|Network modifiers]] for Functions
| + | |
− | | + | |
− | '''Reliable'''
| + | |
− | '''Unreliable'''
| + | |
− | | + | |
− | ====Client====
| + | |
− | <uscript>
| + | |
− | /** Sets the clients weapon to use the replicated variables */
| + | |
− | reliable client function SetWeapProps(UTWeapon W)
| + | |
− | {
| + | |
− | W.EquipTime = NewEquipTime;
| + | |
− | W.PutDownTime = NewPutDownTime;
| + | |
− | }</uscript>
| + | |
− | | + | |
− | ====Server====
| + | |
− | <uscript>
| + | |
− | /** Gets the times from the weapons and sets them to the replicated variables */
| + | |
− | reliable server function GetWeapProps(UTWeapon W)
| + | |
− | {
| + | |
− | NewEquipTime = W.default.EquipTime * 0.68;
| + | |
− | NewPutDownTime = W.default.PutDownTime * 0.70;
| + | |
− | }</uscript>
| + | |
− | | + | |
− | ===Relevance===
| + | |
− | | + | |
− | ===Role and RemoteRole===
| + | |
− | | + | |
− | Definition
| + | |
− | :The [[Actor]] class defines the NetRole enumeration and two variables, [[Role and RemoteRole]], as follows:
| + | |
− | | + | |
− | :*[[UE3:Actor_(UT3)#ENetRole]]
| + | |
− | | + | |
− | :*[[UE1:Actor_enums_(UT)#ENetMode]]
| + | |
− | :*[[UE2:Actor_enums_(U2)#ENetRole]]
| + | |
− | :*[[UE2:Actor_enums_(UT2003)#ENetRole]]
| + | |
− | :*[[UE2:Actor_enums_(U2XMP)#ENetMode]]
| + | |
− | :*[[UE2:Actor_enums_(UT2004)#ENetRole]]
| + | |
| | | |
| + | ===UnrealWiki - Code Noir Redex Theme=== |
| + | [[File:Monobook-noir-alpha3.gif|700px|thumb|left]] |
| + | ====Status: Beta==== |
| + | To Install copy the contents of the following page into your own ''''User:[name]/monobook.css'''' page. |
| + | ::[[User:00zX/monobook.css]] |
| + | ::[http://jigsaw.w3.org/css-validator/validator?uri=http%3A%2F%2Fwiki.beyondunreal.com%2FUser%3A00zX%2Fmonobook.css&profile=css21&usermedium=all&warning=1&lang=en W3C CSS Validator] |
| + | ::[http://i10.photobucket.com/albums/a123/OlympusMons/CodeNoirRedeX.png High Resolution Image]<br> |
| + | =====Features===== |
| + | :Dark Theme |
| + | :High Contrast |
| + | :Improved Readability |
| + | :Highlighter adjustments for UScript, CSS and XML |
| + | :Different coloured borders per GameNameSpace |
| + | :Curved Borders in supporting browsers |
| + | =====Known Issues===== |
| + | :Edit/Input boxes are still black text on white. |
| + | :Profile settings page unreadable. |
| + | <br><br><br> |
| <br> | | <br> |
− | <uscript>
| |
− | enum ENetRole
| |
− | {
| |
− | ROLE_None, // No role at all.
| |
− | ROLE_SimulatedProxy, // Locally simulated proxy of this actor.
| |
− | ROLE_AutonomousProxy, // Locally autonomous proxy of this actor.
| |
− | ROLE_Authority, // Authoritative control over the actor.
| |
− | };
| |
− | var ENetRole RemoteRole, Role;
| |
− | </uscript>
| |
− | <br>
| |
− | ====usage:====
| |
− | <uscript>
| |
− | if (Role == ROLE_Authority)
| |
− | {
| |
− | // This is the authorative copy of this actor, it was spawned on this machine.
| |
− | // It is not a guarantee that we are on the server or in single player!
| |
− | }
| |
| | | |
− | if (Role < ROLE_Authortity)
| + | ==Contact Me== |
− | {
| + | ====IRC==== |
− | // This is a non-authorative copy of this actor that was replicated
| + | _00zX on [irc://irc.enterthegame.com EnterTheGame] |
− | // from the server. In other words, we must be on a client.
| + | ;* [irc://irc.enterthegame.com/unrealscript #unrealscript on EnterTheGame] |
− | }</uscript>
| + | ;* [irc://irc.enterthegame.com/beyondunreal #beyondunreal on EnterTheGame] |
− | <br>
| + | _00zX on [irc://irc.gamesurge.net GameSurge] |
− | As in the replication block of Actor.uc UT3
| + | ;* [irc://irc.irc.gamesurge.net/udkc #udkc on GameSurge] |
− | <uscript>
| + | |
− | // Physics
| + | |
− | if( (!bSkipActorPropertyReplication || bNetInitial) && bReplicateMovement
| + | |
− | && ((RemoteRole == ROLE_SimulatedProxy) && (bNetInitial || bUpdateSimulatedPosition)) )
| + | |
− | </uscript>
| + | |
| | | |
− | ===NetMode=== | + | ====Other/Profiles==== |
− | Definition
| + | [[Special:Emailuser/00zX|E-mail 00zX]] or on |
− | :The [[UE3:WorldInfo_(UT3)|WorldInfo]] (previously Level Class [ut2kx]) class defines the [[UE3:WorldInfo_(UT3)#ENetMode|NetMode]] enumeration and two variables, [[Role and RemoteRole]], as follows:
| + | ;* MonsOlympus @ [www.pastebin.org] |
− | | + | |
− | :*[[UE3:WorldInfo_(UT3)#ENetMode]]
| + | |
− | :**[[UE3:WorldInfo_internal_variables_(UT3)]]
| + | |
− | | + | |
− | :*In [[LevelInfo]] for most Unreal Engine games pre UT3/GOW
| + | |
− | :**[[UE1:LevelInfo_(UT)#ENetMode]]
| + | |
− | :**[[UE2:LevelInfo_(U2)#ENetMode]]
| + | |
− | :**[[UE2:LevelInfo_(UT2003)#ENetMode]]
| + | |
− | :**[[UE2:LevelInfo_(U2XMP)#ENetMode]]
| + | |
− | :**[[UE2:LevelInfo_(UT2004)#ENetMode]]
| + | |
− | | + | |
− | | + | |
− | <uscript>
| + | |
− | var enum ENetMode
| + | |
− | {
| + | |
− | NM_Standalone, // Standalone game.
| + | |
− | NM_DedicatedServer, // Dedicated server, no local client.
| + | |
− | NM_ListenServer, // Listen server, local client+server.
| + | |
− | NM_Client // Client only, no local server.
| + | |
− | } NetMode;
| + | |
− | </uscript>
| + | |
− | | + | |
− | '''Standalone game'''
| + | |
− | '''Dedicated server, no local client'''
| + | |
− | '''Listen server, local client+server'''
| + | |
− | '''Client only, no local server'''
| + | |
− | | + | |
− | =====Examples=====
| + | |
− | ====usage:====
| + | |
− | <uscript>
| + | |
− | simulated event PostBeginPlay()
| + | |
− | {
| + | |
− | if(WorldInfo.NetMode != NM_DedicatedServer)
| + | |
− | {
| + | |
− | // Code here will only be executed on Listen servers and game clients.
| + | |
− | }
| + | |
− |
| + | |
− | if(WorldInfo.NetMode == NM_DedicatedServer)
| + | |
− | {
| + | |
− | // Code here will only be executed on a server.
| + | |
− | }
| + | |
− | }</uscript>
| + | |
− | or similarly like in the Role and RemoteRole example:<br> | + | |
− | <uscript>
| + | |
− | simulated event PostBeginPlay()
| + | |
− | {
| + | |
− | if (WorldInfo.NetMode < NM_DedicatedServer)
| + | |
− | {
| + | |
− | // Code here will only be executed on Listen servers and game clients.
| + | |
− | }
| + | |
− | | + | |
− | if (WorldInfo.NetMode > NM_DedicatedServer)
| + | |
− | {
| + | |
− | // Code here will only be executed on a server or standalone client.
| + | |
− | }
| + | |
− | }</uscript>
| + | |
− | | + | |
− | | + | |
− | ==Useful Replication Properties==
| + | |
− | | + | |
− | ===UT3 actor.uc===
| + | |
− | <uscript>
| + | |
− | // Networking flags
| + | |
− | var const bool bNetTemporary; // Tear-off simulation in network play.
| + | |
− | var const bool bOnlyRelevantToOwner; // this actor is only relevant to its owner. If this flag is changed during play, all non-owner channels would need to be explicitly closed.
| + | |
− | var transient bool bNetDirty; // set when any attribute is assigned a value in unrealscript, reset when the actor is replicated
| + | |
− | var bool bAlwaysRelevant; // Always relevant for network.
| + | |
− | var bool bReplicateInstigator; // Replicate instigator to client (used by bNetTemporary projectiles).
| + | |
− | var bool bReplicateMovement; // if true, replicate movement/location related properties
| + | |
− | var bool bSkipActorPropertyReplication; // if true, dont replicate actor class variables for this actor
| + | |
− | var bool bUpdateSimulatedPosition; // if true, update velocity/location after initialization for simulated proxies
| + | |
− | var bool bTearOff; // if true, this actor is no longer replicated to new clients, and
| + | |
− | // is "torn off" (becomes a ROLE_Authority) on clients to which it was being replicated.
| + | |
− | var bool bOnlyDirtyReplication; // if true, only replicate actor if bNetDirty is true - useful if no C++ changed attributes (such as physics)
| + | |
− | // bOnlyDirtyReplication only used with bAlwaysRelevant actors
| + | |
− | | + | |
− | | + | |
− | /** Demo recording variables */
| + | |
− | var transient bool bDemoRecording; /** set when we are currently replicating this Actor into a demo */
| + | |
− | var transient bool bClientDemoRecording; /** set when we are recording a clientside demo */
| + | |
− | var transient bool bRepClientDemo; /** set if remote client is recording a clientside demo */
| + | |
− | var bool bDemoOwner; // Demo recording driver owns this actor.
| + | |
− | | + | |
− | /** Should replicate initial rotation. This property should never be changed during execution, as the client and server rely on the default value of this property always being the same. */
| + | |
− | var const bool bNetInitialRotation;
| + | |
− | | + | |
− | /** If true, never replicate rotation */
| + | |
− | var bool bNeverReplicateRotation;
| + | |
− | | + | |
− | var bool bReplicateRigidBodyLocation; // replicate Location property even when in PHYS_RigidBody
| + | |
− | var bool bKillDuringLevelTransition; // If set, actor and its components are marked as pending kill during seamless map transitions
| + | |
− | /** whether we already exchanged Role/RemoteRole on the client, as removing then readding a streaming level
| + | |
− | * causes all initialization to be performed again even though the actor may not have actually been reloaded
| + | |
− | */
| + | |
− | var const bool bExchangedRoles;
| + | |
− | </uscript>
| + | |
− | | + | |
− | | + | |
− | =====booleans=====
| + | |
− | * <code>(Level.NetMode == NM_Client && bNetOwner)</code> – owner clients (special case of client where the local player is the Owner of the actor in question)
| + | |
− | | + | |
− | '''UT2004'''
| + | |
− | | + | |
− | NetUpdateFrequency
| + | |
− | | + | |
− | NetUpdateFrequency is another variable useful in replication. It effectively causes an otherwise relevant (not useful when the actor is not relevant) actor to be relevant NetUpdateFrequency times per second. This is useful when the data changes frequently but you only want periodic updates. For example, PlayerReplicationInfo contains a lot of data about the client. Stuff like the various player's pings may change quite frequently, and having the client keep track of such information would be quite a network hog. But since PlayerReplicationInfo has a NetUpdateFrequency of 2, it is only updated twice a second, which is much nicer for that player's bandwidth. The list of the current NetUpdateFrequency's for all UT classes are listed below:
| + | |
− | | + | |
− | Actor - 100 Hz (times per second)<br>
| + | |
− | ZoneInfo - 4 Hz<br>
| + | |
− | GameReplicationInfo - 4 Hz<br>
| + | |
− | PlayerReplicationInfo - 2 Hz<br>
| + | |
− | Inventory - 8 Hz<br>
| + | |
− | | + | |
− | ===Using Replication===
| + | |
− | <uscript>
| + | |
− | class UT_MDI_Weapon extends UT_MDI;
| + | |
− | | + | |
− | /** How long does it take to Equip this weapon */
| + | |
− | var() repnotify float NewEquipTime;
| + | |
− | | + | |
− | /** How long does it take to put this weapon down */
| + | |
− | var() repnotify float NewPutDownTime;
| + | |
− | | + | |
− | /** Weapon class so we can check owner is right type and set vars */
| + | |
− | var UTWeapon Weap;
| + | |
− | | + | |
− | /** Replication Block */
| + | |
− | replication
| + | |
− | {
| + | |
− | if(bNetDirty && (Role == ROLE_Authority) && bNetInitial)
| + | |
− | NewEquipTime, NewPutDownTime;
| + | |
− | }
| + | |
− | | + | |
− | /** Gets the times from the weapons and sets them to the replicated variables */
| + | |
− | reliable server function GetWeapProps(UTWeapon W)
| + | |
− | {
| + | |
− | NewEquipTime = W.default.EquipTime * 0.68;
| + | |
− | NewPutDownTime = W.default.PutDownTime * 0.70;
| + | |
− | }
| + | |
− | | + | |
− | /** Sets the clients weapon to use the replicated variables */
| + | |
− | reliable client function SetWeapProps(UTWeapon W)
| + | |
− | {
| + | |
− | W.EquipTime = NewEquipTime;
| + | |
− | W.PutDownTime = NewPutDownTime;
| + | |
− | }
| + | |
− | | + | |
− | /** Make sure we have an owner and its the right type before moving on */
| + | |
− | simulated event PostBeginPlay()
| + | |
− | {
| + | |
− | local int i;
| + | |
− | | + | |
− | if(Owner == None || cUseforWeaps.length <= 0)
| + | |
− | Destroy();
| + | |
− | | + | |
− | Weap = UTWeapon(Owner);
| + | |
− | if(Weap != None)
| + | |
− | {
| + | |
− | if(WorldInfo.NetMode != NM_Client)
| + | |
− | GetWeapProps(Weap);
| + | |
− | | + | |
− | SetTimer(0.01, false, 'SetPropsTimer');
| + | |
− | }
| + | |
− | else
| + | |
− | Destroy();
| + | |
− | }
| + | |
− | | + | |
− | function SetPropsTimer()
| + | |
− | {
| + | |
− | SetWeapProps(Weap);
| + | |
− | }
| + | |
− | | + | |
− | defaultproperties
| + | |
− | {
| + | |
− | //remove all from array
| + | |
− | //cUseforWeapons(0)=none
| + | |
− | | + | |
− | RemoteRole=ROLE_SimulatedProxy
| + | |
− | bAlwaysRelevant=True
| + | |
− | }
| + | |
− | </uscript><br>
| + | |
− | <uscript>
| + | |
− | if(Weap != None)
| + | |
− | {
| + | |
− | if(WorldInfo.NetMode != NM_Client)
| + | |
− | GetWeapProps(Weap);
| + | |
− | | + | |
− | SetTimer(0.01, false, 'SetPropsTimer');
| + | |
− | }
| + | |
− | </uscript><br>
| + | |
− | <uscript>
| + | |
− | function SetPropsTimer()
| + | |
− | {
| + | |
− | SetWeapProps(Weap);
| + | |
− | }
| + | |
− | //Sets the properties to the values from the Server on the client
| + | |
− | </uscript>
| + | |
− | | + | |
− | | + | |
− | ===Related Topics===
| + | |
− | * [[Legacy:Introduction_To_Replication|Introduction To Replication]]
| + | |
− | * [[Legacy:Replication|Replication]]
| + | |
− | * [[Legacy:Replication Block|Replication Block]]
| + | |
− | * [[Legacy:Role|Role]] and RemoteRole, and [[Legacy:NetMode|NetMode]]
| + | |
− | * [[Legacy:Netcode Idioms|Netcode Idioms]]
| + | |
− | * [[Legacy:Replication Examples|Replication Examples]]
| + | |
− | * [[Legacy:Replication_De-Obfuscation|Replication De-Obfuscation]]
| + | |
− | | + | |
− | | + | |
− | ==Proposal==
| + | |
| | | |
− | ===stuff===
| + | --------<br> |
− | -[[User:00zX|00zX]] 21:31, 29 March 2009 (UTC) | + | |
− | ====gogo====
| + | |
− | :[[UE3:Object_static_native_functions_(UT3)]]
| + | |
− | :[[Legacy:Object_(UT3)/Operators]]
| + | |
− | :[[Legacy:Operators]]
| + | |
− | :[[Legacy:Scripting_Operators]]
| + | |
− | :[[Legacy:Iterator]]
| + | |
− | :[[Variables#Modifiers]]
| + | |