ホームページ php教程 php手册 砲弾がターゲットに命中して消えて得点することを実現するJS戦車戦

砲弾がターゲットに命中して消えて得点することを実現するJS戦車戦

Sep 15, 2016 am 11:14 AM

js坦克大战以实现炮弹击中目标消失并且记分
话不多说
下载下面的代码包就能看到效果,
效果图:
砲弾がターゲットに命中して消えて得点することを実現するJS戦車戦
js代码如下:/**初始化*/<br> var shell=document.getElementById('tk');<br> shell.innerHTML='<div></div>';<br> var w=shell.offsetWidth;h=shell.offsetHeight;<br> /**初始化*/<br> function keyDown(e) {  <br>          var keycode = e.which; <br>          remove(keycode,2);//坦克移动<br>        if(keycode=='32'){//发射子弹<br>              zidan();<br>        }<br>       }<br> <br> function keyUp(e){//键位弹起时候记录最后按下方向键,并将其储存到class中去<br>      var keycode = e.which; shell_1=document.getElementById('shell_1');<br>      <br>      if(keycode=='37' || keycode=='38' || keycode=='39' || keycode=='40'){<br>         shell_1.className='qin'+keycode;<br>      }<br>     <br> }<br>   /**键位监听*/<br>    document.onkeydown = keyDown;<br>    document.onkeyup = keyUp;<br>    /**键位监听*/<br> function remove(code,su){//玩家坦克移动函数<br>     var shell_1=document.getElementById('shell_1');<br>     var l;<br>     if(code=='37'){//左移<br>         l=shell_1.style.marginLeft;<br>         l=parseInt(l);<br>         if(l>0){<br>            shell_1.style.marginLeft=(l-su)+'px';<br>         }<br>     }<br>     <br>     if(code=='38'){//上移<br>         l=shell_1.style.marginTop;<br>         l=parseInt(l);<br>         if(l>0){<br>            shell_1.style.marginTop=(l-su)+'px';<br>         }<br>     }<br>     <br>     if(code=='39'){//右移<br>         l=shell_1.style.marginLeft;<br>         l=parseInt(l);<br>         if(l            shell_1.style.marginLeft=(l+su)+'px';<br>         }<br>     }<br> <br>     if(code=='40'){//下移<br>         l=shell_1.style.marginTop;<br>         l=parseInt(l);<br>         if(l            shell_1.style.marginTop=(l+su)+'px';<br>         }<br>     }<br>     <br> }<br> <br> function zidan(){//玩家坦克子弹函数<br>     /**获取子弹初始位置*/<br>     var che=document.getElementById('shell_1');<br>     var l=che.style.marginLeft;<br>     var t=che.style.marginTop;<br>     var html=shell.innerHTML;//获取原有html<br>     /**获取子弹初始位置*/<br>     <br>     var myDate = new Date();<br>     var myid=myDate.getTime(); <br>     <br>     /**创建初始子弹*/<br>        shell.innerHTML=html+'<div></div>';<br> /**最初の箇条書きを作成する*/<br> <br> /**弾丸の方向を知る*/<br> var fx=che.className;//弾丸の方向は弾丸の初期段階でのみ取得可能です<br> /**弾丸の方向を知る*/<br> <br> <br> <br> <br> var set=setInterval(function(){<br> <br> var zd=document.getElementById(myid);//箇条書きを取得します<br> <br> If(fx=='qin39'){//弾丸は右へ進みます<br> var ls=zd.style.marginLeft;<br> ls=parseInt(ls);<br>                                           If(ls<w></w> zd.style.marginLeft=(ls+1)+'px';<br> }その他{<br> レジダン(myid);<br> 「 }<br> }<br> If(fx=='qin37'){//弾丸は左へ進みます<br> var ls=zd.style.marginLeft;<br> ls=parseInt(ls);<br> If(ls>0){<br> zd.style.marginLeft=(ls-1)+'px';<br> }その他{<br> レジダン(myid);<br> 「 }<br> }<br> If(fx=='qin38'){//上向きの弾丸<br> var ls=zd.style.marginTop;<br> ; If(ls>0){<br> zd.style.marginTop=(ls-1)+'px';<br> }その他{<br> レジダン(myid);<br> 「 }<br> }<br> If(fx=='qin40'){//下向きの箇条書き<br> var ls=zd.style.marginTop;<br> ls=parseInt(ls);<br> If(ls<h></h> zd.style.marginTop=(ls+1)+'px';<br> }その他{<br> レジダン(myid);<br> 「 }<br> }<br> <br> },10);<br> <br> }<br> <br> <br> function rezidan(id){//删除子弹函数或者坦克<br>     var child=document.getElementById(id);<br>     if(child){<br>        shell.removeChild(child);<br>     }<br> }<br> <br> <br> //**电脑坦克*/<br> <br> function ran(){//随机1到4的方位函数<br>   var kwc=Math.ceil(Math.random()*10);<br>   var kwv;<br>   if(kwc%4==0){kwv=1;}<br>   if(kwc%4==1){kwv=2;}<br>   if(kwc%4==2){kwv=3;}<br>   if(kwc%4==3){kwv=4;}<br>   return kwv;<br> }<br> <br> <br> <br> function rantanke(){//随机创建敌方坦克<br>     <br>     <br>     <br>     /**初始坦克随机出现位置*/<br>     var html=shell.innerHTML;//获取原有html<br>     var t=Math.random()*1000;<br>     var l=Math.random()*1000;<br>     <br>     if(t>h){t=(t-h)+'px';}else{t=t+'px';}//判断坦克不会超出边界太远<br>     if(l>w){l=(l-w)+'px';}else{l=l+'px';}//判断坦克不会超出边界太远<br>     /**初始坦克随机出现位置*/<br>     <br>     <br>     <br>     var myDate = new Date();<br>     var myid=myDate.getTime();<br>     /**创建坦克*/<br>        shell.innerHTML=html+'<div></div>';<br>     /**タンクを作成する*/<br>     <br>        var setz=setInterval(function(){<br>            /**殴られる*/ <br>            var ztk=document.getElementById(myid);dt=ztk.style.marginTop;dl=ztk.style.marginLeft;<br>            dt=parseInt(dt);dl=parseInt(dl);           <br>            var zidanob=document.getElementsByClassName('zidan');<br>             if(zidanob.length!=0){ <br>                  for(i=0;i<zidanob.length></zidanob.length>              var zt=zidanob[i].style.marginTop;<br>              var zl=zidanob[i].style.marginLeft;<br>              zt=parseInt(zt);zl=parseInt(zl);<br>                 if(zt>dt && ztdl && zl                     zidanob[i].style.display='none';//隐藏子弹<br>                     zidanob[i].className='';//当子弹碰撞後删除子弹的クラスは次次继续击中敌方タンク<br>を防ぐため                     rezidan(myid);//删除殴られるタン克<br>                     クリアインターバル(setz);  //删除&タンクの時間関数<br>                     fensu();//记录分数<br>                 } <br>             }<br>             }<br>            /**&*/ <br>               var classz=ztk.className;<br>               var oArr = clasz.split(" ");<br>               var fwz;//每次执行这段代码FWZ就清空,fwz是方向判断变量<br>               <br>               <br>               if(classz){// 否か判断&後第一次移動<br>              <br>                     if(oArr[0]=='qinr'){//持续向右移動50回<br>                         if(parseInt(oArr[1])                          var lz=ztk.style.marginLeft;<br>                        lz=parseInt(lz);<br>If(lz<w></w> ztk.style.marginLeft=(lz+2)+'px';<br> } else {<br> Fwz = ran () // 壁と格闘して位置を再選択します <br>;                                                          Var clsaa = PARSEINT ([1])+1; ztk.className='qinr '+clsaa;<br> } else {<br> fwz=ran();//向きを再選択<br> }<br> }<br> <br> <br> If(oArr[0]=='qinl'){//左に50回移動し続けます<br> If(parseInt(oArr[1])                                                                                                                                                                                                                                 lz=parseInt(lz);<br> If(lz>0){<br> ztk.style.marginLeft=(lz-2)+'px'; } else {<br> Fwz = ran () // 壁と格闘して位置を再選択します <br>;                                                               Var clsaa = PARSEINT ([1])+1; ztk.className='qinl '+clsaa;<br> } else {<br> Fwz = ran () // 位置を再選択します <br>; }<br> }<br> <br> <br>if(oArr[0]=='qint'){//50 回上に進み続けます<br> If(parseInt(oArr[1])                                                                                                                                                                                                                                 lz=parseInt(lz);<br> If(lz>0){<br> ztk.style.marginTop=(lz-2)+'px'; } else {<br> Fwz = ran () // 壁と格闘して位置を再選択します <br>;                                                                    Var clsaa = PARSEINT ([1])+1; ztk.className='qint '+clsaa;<br> } else {<br> Fwz = ran () // 位置を再選択します <br>; }<br> }<br>                                                            If(oArr[0]=='qinf'){//下に 50 回移動し続けます<br> If(parseInt(oArr[1])                                                                                                                                                                                                                                                                                   lz=parseInt(lz);<br> If(lz<h></h> ztk.style.marginTop=(lz+2)+'px';<br> } else {<br> Fwz = ran () // 壁と格闘して位置を再選択します <br>;                                                          Var clsaa = PARSEINT ([1])+1; ztk.className='qinf '+clsaa;<br> } else {<br> Fwz = ran () // 位置を再選択します <br>;}<br> }<br>                                                            } else {<br> Fwz = ran () // アクティビティ関数 <br>; }<br>                                                                                                                                                                               (fwz == 2) {// 興味深い値が 2 の場合、右側に実行します var lz=ztk.style.marginLeft;<br> lz=parseInt(lz);<br> ztk.style.marginLeft=(lz+2)+'px'; ztk.className='qinr 1';<br> }<br>                                             If (fwz == 3) {// 興味深い値 3 が左に実行されます var lz=ztk.style.marginLeft;<br> lz=parseInt(lz);<br> ztk.style.marginLeft=(lz-2)+'px';<br> ztk.className='qinl 1';<br> }<br>                                             If (fwz == 1) {// 興味深い値 1 が上向きに実行されます <br> var lz=ztk.style.marginTop;<br> lz=parseInt(lz);<br> ztk.style.marginTop=(lz-2)+'px';<br> ztk.className='qint 1';<br> }<br>                                             (fwz == 4) {// 興味深い値が 4 の場合、下に移動します <br> var lz=ztk.style.marginTop;<br> lz=parseInt(lz);<br> ztk.style.marginTop=(lz+2)+'px';<br> ztk.className='qinf 1';<br> }<br> },50);<br> <br> }<br> function fensu(){//スコアリング関数<br> var ob=document.getElementById('fs');<br>var s=ob.innerText;<br> s=parseInt(s);<br> s=s+1;<br> Ob.innerText=s;<br> }

砲弾がターゲットに命中して消えて得点することを実現するJS戦車戦 rew.zip ( 33.16 KB ダウンロード: 9 回 )

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Python プログラミングの入門コード例について学びます。 Python プログラミングの入門コード例について学びます。 Jan 04, 2024 am 10:50 AM

入門コード例で Python プログラミングについて学ぶ Python は、習得が簡単でありながら強力なプログラミング言語です。初心者にとって、Python プログラミングの入門コード例を理解することは非常に重要です。この記事では、すぐに始めるのに役立つ具体的なコード例をいくつか紹介します。 Print HelloWorldprint("HelloWorld") これは、Python の最も単純なコード例です。 print()関数は、指定された内容を出力するために使用されます。

Go 言語プログラミングの例: Web 開発のコード例 Go 言語プログラミングの例: Web 開発のコード例 Mar 04, 2024 pm 04:54 PM

「Go 言語プログラミングの例: Web 開発におけるコード例」 インターネットの急速な発展に伴い、Web 開発はさまざまな業界で不可欠な部分になりました。 Go 言語は、強力な機能と優れたパフォーマンスを備えたプログラミング言語として、Web 開発の開発者にますます好まれています。この記事では、読者が Go 言語をより深く理解し、Go 言語を使用して独自の Web アプリケーションを構築できるように、具体的なコード例を通じて Web 開発に Go 言語を使用する方法を紹介します。 1. シンプルな HTTP サーバー まず、

PHP 変数の実際の使用: 10 の実際の使用例 PHP 変数の実際の使用: 10 の実際の使用例 Feb 19, 2024 pm 03:00 PM

PHP 変数はプログラムの実行中に値を保存し、動的でインタラクティブな WEB アプリケーションを構築するために重要です。この記事では、PHP 変数を詳しく説明し、10 個の実際の例を使用して実際に動作する様子を示します。 1. ユーザー入力の保存 $username=$_POST["username"];$passWord=$_POST["password"]; この例では、フォーム送信からユーザー名とパスワードを抽出し、その後の処理のために変数に保存します。 2. 構成値 $database_host="localhost";$database_username="username";$database_pa を設定します。

Java は単純なバブルソートコードを実装します Java は単純なバブルソートコードを実装します Jan 30, 2024 am 09:34 AM

Java バブル ソートの最も簡単なコード例 バブル ソートは一般的な並べ替えアルゴリズムであり、その基本的な考え方は、並べ替える順序を、隣接する要素の比較と交換を通じて順序付けされた順序に徐々に調整することです。次に、バブル ソートの実装方法を示す簡単な Java コード例を示します。 publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

初心者から熟練者まで: Go 言語で一般的に使用されるデータ構造のコード実装 初心者から熟練者まで: Go 言語で一般的に使用されるデータ構造のコード実装 Mar 04, 2024 pm 03:09 PM

タイトル: 初心者から熟練者まで: Go 言語で一般的に使用されるデータ構造のコード実装 データ構造はプログラミングにおいて重要な役割を果たし、プログラミングの基礎です。 Go 言語には、一般的に使用されるデータ構造が多数あり、これらのデータ構造の実装をマスターすることは、優れたプログラマーになるために重要です。この記事では、Go 言語で一般的に使用されるデータ構造を紹介し、読者がこれらのデータ構造を使い始めて習熟するのに役立つ、対応するコード例を示します。 1. 配列 配列は基本的なデータ構造であり、同じ型のグループです。

Huawei Cloud Edge Computing Interconnection Guide: インターフェースを迅速に実装するための Java コード例 Huawei Cloud Edge Computing Interconnection Guide: インターフェースを迅速に実装するための Java コード例 Jul 05, 2023 pm 09:57 PM

Huawei クラウド エッジ コンピューティング相互接続ガイド: インターフェイスを迅速に実装するための Java コード サンプル IoT テクノロジーの急速な発展とエッジ コンピューティングの台頭により、ますます多くの企業がエッジ コンピューティングのアプリケーションに注目し始めています。 Huawei Cloud はエッジ コンピューティング サービスを提供し、企業に信頼性の高いコンピューティング リソースと便利な開発環境を提供し、エッジ コンピューティング アプリケーションの実装を容易にします。この記事では、Java コードを通じて Huawei Cloud エッジ コンピューティング インターフェイスを迅速に実装する方法を紹介します。まずは開発環境を準備する必要があります。 Java Development Kit がインストールされていることを確認してください (

PHPを使用して在庫管理システムに在庫管理機能コードを記述する方法 PHPを使用して在庫管理システムに在庫管理機能コードを記述する方法 Aug 06, 2023 pm 04:49 PM

PHP を使用して在庫管理システムの在庫管理機能コードを記述する方法 在庫管理は多くの企業にとって不可欠な部分です。複数の倉庫を持つ企業にとって、在庫管理機能は特に重要です。在庫を適切に管理および追跡することで、企業は異なる倉庫間で在庫を割り当て、運用コストを最適化し、コラボレーション効率を向上させることができます。この記事では、PHP を使用して在庫倉庫管理機能のコードを記述する方法を紹介し、関連するコード例を示します。 1. 在庫倉庫管理機能のコードを書き始める前に、データベースを確立します。

ガイダンスと例: Java で選択ソート アルゴリズムを実装する方法を学習します。 ガイダンスと例: Java で選択ソート アルゴリズムを実装する方法を学習します。 Feb 18, 2024 am 10:52 AM

Java 選択ソート方法のコード記述ガイドと例 選択ソートは、シンプルで直観的なソート アルゴリズムです。そのアイデアは、ソートされていない要素から毎回最小 (または最大) の要素を選択し、すべての要素がソートされるまで交換することです。この記事では、選択項目の並べ替えのためのコード作成ガイドを提供し、特定の Java サンプル コードを添付します。アルゴリズム原理 選択ソートの基本原理は、ソート対象の配列をソート済み部分とソートされていない部分の 2 つの部分に分割し、その都度、未ソート部分から最小 (または最大) の要素が選択され、ソート済み部分の最後に配置されます。上記を繰り返します

See all articles