-
Notifications
You must be signed in to change notification settings - Fork 1
Siv3D August 2016 の新機能サンプル
Reputeless edited this page Aug 26, 2016
·
19 revisions
# include <Siv3D.hpp>
void Main()
{
while (System::Update())
{
if (Input::KeyA.clicked)
{
Say(L"こんにちは。シブスリーティーの文章読み上げ機能です。");
}
else if (Input::KeyB.clicked)
{
Say(L"Today's lucky number is ", Random(100));
}
if (Speech::IsSpeaking())
{
const double t = Time::GetMillisec() * 0.002;
Circle(Window::Center(), 40)
.drawArc(t, 30_deg, 8)
.drawArc(t + 120_deg, 30_deg, 8)
.drawArc(t + 240_deg, 30_deg, 8);
}
}
}
# include <Siv3D.hpp>
void Main()
{
Graphics::SetBackground(Color(80, 160, 230));
Graphics3D::SetAmbientLight(ColorF(0.3));
const Texture textureGround(L"Example/grass.jpg", TextureDesc::For3D);
const Mesh meshGround(MeshData::Plane(30, 30, { 6, 6 }));
const Texture textureBox(L"Example/brick.jpg", TextureDesc::For3D);
const Model model(L"Example/Well/Well.wavefrontobj");
ShadowLight shadowLight;
shadowLight.lookat.set(0, 0, 0);
while (System::Update())
{
Graphics3D::FreeCamera();
const double y = 30 + Sin(Time::GetMillisec() * 0.001) * 10;
const double angle = Time::GetMillisec() * 0.0005;
const Vec3 lightPos = Cylindrical(25, angle, y);
shadowLight.position.set(lightPos);
Graphics3D::SetShadowLight(shadowLight);
Graphics3D::SetLight(0, Light::Directional(lightPos.normalized()));
meshGround.draw(textureGround);
Sphere(0, 5, 0, 2).draw().drawShadow();
model.draw(Mat4x4::Translate(5, 0, 0)).drawShadow(Mat4x4::Translate(5, 0, 0));
for (auto i : step(6))
{
const Vec3 pos = Vec3(0, 0, 6) + Cylindrical(4, Radians(i*60), 0);
Cylinder(pos, pos + Vec3(0, 4, 0), 0.2).draw(HSV(i*60, 0.6, 1.0)).drawShadow();
}
for (auto i : step(6))
{
Box(-5 + i * 2, 0.5, -5, 1).draw(textureBox).drawShadow();
}
}
}
# include <Siv3D.hpp>
void Main()
{
const Font font(20);
Array<Box> boxes;
for (auto i : step(100))
{
boxes.emplace_back(RandomVec3({ -30, 30 }, { -30, 30 }, { -30, 30 }), 3.0);
boxes[i].rotation.rotateRollPitchYaw(Random(TwoPi), Random(TwoPi), Random(TwoPi));
}
while (System::Update())
{
Graphics3D::FreeCamera();
for (auto& box : boxes)
{
box.rotation.rotateRollPitchYaw(0.01, 0.01, 0.01);
}
int32 count = 0;
const ViewFrustum vf = Graphics3D::GetCamera().calcViewFrustum();
for (const auto& box : boxes)
{
if (vf.intersects(box))
{
box.draw();
++count;
}
}
font(L"描画された Box: {}/{}"_fmt, count, boxes.size()).draw(10, 10, Palette::Orange);
}
}
参考比較: https://github.com/Siv3D/Reference-JP/wiki/ドットお絵かき
# include <Siv3D.hpp>
# include <HamFramework.hpp>
void Main()
{
ScalableWindow::Setup(640, 480);
Graphics::SetBackground(Palette::White);
const int32 dotSize = 40;
Grid<int32> dots(Window::BaseWidth() / dotSize, Window::BaseHeight() / dotSize);
while (System::Update())
{
{
const auto transformer = ScalableWindow::CreateTransformer();
for (auto p : step({ dots.width, dots.height }))
{
const Rect rect(p * dotSize, dotSize, dotSize);
if (rect.leftClicked)
{
++dots[p.y][p.x] %= 4;
}
const Color color(240 - dots[p.y][p.x] * 70);
rect.stretched(-1).draw(color);
}
}
ScalableWindow::DrawBlackBars(HSV(40, 0.2, 0.9));
}
}
# include <Siv3D.hpp>
void Main()
{
while (System::Update())
{
if (Input::MouseR.clicked)
{
Clipboard::Clear();
}
if (Clipboard::HasChanged())
{
Println(L"HasChanged");
}
}
}
# include <Siv3D.hpp>
void Main()
{
Graphics::SetBackground(Color(160, 200, 100));
GUI gui(GUIStyle::Default);
gui.setTitle(L"タイトル");
gui.add(L"text", GUITextField::Create(6));
while (System::Update())
{
IME::SetCompositionWindowPos(gui.getPos());
}
}
- サイズ可変のウィンドウ
- W/A/S/D キーやマウス右ボタン、ホイールでカメラを移動
# include <Siv3D.hpp>
# include <HamFramework.hpp>
void Main()
{
ScalableWindow::Setup();
CameraBox2D camera(Vec2(0,0), 17.0);
PhysicsWorld world;
auto ground = world.createLineString(Vec2(0, 0), { Vec2(-20, 20), Vec2(-20, 10), Vec2(20, 0), Vec2(20, 20) }, none, none, PhysicsBodyType::Static);
Array<PhysicsBody> bodies;
bodies.push_back(world.createPolygon(Vec2(-8, 9), Geometry2D::CreateStar(1)));
for (auto i : step(100))
{
bodies.push_back(world.createCircle(Vec2(0, 5 + i * 2), 0.5));
}
while (System::Update())
{
world.update();
camera.update();
{
const auto t1 = camera.createTransformer();
const auto t2 = ScalableWindow::CreateTransformer();
ground.draw();
for (const auto& body : bodies)
{
body.draw(Palette::Skyblue);
}
}
camera.draw(Palette::Orange);
}
}
- 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