iPad専用アクションゲーム「スライムは投げる」

最近のエントリー

この処理の間だけ待機カーソルを表示しておきたい、ってことが良くあります。
やり方をいろんなサイトで調べても、一時的にカーソルを待機カーソルに設定して、用が済んだたら戻す、というようなコードばかり見かけたのですが、
途中で例外が飛んできたらどうすんの?(try finallyで捕まえてカーソル戻すの?)とかいちいち考えるのが面倒なので、クラス化してみました。

VC++MFCのCWaitCursorと同じようなものです。

using System;
using System.Windows.Forms;

namespace Takabosoft.Common.Forms
{
    class WaitCursor : IDisposable
    {
        private Cursor old = null;

        internal WaitCursor()
        {
            old = Cursor.Current;
            Cursor.Current = Cursors.WaitCursor;
        }

        #region IDisposable メンバー

        public void Dispose()
        {
            Cursor.Current = old;
        }

        #endregion
    }
}

(ファイナライザが無いのは仕様です^^;)

あとは、待機カーソルにしたい処理をusingで囲ってもらえれば、その間には待機カーソルになると思います。
例外が中で発生しても、ちゃんとカーソルが戻る予定です。

using (WaitCursor wait = new WaitCursor())
{
    // ここを処理している間、待機カーソルになる
}

まだ、あまり検証していませんが。

東京都江戸川区にて「中高生のためのパソコン作曲講座」が行われました。
その講座にて、MIDI音楽編集ソフト「Domino」が使用されました。

詳しくはこちら↓
http://www.kids-forum.jp/2011edogawa/compose_2011.html

Dominoが地域の文化に貢献しているようで、なによりです。
いきなり作曲というと敷居が高そうに見えますが、きっと講師陣の腕が良かったのでしょうね。

自分のソフトが世の中でどう使われているのかというのは非常に興味があります。
こういった講座なんかは近ければこっそり見学に行きたいぐらいです。

どうですか、浜松市も音楽の街なんて言ってるぐらいですし、作曲講座やってみませんか?

SINさんより、Roland SD-50用の音源定義ファイルをご投稿いただきました。
ありがとうございましたm(_ _)m

ダウンロードはこちらの下の方からどうぞ。
https://takabosoft.com/domino/module

SINさんのサイト(hatena)はこちらです。
http://d.hatena.ne.jp/SIN-28/

他にも音源定義ファイルを公開されている方、ご提供いただける方はメールにてご連絡ください。
こちらでリンクを貼らせていただきます。

新年あけましておめでとうございます。
本年もよろしくお願いいたします。

・・・とブログを書こうと思ってだらだら過ごしていた結果がもう5日です、酷いモンです。

昨年は体調が悪いことが多く、絶不調な1年だったなぁと思います。
なので今年は健康第一で心身ともに元気にやっていきたいと思います。

運動不足も深刻なので、なんとか体を動かしていきたいです。
これはプログラマ、というか自宅大好きな人には課題ですね。
昨年水泳道具をとりあえず揃えたのに結局(温水)プールに行かなかったので、今年こそは行ってみたいと思います。
そして出来れば毎週通いたいです。
(せっかく近場に新しい市営プールが出来たので、行こう行こうとは思っていたのですが。)

wii fitのバランスボードも何故か故障(電池変えても反応しない)しているので、今年中には修理に出したいと思います。
(なんか梱包とか郵送したりするの面倒くさいなぁと思いつつ年が明けてしまいました。)

プログラムの方は去年は・・・

  • C++(Windowsアプリ開発):多め
  • C#(Windowsアプリ開発):ちょろっと
  • Objective-C(iPhoneアプリ開発):ちょろっと
  • Java(Androidアプリ開発):ちょろっと
  • ActionScript(AIR/Flexアプリ開発):ちょろっと

という感じでした。

今年はC#を触る機会がもう少し増えそうです。
C#はDispose(using)地獄さえ見なければすごく扱いやすいので、お気に入りです。

そんなわけで、今年もお付き合いをお願いいたしますm(_ _)m

最近C#を勉強してます(というか一通り勉強し終わった感じです)。
WPFだとドロップシャドウを簡単に付けれるのですが、Formだと出来ないっぽいので、ちょっと作ってみました。

Edge1

影の色や不透明度、ぼかし具合も自由に変えられます。
対象がBitmapなので、やろうと思えば文字列にドロップシャドウを加えることも出来ます。

