Beep音で音楽(Beep,Sleep)
時々検索されるので、Beep音で音楽を演奏してみましょう。
プログラムはほぼAPIをCALLするだけです。
まずは、シートです。
ドレミの周波数は結構適当なので、詳しい方は自分で調整して下さい。
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サンプル集」の記事
日付の検索(配列の使用)
新着記事NEW ・・・新着記事一覧を見る
TRIMRANGE関数(セル範囲をトリム:端の空白セルを除外)|エクセル入門(2024-08-30)
正規表現関数(REGEXTEST,REGEXREPLACE,REGEXEXTRACT)|エクセル入門(2024-07-02)
エクセルが起動しない、Excelが立ち上がらない|エクセル雑感(2024-04-11)
ブール型(Boolean)のis変数・フラグについて|VBA技術解説(2024-04-05)
テキストの内容によって図形を削除する|VBA技術解説(2024-04-02)
ExcelマクロVBA入門目次|エクセルの神髄(2024-03-20)
VBA10大躓きポイント(初心者が躓きやすいポイント)|VBA技術解説(2024-03-05)
テンキーのスクリーンキーボード作成|ユーザーフォーム入門(2024-02-26)
無効な前方参照か、コンパイルされていない種類への参照です。|エクセル雑感(2024-02-17)
初級脱出10問パック|VBA練習問題(2024-01-24)
アクセスランキング ・・・ ランキング一覧を見る
1.最終行の取得(End,Rows.Count)|VBA入門
2.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.繰り返し処理(For Next)|VBA入門
5.RangeとCellsの使い方|VBA入門
6.ブックを閉じる・保存(Close,Save,SaveAs)|VBA入門
7.セルのクリア(Clear,ClearContents)|VBA入門
8.メッセージボックス(MsgBox関数)|VBA入門
9.条件分岐(Select Case)|VBA入門
10.ブック・シートの選択(Select,Activate)|VBA入門
- ホーム
- マクロVBA応用編
- マクロVBAサンプル集
- Beep音で音楽(Beep,Sleep)
このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。