基本信息
源码名称:动态操作WinForm用户控件
源码大小:2.17M
文件格式:.rar
开发语言:C#
更新时间:2019-05-13
   友情提示:(无需注册或充值,赞助后即可获取资源下载链接)

     嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300

本次赞助数额为: 3 元 
   源码介绍
根据数据中查询的结果的数量来动态生成用户自定义控件,点击某一个用户自定义控件后跳转到另一个界面

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 CarButton;
using System.Data.SqlClient;

namespace Example
{
    public partial class Main : Form
    {
        public Main()
        {
            InitializeComponent();
            helper = new SQLHelper();
        }

        //用于测试使用
        public const int userID = 10000000;
        SQLHelper helper;

        private void Main_Load(object sender, EventArgs e)
        {
            AddData();
            //显示浏览记录数量
            label1.Text = GetCount().ToString();
        }

        /// <summary>
        /// 获得历史浏览记录数量
        /// </summary>
        int GetCount()
        {
            string s = "select count (*) from record where userid=@userid";
            SqlParameter[] sqlParameter = new SqlParameter[]{
                new SqlParameter("@userid",userID)
                 };
            return (int)new SQLHelper().ExecuteScalar(s, sqlParameter);
        }

        /// <summary>
        /// 获取数据库中所有汽车的信息
        /// </summary>
        /// <returns></returns>
        List<Car> GetCars()
        {
            //string selectCar = "with total as select *, row_number() over(order by Id) as rowNum from car) select * from total where rowNum between 1 and 4";
            string selectCar = "select * from car";

            List<Car> cars = new List<Car>();
            //Car car = new Car();//BUG***********************************************

            DataTable dataTable = helper.GetDataTable(selectCar, CommandType.Text);
            for (int i = 0; i < dataTable.Rows.Count; i )
            {
                Car car = new Car();
                car.ID = Convert.ToInt32(dataTable.Rows[i]["ID"]);
                car.CarName = dataTable.Rows[i]["CarName"] as string;
                car.NewPrice = Convert.ToDouble(dataTable.Rows[i]["NewPrice"]);
                car.OldPrice = Convert.ToDouble(dataTable.Rows[i]["OldPrice"]);
                car.FristPayment = Convert.ToDouble(dataTable.Rows[i]["FristPayment"]);
                car.Introduction = dataTable.Rows[i]["Introduction"].ToString();
                car.Picture = new PictureOperate().GetImage((byte[])dataTable.Rows[i]["Picture"]);
                cars.Add(car);
            }
            return cars;
        }

        /// <summary>
        /// 通过代码创建控件
        /// </summary>
        /// <param name="x"></param>
        /// <param name="y"></param>
        /// <param name="number"></param>
        /// <param name="car"></param>
        void CreateUserControl(int x, int y, int number, Car car)
        {
            //配置UserControlCarList相应的属性
            UserControlCarList user = new UserControlCarList();
            user.Name = "userControlCarList" number;
            user.Location = new System.Drawing.Point(x, y);
            user.pictureBox_CarImage.Image = car.Picture;
            user.label_CarIntroduction.Text = car.Introduction;
            user.label_CarName.Text = car.CarName;
            user.label_CarPrice.Text = car.NewPrice / 10000.0 "万  首付" car.FristPayment / 10000.0 "万";
            user.label_CarID.Text = car.ID.ToString();
            user.label_UserID.Text = userID.ToString();

            //将动态创建的控件添加到Panel控件中
            panel1.Controls.Add(user);

            user.Click = new EventHandler(aBtn_Click);//使用事件函数句柄指向一个具体的函数  
        }

        /// <summary>
        /// 通过从数据库中读取到的汽车,创建相应的控件
        /// </summary>
        void AddData()
        {
            List<Car> cars = GetCars();
            int i = 1;
            //动态创建控件
            foreach (var item in cars)
            {
                if (i % 2 != 0)
                {
                    //220 270
                    CreateUserControl(12, 12 (i - 1) / 2 * 220, i, item);
                }
                else
                {
                    CreateUserControl(12 220, 12 (i - 2) / 2 * 220, i, item);
                }
                i ;
            }
        }

        /// <summary>
        /// 点击"动态创建的控件"跳转到汽车详细信息的界面
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void aBtn_Click(object sender, EventArgs e)
        {
            //通过sender对象来获取是由哪个控件传来的Click事件
            UserControlCarList user = (UserControlCarList)sender;
            //跳转到汽车详细信息的界面,并将用户ID和汽车ID传过去
            new CarInfo(Convert.ToInt32(user.label_CarID.Text), Convert.ToInt32(user.label_UserID.Text)).Show();
            this.Close();
        }

        private void label1_Click(object sender, EventArgs e)
        {
            new Record(userID).Show();
            this.Close();
        }

        private void label2_Click(object sender, EventArgs e)
        {
            new Record(userID).Show();
            this.Close();
        }
    }
}