-
Notifications
You must be signed in to change notification settings - Fork 1
Siv3Dの基本
⚠ このページは古い Siv3D (August 2016 v2) のリファレンスのアーカイブです。
最新版の Siv3D (OpenSiv3D) については OpenSiv3D Web サイト をご覧ください。
Siv3D のロゴを表示してすぐに終了する、一番短くて簡単なプログラムです。
# include <Siv3D.hpp>
void Main()
{
}
メインループ while (System::Update())
を書くと、ウィンドウが閉じられる か、Esc キーが押される までアプリケーションが実行され続けます。
メインループは 1 フレームで 1 周、一般的なパソコンでは 1 秒間に最大 60 周実行されます。
メインループ内にプログラムを書くことで、毎フレーム継続して絵を表示したり、入力を処理したりできます。
# include <Siv3D.hpp>
void Main()
{
while (System::Update())
{
}
}
ウィンドウ内の黒い部分が画面(クライアント領域)です。
Siv3D ではクライアント領域に図形や画像を表示できます。
クライアント領域上の位置を表す 座標系 は、右方向が +X , 下方向が +Y です。
特に指定しない限り、クライアント領域の大きさは 幅 640 ピクセル, 高さ 480 ピクセル です。
したがって、一番左上の座標は (0,0)、右下の座標は (639,479) になります。
マウスカーソルに従って白い円が動くプログラムです。
マウスカーソルの座標がオレンジ色の文字で表示されます。
詳しい仕組みは次の章以降で説明されます。
# include <Siv3D.hpp>
void Main()
{
const Font font(30);
while (System::Update())
{
Circle(Mouse::Pos(), 100).draw();
font(Mouse::Pos()).draw(50, 200, Palette::Orange);
}
}
回転するカラフルな正方形を描いてみましょう。
詳しい仕組みは次の章以降で説明されます。
# include <Siv3D.hpp>
void Main()
{
Graphics::SetBackground(Palette::White);
while (System::Update())
{
for (int32 i = 0; i < 36; ++i)
{
const double radian = Radians(i * 10 + System::FrameCount());
const Vec2 pos = Circular(200, radian) + Window::Center();
RectF(25).setCenter(pos).rotated(radian).draw(HSV(i * 10));
}
}
}
これから先に進むと登場する Texture
, DynamicTexture
, Image
, Sound
, Wave
, Font
といった型のデータは、画像や音楽を準備する処理に少し時間がかかります。メインループの中で、毎フレーム作成することは避けてください。
// 間違ったプログラム
# include <Siv3D.hpp>
void Main()
{
while (System::Update())
{
// NG! 毎フレーム テクスチャを作成する
const Texture texture(L"Example/Windmill.png");
// NG! 毎フレーム フォントを作成する
const Font font(100);
texture.draw();
font(L"Hello").draw();
}
}
メインループの前にあらかじめデータを用意すれば、時間のかかる処理は 1 度だけですみます。
以下のような効率の良いプログラムを書きましょう。
# include <Siv3D.hpp>
void Main()
{
// OK! 1度だけテクスチャを作成する
const Texture texture(L"Example/Windmill.png");
// OK! 1度だけフォントを作成する
const Font font(100);
while (System::Update())
{
texture.draw();
font(L"Hello").draw();
}
}
上級者向け の機能ですが、アセット管理 を使うと、同じデータを何度もロードするミスを防げるだけでなく、ロードしたデータにプログラムのどこからでもアクセスできるようになります。
# include <Siv3D.hpp>
void Draw()
{
TextureAsset(L"a").draw();
FontAsset(L"b")(L"Hello").draw();
}
void Main()
{
TextureAsset::Register(L"a", L"Example/Windmill.png");
FontAsset::Register(L"b", 100);
while (System::Update())
{
Draw();
}
}
Siv3D は文字の型に ワイド文字 を使います。ワイド文字を使うには
L"あいうえお", L"Hello, world!", L'A', L'3'
のように、文字や文字列のクオーテーションの前に L
を置きます。
ワイド文字はひらがなや漢字を wchar 型 1 要素で表現できるため、日本語を簡単に扱えます。
# include <Siv3D.hpp>
void Main()
{
Graphics::SetBackground(Palette::White);
const Font font(36);
const String text = L"あいうえおかきくけこ";
while (System::Update())
{
for (size_t i = 0; i < text.length; ++i)
{
font(text[i]).draw(i * 40, i * 40, HSV(i * 20));
}
}
}
「次の章へ進む →」をクリックして、次のチュートリアルへ進みましょう。
- Siv3D の基本
- 図形を描く
- テクスチャを描く
- テキストを描く
- 文字列と数値の変換
- キーボード入力
- マウス入力
- サウンドの再生
- MIDI の再生
- ウィンドウと背景
- 図形のあたり判定
- 乱数
- ダイアログ
- ドラッグ & ドロップ
- アプリの状態
- テキストファイル
- INI, CSV, JSON
- バイナリファイル
- GUI
- アセット管理
- 画像編集
- Web カメラ
- マイク入力
- 経過時間の測定
- HSV カラー
- ファイルダウンロード
- 3D 描画
- 2D のレンダーステート
- 3D のレンダーステート
- パーティクル
- スクリーンショット
- アプリケーションの公開
- さらに学ぶには
- アプリランチャーを作ろう
- 音楽プレイヤーを作ろう
- 横スクロールゲームを作ろう
- ドット絵エディタを作ろう
- シーン遷移をサポートする SceneManager の使い方
- Siv3D ミニサンプル集
- タスクシステムを使う
- スケッチ
- 画像ビューアー
- オーディオスペクトラム
- マイク入力スペクトラム
- 文字色の反転
- 天気予報
- ドットお絵かき
- 15パズル
- ブロックくずし
- 時計
- 音楽プレイヤー
- ピアノ
- ライフゲーム
- シーン管理
- 地球
- 3Dシーン
- 3D交差判定
- Wooden Mirror
- シューティングゲーム
- Image to Polygon
- Sketch to Polygon
- 軌跡
- Plot3D
- テンポとピッチの変更
- 長方形の影
- Twitterクライアント
- Polygon to Mesh
- 3Dテキスト
- アプリ終了の確認
- 地形の生成
- アーカイブファイル
- GUIのアニメーション
- Aero Glassエフェクト
- Glitch
- リンクテキスト
- 付箋
- シーン切り替え(シルエット)
- MIDIシーケンサー
- 数つなぎ
- 画面を揺らす
- 対称定規
- aobench
- MIDIビジュアライザー
- 電卓
- 手書き文字認識
- 顔検出
- 音声合成
- Image to PhysicsBody