/// <summary>
/// ドロップシャドウを加えた新しいビットマップを作成します。
/// </summary>
/// <param name="srcBmp">対象のビットマップ</param>
/// <param name="blur">ぼかし</param>
/// <param name="distance">影の距離</param>
/// <param name="shadowColor">影の色</param>
/// <param name="baseOffset">描画先オフセット値の格納先</param>
/// <returns>ドロップシャドウが加えられた新しいビットマップ</returns>
private static Bitmap AppendDropShadow(Bitmap srcBmp, int blur, Point distance, Color shadowColor, out Point baseOffset)
{
    baseOffset = new Point(0, 0);
    if (srcBmp == null || blur < 0)
    {
        return null;
    }

    // ドロップシャドウを含めた新しいサイズを算出
    Rectangle srcRect = new Rectangle(0, 0, srcBmp.Width, srcBmp.Height);
    Rectangle shadowRect = srcRect;
    shadowRect.Offset(distance.X, distance.Y);
    Rectangle shadowBlurRect = shadowRect;
    shadowBlurRect.Inflate(blur, blur);
    Rectangle destRect = Rectangle.Union(srcRect, shadowBlurRect);
    baseOffset.X = destRect.X - srcRect.X;
    baseOffset.Y = destRect.Y - srcRect.Y;

    Bitmap destBmp = new Bitmap(destRect.Width, destRect.Height, PixelFormat.Format32bppArgb);

    // 影部分をレンダリングする
    BitmapData destBmpData = destBmp.LockBits(new Rectangle(0, 0, destRect.Width, destRect.Height), ImageLockMode.ReadWrite, PixelFormat.Format32bppArgb);
    BitmapData srcBmpData = srcBmp.LockBits(srcRect, ImageLockMode.ReadWrite, PixelFormat.Format32bppArgb);

    unsafe
    {
        byte* destLine = (byte*)destBmpData.Scan0 + (shadowBlurRect.Y - destRect.Y) * destBmpData.Stride + (shadowBlurRect.X - destRect.X) * 4;
        byte* srcBeginLine = (byte*)srcBmpData.Scan0 + (- blur - blur) * srcBmpData.Stride + (- blur - blur) * 4;

        int destWidth = shadowBlurRect.Width;
        int destHeight = shadowBlurRect.Height;

        int srcWidth = srcBmp.Width;
        int srcHeight = srcBmp.Height;

        int div = (1 + blur + blur) * (1 + blur + blur);

        byte r = shadowColor.R;
        byte g = shadowColor.G;
        byte b = shadowColor.B;
        float alpha = shadowColor.A / 255.0f;

        int destStride = destBmpData.Stride;
        int srcStride = srcBmpData.Stride;

        for (int destY = 0; destY < destHeight; destY++, destLine += destStride, srcBeginLine += srcStride)
        {
            byte* dest = destLine;
            byte* srcBegin = srcBeginLine;
            for (int destX = 0; destX < destWidth; destX++, dest += 4, srcBegin += 4)
            {
                // α値をぼかす
                int total = 0;
                byte* srcLine = srcBegin;
                for (int srcY = destY - blur - blur; srcY <= destY; srcY++, srcLine += srcStride)
                {
                    if (srcY >= 0 && srcY < srcHeight)
                    {
                        byte* src = srcLine;
                        for (int srcX = destX - blur - blur; srcX <= destX; srcX++, src += 4)
                        {
                            if (srcX >= 0 && srcX < srcWidth)
                            {
                                total += src[3];
                            }
                        }
                    }
                }

                dest[0] = b;
                dest[1] = g;
                dest[2] = r;
                dest[3] = (byte)((total / div) * alpha);
            }
        }
    }

    srcBmp.UnlockBits(srcBmpData);
    destBmp.UnlockBits(destBmpData);

    // 元の画像を重ねる
    using (Graphics g = Graphics.FromImage(destBmp))
    {
        g.DrawImage(srcBmp, srcRect.X - destRect.X, srcRect.Y - destRect.Y, srcBmp.Width, srcBmp.Height);
    }

    return destBmp;
}

LockBitsはtry catchした方が良かったかな、まあいいか。

記事検索

コミュニティ

Banner designed by 樟刺様
ドット絵掲示板
ドット絵掲示板
自作の「ドット絵」を投稿することができます。ドッターさん同士の交流の場としてご利用ください。
TakaboSoft Wiki
TakaboSoft Wiki
ソフトウェアに関する質問・不具合報告・要望などを書き込むことができます。