簡體   English   中英

C#將變量傳遞給類,然后以形式返回類輸出

[英]C# Passing Variable to class, then returning class output in form

我在如何在類之間來回傳遞數據方面全神貫注。 我參加了一些大學課程,介紹OOP,Beginning C ++,Beginning C#,並完成了一些自定進度的在線教程。 我相信我正在掌握何時使用類,而不是如何使用它們。 因此,這就是我要嘗試做的事情,我只需要有關如何完成此操作的一些指導即可。 請不要告訴我谷歌,因為我一直在搜索直到手指流血(不能從字面上看),此時只需要進行其他操作(例如特定的術語)即可。 如果有人仍然可以用C#術語向我解釋,那將是有幫助的,因為我將有一些特定的內容可以重新開始搜索。

所以這是我在的地方

我編寫了一個應用程序,將所有內容放入同一個類(Form1)中並使其正常工作。 我正在使用下拉列表中的值,這些值用於執行數據庫查詢並分配一些用於播放視頻的變量。

這是我在Form1中完整的代碼

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlServerCe;

namespace Tests
{
public partial class Tests : Form
{
    public Tests()
    {
        InitializeComponent();


        using (var conn = new SqlCeConnection("Data Source=TestDB.sdf;Password=;Persist Security Info=True"))
        {
            conn.Open();
            var comm = new SqlCeCommand("SELECT DISTINCT ColumnOne FROM main", conn);                
            SqlCeDataReader reader = comm.ExecuteReader();

            while (reader.Read())
                columnOneComboBox.Items.Add(reader["ColumnOne"]);
        }
    }

    private void columnOneComboBox_SelectedIndexChanged(object sender, EventArgs e)
    {
        testsListBox.Items.Clear();
        testVideoMediaPlayer.Visible = false;

        var columnOne = columnOneComboBox.SelectedItem.ToString();
        using (var conn = new SqlCeConnection("Data Source=TestDB.sdf;Password=;Persist Security Info=True"))
        {
            conn.Open();
            var comm = new SqlCeCommand("SELECT * FROM main WHERE ColumnOne='" + columnOne + "' ORDER BY ColumnTwo", conn);
            SqlCeDataReader reader = comm.ExecuteReader();

            while (reader.Read())
                testsListBox.Items.Add(reader["ColumnTwo"]);
        }
    }

    private void TestListBox_SelectedIndexChanged(object sender, EventArgs e)
    {
        var columnTwo = testsListBox.SelectedItem.ToString();
        using (var conn = new SqlCeConnection("Data Source=TestDB.sdf;Password=Tr@1n!ng;Persist Security Info=True"))
        {
            conn.Open();
            var comm = new SqlCeCommand("SELECT * FROM main WHERE ColumnTwo='" + columnTwo + "'", conn);
            SqlCeDataReader reader = comm.ExecuteReader();

            if (reader.Read())
            {
                bodyPositionRichTextBox.Text = reader["ColumnThree"].ToString();
                techniqueRichTextBox.Text = reader["ColumnFour"].ToString();
                string videoPath = reader["Video"].ToString();

                if (videoPath != "")
                {
                    testVideoMediaPlayer.URL = @"Videos/" + videoPath;
                    testVideoMediaPlayer.settings.playCount = 1000;
                    testVideoMediaPlayer.uiMode = "none";
                    testVideoMediaPlayer.Visible = true;
                    testVideoMediaPlayer.stretchToFit = true;
                    testVideoMediaPlayer.fullScreen = false;
                }
                else
                {
                    testVideoMediaPlayer.Visible = false;
                }
            }
        }
    }
}
}

現在,我正在考慮創建一個單獨的類,稱為MediaPlayer,但我需要在MediaPlayer類中使用Form1中的變量,在該變量中指定了所有視頻控件,然后讓From1調用該播放器。 因此,以下是我想遷移到MediaPlayer.cs的想法:

                if (videoPath != "")
                {
                    testVideoMediaPlayer.URL = @"Videos/" + videoPath;
                    testVideoMediaPlayer.settings.playCount = 1000;
                    testVideoMediaPlayer.uiMode = "none";
                    testVideoMediaPlayer.Visible = true;
                    testVideoMediaPlayer.stretchToFit = true;
                    testVideoMediaPlayer.fullScreen = false;
                }
                else
                {
                    testVideoMediaPlayer.Visible = false;
                }

我會以錯誤的方式處理嗎? 我沒有得到如何將字符串變量“ Videos”從Test.cs傳遞到MediaPlayer.cs或如何從Test.cs調用MediaPlayer.cs。 感謝您提供的任何指導。

此類的MediaPlayer類(用您的組件類型代替):

public class MediaPlayer
{
    /* your video type */ TestVideoMediaPlayer { get; set; }

    public MediaPlayer(/* your video type */ testVideoMediaPlayer)
    {
        TestVideoMediaPlayer = testVideoMediaPlayer;
    }

    public void SetMediaPlayer(string url, int playerCount, string uiMode, bool visible, bool stretch, bool fullScreen)
    {
         if (url != "")
            {
                TestVideoMediaPlayer.URL = @"Videos/" + url;
                TestVideoMediaPlayer.settings.playCount = playerCount;
                TestVideoMediaPlayer.uiMode = uiMode;
                TestVideoMediaPlayer.Visible = visible;
                TestVideoMediaPlayer.stretchToFit = stretch;
                TestVideoMediaPlayer.fullScreen = fullScreen;
            }
            else
            {
                TestVideoMediaPlayer.Visible = false;
            }
    }
}

並將您的電話替換為:

 if (reader.Read())
 {
      bodyPositionRichTextBox.Text = reader["ColumnThree"].ToString();
      techniqueRichTextBox.Text = reader["ColumnFour"].ToString();
      string videoPath = reader["Video"].ToString();

      MediaPlayer mp = new MediaPlayer(testVideoMediaPlayer);
      mp.SetMediaPlayer(videoPath, 1000, "none", true, true, false);
 }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM