VBAサンプル集
Beep音で音楽(Beep,Sleep)

ExcelマクロVBAの実用サンプル、エクセルVBA集と解説
最終更新日:2013-05-14

Beep音で音楽(Beep,Sleep)

時々検索されるので、Beep音で音楽を演奏してみましょう。

プログラムはほぼAPIをCALLするだけです。

まずは、シートです。

マクロ VBA サンプル画像


こんな感じです。

ドレミの周波数は結構適当なので、詳しい方は自分で調整して下さい。

2~3行目に、基本のドレミに対応する周波数を入力しておきます。

半音等が必要なら、それも登録すれば良いでしょう。

そして、

5行目に、音楽を入れます。

6行目は、時間をミリ秒で入力します。

無音を指定する場合は、6行目の時間のみ指定して下さい。

そして、以下がプログラムです。



Option Explicit

Public Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long)
Public Declare Function Beep Lib "kernel32" (ByVal dwFreq As Long, ByVal dwDuration As Long) As Long

Sub PlayMusic()
  Dim i As Long
  Dim varHlookup As Variant
  For i = 2 To Cells(5, Columns.Count).End(xlToLeft).Column
    On Error Resume Next
    varHlookup = Application.WorksheetFunction.HLookup(Cells(5, i), Range("B2:W3"), 2, False)
    If Err Then
      Sleep (Cells(6, i))
    Else
      Call CallBeep(varHlookup, Cells(6, i))
    End If
    On Error GoTo 0
  Next i
End Sub

Sub CallBeep(ByVal lngfreq As Long, ByVal lngTime As Long)
  Call Beep(lngfreq, lngTime)
End Sub



特に説明のしようもないです。

使ってみて、いろいろ遊んでください。

周波数をいろいろ変更すれば、結構音楽らしくなるのではないかと思います。

音程が少しおかしいのは、プログラムの問題ではなく、私の音楽センスですので、勘弁して下さい。

すみませんが、私は、音楽は全然分かりませんので、これ以上の情報はちょっと無理です。

ご自由に、改変して下さい。

ダウンロード

↑からダウンロードして下さい。

そのまま開いても動作すると思います。

ご利用は、自己責任でお願いします。

当方では、不具合による一切の責任は負いません。

ただし、質問程度は、コメントで受付ます。





同じテーマ「マクロVBAサンプル集」の記事

「セルの結合」をショートカットに登録(OnKey)
半角カナのみ全角カナに変換する
計算式の元となる数値定数を消去する(Precedents)
Beep音で音楽(Beep,Sleep)
日付の検索(配列の使用)
ストップウォッチ(1/100秒)(Timer)
ストップウォッチ改(1/100秒)(Timer)
重複の無いユニークなデータ作成
WEBデータの取得方法
右クリックメニューの変更(CommandBars)
エクセルのアイコン取得(FaceID)


新着記事NEW ・・・新着記事一覧を見る

VBA100本ノック 98本目:席替えルールが守られているか確認|VBA練習問題(3月1日)
VBA100本ノック 97本目:Accessからデータを取得2|VBA練習問題(2月27日)
VBA100本ノック 96本目:Accessからデータを取得1|VBA練習問題(2月26日)
VBA100本ノック 95本目:図形のテキストを検索するフォーム作成|VBA練習問題(2月24日)
VBA100本ノック 94本目:表範囲からHTMLのtableタグを作成|VBA練習問題(2月23日)
VBA100本ノック 93本目:複数ブックを連結して再分割|VBA練習問題(2月22日)
VBA100本ノック 92本目:セルの色を16進で返す関数|VBA練習問題(2月20日)
VBA100本ノック 91本目:時間計算(残業時間の月間合計)|VBA練習問題(2月19日)
VBA100本ノック 90本目:セルに重なっている画像の削除|VBA練習問題(2月17日)
VBA100本ノック 89本目:2つのフォルダの統合|VBA練習問題(2月16日)


アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.RangeとCellsの使い方|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.マクロって何?VBAって何?|VBA入門
5.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
6.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
7.繰り返し処理(For Next)|VBA入門
8.セルに文字を入れるとは(Range,Value)|VBA入門
9.マクロはどこに書くの(VBEの起動)|VBA入門
10.とにかく書いてみよう(Sub,End Sub)|VBA入門




このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。



このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
本文下部へ