4. 模様を作る
4.1 円を並べる
- ループと図形描画を組み合わせると、模様やパターンを簡単に描くことができます
data:image/s3,"s3://crabby-images/c67ce/c67ce87012939f66377b82ccfdb59ede3ea9342f" alt=""
# include <Siv3D.hpp>
void Main()
{
Scene::SetBackground(Palette::White);
while (System::Update())
{
for (int32 i = 0; i < 5; ++i)
{
Circle{ (i * 100), 100, 30 }.draw(Palette::Skyblue);
}
for (int32 i = 0; i < 5; ++i)
{
Circle{ (50 + i * 100), 200, 30 }.draw(Palette::Seagreen);
}
}
}
4.2 二重ループで円を並べる
data:image/s3,"s3://crabby-images/e19a7/e19a7a321264118f43fc9f02f7a00581f713dd5e" alt=""
# include <Siv3D.hpp>
void Main()
{
Scene::SetBackground(Palette::White);
while (System::Update())
{
for (int32 y = 0; y < 4; ++y)
{
for (int32 x = 0; x < 6; ++x)
{
Circle{ (x * 100), (y * 100), 30 }.draw(Palette::Skyblue);
}
}
}
}
4.3 少し複雑にする
data:image/s3,"s3://crabby-images/987eb/987eb3c767bd78ea3a6f482280e24baa77e181ad" alt=""
# include <Siv3D.hpp>
void Main()
{
Scene::SetBackground(Palette::White);
while (System::Update())
{
for (int32 y = 0; y < 4; ++y)
{
for (int32 x = 0; x < 6; ++x)
{
if ((x + y) % 2 == 0)
{
Circle{ (x * 100), (y * 100), 10 }.draw(Palette::Skyblue);
}
else
{
Circle{ (x * 100), (y * 100), 30 }.draw(Palette::Skyblue);
}
}
}
}
}
4.4 長方形を並べる
data:image/s3,"s3://crabby-images/ea6ba/ea6ba8ef6f8e68a782744b4a510773049ef7ce42" alt=""
# include <Siv3D.hpp>
void Main()
{
Scene::SetBackground(Palette::White);
while (System::Update())
{
for (int32 x = 0; x < 6; ++x)
{
Rect{ (x * 100), 0, 80, 600 }.draw(Palette::Skyblue);
}
}
}
4.5 色を徐々に変化させる (1)
data:image/s3,"s3://crabby-images/1a159/1a159913d12c7b87d23f4f91e575f7f050c2310a" alt=""
# include <Siv3D.hpp>
void Main()
{
Scene::SetBackground(Palette::White);
while (System::Update())
{
for (int32 x = 0; x < 6; ++x)
{
Rect{ (x * 100), 0, 80, 600 }.draw(ColorF{ 0.0, (x * 0.2), 1.0 });
}
}
}
4.6 色を徐々に変化させる (2)
data:image/s3,"s3://crabby-images/3d9f0/3d9f0dc30339565c5fe61d9b892bd07b74fd2a76" alt=""
# include <Siv3D.hpp>
void Main()
{
Scene::SetBackground(Palette::White);
while (System::Update())
{
for (int32 x = 0; x < 10; ++x)
{
Rect{ (x * 80), 0, 80, 600 }.draw(HSV{ (x * 36), 0.5, 1.0 });
}
}
}