BUNZIN NET ポータル / プログラムは考え方です / メルマガバックナンバーリスト
前のメルマガ / 次のメルマガ

2010/01/07発行 『【櫻井です】画面への「ラーメン(3分)」ボタンの追加』

━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
レンタル掲示板とクイズ投稿サイトを開発した櫻井文人の
プログラムの考え方が身につくメルマガ『プログラムは考え方です』
───────────────────────────────────
メルマガ発行人
櫻井文人のプロフィール ⇒ http://www.bunzin.net/program/prof.html
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

こんにちは、メルマガ発行人の櫻井文人です。
あけましておめでとうございます。
詳しくは編集後記で。


前回のメルマガでは、
タイマープログラムに追加する、
3分間をワンタッチで計測する機能についての説明をしました。

インスタントラーメンを作る時に便利そうですね。

今回のメルマガからは、少しずつ機能を追加していきます。

今回は、イベント発生のきっかけとなるボタンの
画面への追加をおこないます。


───────────────────────────────────
【おすすめ】

今話題の電子タバコですが、
ちょっと試してみたいと思っても、
どれもだいたい1万円くらいなので、なかなか手が出しにくいですよね。

実は5千円もしない電子タバコのセットがあるんです。

 コチラ ⇒ http://www.moshimo.com/article/121691/138981

  ターボフィルター電子タバコ『マジックスモーカー』
  本体キット《メンソール風味》

  販売価格:4,000円 (税込:4,200円)

 コチラ ⇒ http://www.moshimo.com/article/121691/138981

これなら、ちょっと試してみるのにはよさそうですね。


━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
■■ 画面への「ラーメン(3分)」ボタンの追加
───────────────────────────────────

今回は、タイマープログラムに、イベント発生のきっかけとなるボタンの
画面への追加をおこないます。


■画面への「ラーメン(3分)」ボタンの追加

 タイマープログラム内の以下の画面を定義している箇所に、
 「ラーメン(3分)」ボタンのための定義を追加しました。


    1行目:html = "" _
    2行目:+ "<form name=""form1"" >" _
    3行目:+ "   <table width=300><tr><td>" _
    4行目:+ "      <input type=""hidden"" name=""CLICKED_PLUS""  value=""false"">" _
    5行目:+ "      <input type=""hidden"" name=""CLICKED_MINUS"" value=""false"">" _
    6行目:+ "      <input type=""hidden"" name=""CLICKED_START"" value=""false"">" _
    7行目:+ "      <input type=""hidden"" name=""CLICKED_STOP""  value=""false"">" _
    8行目:+ "      <input type=""hidden"" name=""NOODLE_3MIN""  value=""false"">" _
    9行目:+ "      <input type=""hidden"" name=""CLICKED_CLOSE"" value=""false"">" _
  10行目:+ "      <input type=""text"" name=""COUNTER"" size=5>" _
  11行目:+ "      <input type=""button"" " _
  12行目:+ "         onClick = ""getElementsByName('CLICKED_PLUS')(0).value = 'true';""" _
  13行目:+ "         value=""+"">" _
  14行目:+ "       <input type=""button"" " _
  15行目:+ "         onClick = ""getElementsByName('CLICKED_MINUS')(0).value = 'true';""" _
  16行目:+ "         value=""−"">" _
  17行目:+ "      <br>" _
  18行目:+ "      <input type=""button"" " _
  19行目:+ "         onClick = ""getElementsByName('CLICKED_START')(0).value = 'true';""" _
  20行目:+ "         value=""スタート"">" _
  21行目:+ "      <input type=""button"" " _
  22行目:+ "         onClick = ""getElementsByName('CLICKED_STOP')(0).value = 'true';""" _
  23行目:+ "         value=""ストップ"">" _
  24行目:+ "      <input type=""button"" " _
  25行目:+ "         onClick = ""getElementsByName('NOODLE_3MIN')(0).value = 'true';""" _
  26行目:+ "         value=""ラーメン(3分)"">" _
  27行目:+ "   </td><td align=""right"" valign=""top"">" _
  28行目:+ "      <input type=""button"" " _
  29行目:+ "         onClick = ""getElementsByName('CLICKED_CLOSE')(0).value = 'true';""" _
  30行目:+ "         value=""閉じる"">" _
  31行目:+ "   </td></tr></table>" _
  32行目:+ "</form>" _


 今回は8行目、そして24行目から26行目を追加しました。

 ・8行目では、
  ボタンがクリックされたことを覚えておくための、
  NOODLE_3MINという名前の部品を組み込んでいます。
  この部品は画面には表示されませんが、
  変数のように値を覚えておくことができます。
  NOODLE_3MINには初期値としてfalseを格納しておきます。

 ・24行目から26行目では、
  「ラーメン(3分)」ボタンを組み込んでいます。
  またボタンがクリックされると、8行目で組み込んだNOODLE_3MINに
  trueを格納します。

  つまり、NOODLE_3MINがfalseからtrueに変わった時に、
  「ラーメン(3分)」ボタンがクリックされたというイベントが
  発生したということなります。
  このNOODLE_3MINのfalseからtrueへの変化を
  イベントループ内のイベントディスパッチャが検知して、、
  イベントに対応したイベントハンドラを呼び出すことになります。


