-7

我正在制作一个刽子手游戏,这部分代码位于按钮新游戏的后面。每次用户选择新游戏时,我希望游戏加载一个新词供用户猜测。我的问题是我需要将我的代码放入一个循环中。例如,如果没有 if/else 语句不为真,则选择另一个随机数,直到语句为真...

我希望这是有道理的 =) 这是我到目前为止的代码。

namespace HangMan
{
public partial class Form1 : Form
{
    int RW;
    string previous;

    public Form1()
    {
        InitializeComponent();

    }



    private void Form1_Load(object sender, EventArgs e)
    {
        foreach (TextBox textBox in addTextBox())
        {
            textBox.Visible = false;
            textBox.Text = "";
        }
    }

    private static void LoadImages()
    {
        Image newImageIntro = Image.FromFile("HangmanIntro.jpg");
        Image newImage1 = Image.FromFile("1.jpg");
        Image newImage2 = Image.FromFile("2.jpg");
        Image newImage3 = Image.FromFile("3.jpg");
        Image newImage4 = Image.FromFile("4.jpg");
        Image newImage5 = Image.FromFile("5.jpg");
        Image newImage6 = Image.FromFile("6.jpg");
        Image newImage7 = Image.FromFile("7.jpg");
        Image newImage8 = Image.FromFile("8.jpg");
        Image newImage9 = Image.FromFile("9.jpg");
    }

    private void txtEnText_TextChanged(object sender, EventArgs e)
    {

    }

    private void txtEnText_Enter(object sender, EventArgs e)
    {

    }

public List<TextBox> addTextBox()
    {
        List<TextBox> tBox = new List<TextBox>();

        tBox.Add(textBox1);
        tBox.Add(textBox2);
        tBox.Add(textBox3);
        tBox.Add(textBox4);
        tBox.Add(textBox5);
        tBox.Add(textBox6);
        tBox.Add(textBox7);
        tBox.Add(textBox8);
        tBox.Add(textBox9);
        tBox.Add(textBox10);

        return tBox;
    }

    private void button1_Click(object sender, EventArgs e)
    {
        Random rW = new Random();

        foreach (TextBox textBox in addTextBox())
        {
            textBox.Visible = false;
        }


        RW = rW.Next(1, 4);

        if (RW == 1 & previous != "1" ) //Cat
        {
            textBox1.Visible = true;
            textBox2.Visible = true;
            textBox3.Visible = true;
            previous = "1";


        }
        else if (RW == 2 & previous != "2" ) //Elephant
        {
            textBox1.Visible = true;
            textBox2.Visible = true;
            textBox3.Visible = true;
            textBox4.Visible = true;
            textBox5.Visible = true;
            textBox6.Visible = true;
            textBox7.Visible = true;
            textBox8.Visible = true;
            previous = "2";
        }
        else if (RW == 3 & previous != "3") //Giraffe
        {
            textBox1.Visible = true;
            textBox2.Visible = true;
            textBox3.Visible = true;
            textBox4.Visible = true;
            textBox5.Visible = true;
            textBox6.Visible = true;
            textBox7.Visible = true;
            previous = "3";
        }
        else if (RW == 4 & previous != "4") //Monkey
        {
            textBox1.Visible = true;
            textBox2.Visible = true;
            textBox3.Visible = true;
            textBox4.Visible = true;
            textBox5.Visible = true;
            textBox6.Visible = true;
            previous = "4";
        }
        else
        {
        }



    }
}

}

4

2 回答 2

2

不要循环检查,而是尝试循环直到你得到一个你喜欢的随机数。

这是一些关于如何执行此类操作的伪代码。

//while the next random number is not the same as the previous
    //Generate a new random number

一旦你有一个你喜欢的随机数,你就不必检查那些 if 中的前一个数字。

您可能还想查找 switch 语句的文档,因为它可能使您的代码在此处更具可读性。

于 2013-01-28T21:17:05.867 回答
1

把它放在你的代码周围:

while(true)
{
// CODE
break;
}

else {}零件内部:

continue;

编辑:您也可以使用 LINQ,例如

while(Controls.OfType<TextBox>().All(t => !t.Visible))

如果您只有那些在循环内可见性变化的框。

于 2013-01-28T21:10:01.577 回答