■修正後のプログラム

 以下が、修正後のタイマープログラムです。

----------------------------------------------------------------------
rem プログラムの開始

rem **********************************************
rem お手軽タイマープログラム
rem **********************************************

rem **********************************************
rem プログラムの準備
rem **********************************************
set w = WScript

set ie = CreateObject("InternetExplorer.Application")
ie.Width = 350
ie.Height = 130
ie.ToolBar = false
ie.StatusBar = false
ie.Resizable = false
ie.Visible = true
ie.Navigate "about:blank"
do while ie.Busy
  w.sleep 100
loop

html = "" _
+ "<form name=""form1"" >" _
+ "   <table width=300><tr><td>" _
+ "      <input type=""hidden"" name=""CLICKED_PLUS""  value=""false"">" _
+ "      <input type=""hidden"" name=""CLICKED_MINUS"" value=""false"">" _
+ "      <input type=""hidden"" name=""CLICKED_START"" value=""false"">" _
+ "      <input type=""hidden"" name=""CLICKED_STOP""  value=""false"">" _
+ "      <input type=""hidden"" name=""NOODLE_3MIN""  value=""false"">" _
+ "      <input type=""hidden"" name=""CLICKED_CLOSE"" value=""false"">" _
+ "      <input type=""text"" name=""COUNTER"" size=5>" _
+ "      <input type=""button"" " _
+ "         onClick = ""getElementsByName('CLICKED_PLUS')(0).value = 'true';""" _
+ "         value=""+"">" _
+ "       <input type=""button"" " _
+ "         onClick = ""getElementsByName('CLICKED_MINUS')(0).value = 'true';""" _
+ "         value=""−"">" _
+ "      <br>" _
+ "      <input type=""button"" " _
+ "         onClick = ""getElementsByName('CLICKED_START')(0).value = 'true';""" _
+ "         value=""スタート"">" _
+ "      <input type=""button"" " _
+ "         onClick = ""getElementsByName('CLICKED_STOP')(0).value = 'true';""" _
+ "         value=""ストップ"">" _
+ "      <input type=""button"" " _
+ "         onClick = ""getElementsByName('NOODLE_3MIN')(0).value = 'true';""" _
+ "         value=""ラーメン(3分)"">" _
+ "   </td><td align=""right"" valign=""top"">" _
+ "      <input type=""button"" " _
+ "         onClick = ""getElementsByName('CLICKED_CLOSE')(0).value = 'true';""" _
+ "         value=""閉じる"">" _
+ "   </td></tr></table>" _
+ "</form>" _

ie.Document.Body.InnerHtml = html
ie.Document.Title = "お手軽タイマー"

on error resume next

ie.Document.GetElementsByName("COUNTER")(0).value = 180
status = "IDLE"
bef_sec = 0

rem **********************************************
rem イベントループ
rem **********************************************
do while ie.Busy or status <> "CLOSE"

   If ie.Document.GetElementsByName("CLICKED_PLUS")(0).value <> "false" Then
      ie.Document.GetElementsByName("CLICKED_PLUS")(0).value = "false"
      clicked_plus()
   End If

   If ie.Document.GetElementsByName("CLICKED_MINUS")(0).value <> "false" Then
      ie.Document.GetElementsByName("CLICKED_MINUS")(0).value = "false"
      clicked_minus()
   End If

   If ie.Document.GetElementsByName("CLICKED_START")(0).value <> "false" Then
      ie.Document.GetElementsByName("CLICKED_START")(0).value = "false"
      clicked_start()
   End If

   If ie.Document.GetElementsByName("CLICKED_STOP")(0).value <> "false" Then
      ie.Document.GetElementsByName("CLICKED_STOP")(0).value = "false"
      clicked_stop()
   End If

   If ie.Document.GetElementsByName("CLICKED_CLOSE")(0).value <> "false" Then
      ie.Document.GetElementsByName("CLICKED_CLOSE")(0).value = "false"
      clicked_close()
   End If

   If status = "EXE_COUNT_DOWN" Then exe_count_down()

   w.sleep 100

loop

ie.Quit

rem **********************************************
rem イベントハンドラ「clicked_plus()」
rem 「+」ボタンがクリックされた時の処理
rem **********************************************
function clicked_plus()
   now_cnt = ie.Document.GetElementsByName("COUNTER")(0).value
   If now_cnt = "" Then
      MsgBox "秒数を入力してください。"
   ElseIf IsNumeric(now_cnt) = false Then
      MsgBox "秒数は数字で入力してください。"
   Else
      ie.Document.GetElementsByName("COUNTER")(0).value = now_cnt + 1
   End If
end function

rem **********************************************
rem イベントハンドラ「clicked_minus()」
rem 「-」ボタンがクリックされた時の処理
rem **********************************************
function clicked_minus()
   now_cnt = ie.Document.GetElementsByName("COUNTER")(0).value
   If now_cnt = "" Then
      MsgBox "秒数を入力してください。"
   ElseIf IsNumeric(now_cnt) = false Then
      MsgBox "秒数は数字で入力してください。"
   ElseIf now_cnt > 0 Then
      ie.Document.GetElementsByName("COUNTER")(0).value = now_cnt - 1
   End If
end function

rem **********************************************
rem イベントハンドラ「clicked_start()」
rem 「スタート」ボタンがクリックされた時の処理
rem **********************************************
function clicked_start()
   now_cnt = ie.Document.GetElementsByName("COUNTER")(0).value
   If now_cnt = "" Then
      MsgBox "秒数を入力してください。"
   ElseIf IsNumeric(now_cnt) = false Then
      MsgBox "秒数は数字で入力してください。"
   ElseIf now_cnt < 1 Then
      MsgBox "秒数は1秒以上で入力してください。"
   Else
      bef_sec = Second(Now)
      status = "EXE_COUNT_DOWN"
   End If
end function

rem **********************************************
rem イベントハンドラ「clicked_stop()」
rem 「ストップ」ボタンがクリックされた時の処理
rem **********************************************
function clicked_stop()
   status = "IDLE"
end function

rem **********************************************
rem イベントハンドラ「clicked_close()」
rem 「閉じる」ボタンがクリックされた時の処理
rem **********************************************
function clicked_close()
   status = "CLOSE"
end function

rem **********************************************
rem イベントハンドラ「exe_count_down()」
rem カウントダウン実行中の時の処理
rem **********************************************
function exe_count_down()
   now_cnt = ie.Document.GetElementsByName("COUNTER")(0).value
   now_sec = Second(Now)
   If bef_sec <> now_sec Then
      bef_sec = now_sec
      now_cnt = now_cnt - 1
      ie.Document.GetElementsByName("COUNTER")(0).value = now_cnt
   End If
   If now_cnt <= 0 Then
      MsgBox "時間になりました"
      status = "IDLE"
   End If
end function

rem プログラムの終了
----------------------------------------------------------------------


■次回のメルマガでは・・・

 イベントループ内のイベントディスパッチャに、
 「ラーメン(3分)」ボタンがクリックされたイベントの発生を
 検知する処理を追加します。


━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
■■ 編集後記
───────────────────────────────────

あけましておめでとうございます。

皆様は年末年始はいかがおすごしでしたか。

私は富士山静岡空港にも見学に行ってみました。
まだ、昨年できたばかりなので、周りはほんとに
なにもありませんでした。
ただ、富士山だけはよく見えました。


最後までお読みいただき、ありがとうございました。


━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━

●櫻井が開発したレンタル掲示板は
  コチラ ⇒ http://www.bunzin.gr.jp/m_board/

  画像のアップロードも可能なレンタル掲示板です。
  無料ですのでお気軽にどうぞ。


●櫻井が開発したクイズ投稿サイトは
  コチラ ⇒ http://www.bunzin.gr.jp/quiz/

  あなたが考えたクイズを投稿することができます。
  投稿されたクイズに回答することもできます。
  無料ですのでお気軽にどうぞ。


●お手軽!VBScriptを使ってみよう

  コチラ ⇒ http://www.bunzin.net/program/vbscript/


━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
メルマガ発行人 櫻井文人

メルマガ発行責任者情報は
 コチラ ⇒ http://www.bunzin.net/program/mghsinfo.html

アドレス変更と登録解除はコチラ ⇒ http://www.mag2.com/m/0000293166.html

メルマガバックナンバーは
 コチラ ⇒ http://www.bunzin.net/program/mailmaga/backnumber/

櫻井文人のプロフィール ⇒ http://www.bunzin.net/program/prof.html

ご意見・ご感想はコチラ ⇒ bunzin●bunzin.gr.jp
(メール送信の際は、●を@に置き換えてください。)
(櫻井が確実に読みますが、返信は保障できません。)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 
メルマガ登録・解除
 
前のメルマガ / 次のメルマガ
企画・運営・管理 BUNZIN NET