Global.asax 에서 RouteTable를 사용하셔 POST 데이터 전송시 에러가 발생하는 경우 사용


using System.Web.Routing;


void Application_Start(object sender, EventArgs e)

{

   // 응용 프로그램이 시작될 때 실행되는 코드입니다.

    RouteTable.Routes.Ignore("{resource}.axd/{*pathInfo}");

    RegisterRoutes(RouteTable.Routes);

}


void RegisterRoutes(RouteCollection routes)

{

  routes.MapPageRoute("IndexPage", "Index", "~/Index.aspx");

  //추가

}


트릭 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
void Application_EndRequest(Object Sender, EventArgs e)
{
            if ("POST" == Request.HttpMethod)
            {
                byte[] bytes = Request.BinaryRead(Request.TotalBytes);
                string s = Encoding.UTF8.GetString(bytes);
                if (!String.IsNullOrEmpty(s))
                {
                    int QueryStringLength = 0;
                    if (0 < Request.QueryString.Count)
                    {
                        QueryStringLength = Request.ServerVariables["QUERY_STRING"].Length;
                        Response.AppendToLog("&");
                    }
 
 
                    if (4100 > (QueryStringLength + s.Length))
                    {
                        Response.AppendToLog(s);
                    }
                    else
                    {
                        Response.AppendToLog(s.Substring(0, (4090 - QueryStringLength)));
                        Response.AppendToLog("|||...|||");
                    }
                }
            }
}
cs


asp.net FTP 파일 업로드

.ASPX
<asp:FileUpload id ="FileUpload1" runat ="server"   />

.CS
1
2
3
4
5
6
7
8
9
10
11
string filename = Path.GetFileName(FileUpload1.FileName);
FtpWebRequest rq = (FtpWebRequest)System.Net.FtpWebRequest.Create("ftp://xxx.com/" + filename);
rq.Credentials = new System.Net.NetworkCredential("아이디""비밀번호");
rq.Method = System.Net.WebRequestMethods.Ftp.UploadFile;
System.IO.Stream fs = FileUpload1.PostedFile.InputStream;
byte[] buffer = new byte[fs.Length];
fs.Read(buffer, 0, buffer.Length);
fs.Close();
System.IO.Stream ftpstream = rq.GetRequestStream();
ftpstream.Write(buffer, 0, buffer.Length);
ftpstream.Close();    
cs


asp.net updatepanel 사용시 history.back  할 경우 페이징 상태를 저장합니다.


scriptmanager 에 enablehistory, onnavigate를 설정합니다.

<asp:ScriptManager ID="ScriptManager1" runat="server" EnableHistory ="true"  onnavigate="ScriptManager1_Navigate"></asp:ScriptManager>


cs 처리

protected int CurIndex

{

     get

     {

        return ViewState["CurIndex"] != null ? Convert.ToInt32(ViewState["CurIndex"]) : 0;

      }

      set

      {

                ViewState["CurIndex"] = value;

       }

}


protected void Page_Load(object sender, EventArgs e)

{

    if (!IsPostBack)

    {

        CurIndex = 0;

        BindData();

    }

}


protected void PagingControl_OnPageIndexChanged(object sender, PagingControl.PagingEventArgs e)

{

        CurIndex = e.PageIndex ;

        ScriptManager1.AddHistoryPoint("CurIndex", CurIndex.ToString());

        BindData();

}


protected void ScriptManager1_Navigate(object sender, HistoryEventArgs e)

{

        PagingControl.CurrentPageIndex = Convert.ToInt32(e.State["CurIndex"]);

        BindData();

        UpdatePanel1.Update();

}



ASP.NET 동영상 업로드시 썸네일 이미지 생성


// -ss 00:05:00 5분 


var filePath= Server.MapPath("~/") +"exam.mp4"

var thumImg = Server.MapPath("~/") +  "exam.jpg"

var ffmpeg = new Process

{

     StartInfo =

      {  // 60sec

         Arguments = " -i \"" + filePath + "\"  -s 280*240  -ss 00:05:00 -vframes 1 -an -f image2 -vcodec mjpeg  \"" + thumImg + "\"",

         FileName = Server.MapPath("ffmpeg.exe")

       }

};

ffmpeg.StartInfo.UseShellExecute = false;

ffmpeg.StartInfo.CreateNoWindow = true;

ffmpeg.StartInfo.RedirectStandardOutput = false;

ffmpeg.Start();

CONVERT VB TO VB.NET

VB 파일 VB.NET 으로 변환

 

vs2008에서 변환가능

 

참고영상

https://www.youtube.com/watch?v=8Fjn95oNNT4

IIS
IIS 7 에러

 \\?\C:\Windows\system32\inetserv\config\applicationHost.config

해결

1. 리부팅
2. iis 재설치

asp.net ClientMode="Static" , ClientID 
UpdatePanel 안에서 사용시에는 PostBack 이 일어납니다.

FrameWork4.0

<script>

$("#<%= ddl.ClientID %>")
--> $("#ddl") //ClientMode="Static"

</script>

<asp:DropDownList
ID ="ddl" runat ="serverClientMode="Static" > </DropDownList>




DateTime.Compare 날짜 비교
public static int Compare(
	DateTime t1,
	DateTime t2
)
DateTime.Compare(DateTime t, DateTime t1) < 0  // t 가 t1보다 이전
DateTime.Compare(DateTime t, DateTime t1) == 0 // t 가 t1와 같음
DateTime.Compare(DateTime t, DateTime t1) > 0  // t 가 t1보다 클경우
 
if(DateTime.Compare(
Convert.ToDateTime('2011-11-25').AddDays(10), 
Convert.ToDateTime('2011-12-01')) > 0)
 
 


ASP.NET w3socket 통한 소켓 통신

Socket.dll 다운로드 

.cs
Socket.TCPClass sock = new Socket.TCPClass();
sock.Host = "IP:포트";
sock.TimeOut = 2000;
sock.Open();
sock.SendLine("Send");
sock.Wait();
Response.Write(sock.GetText(6));
Response.Write(sock.Buffer);
sock.Close();

'정리없는자료 > .NET' 카테고리의 다른 글

asp.net ClientMode="Static"  (0) 2011.12.01
DateTime.Compare 날짜 비교  (0) 2011.12.01
ASP.NET ( C# ) Socket 통신, w3Sockets  (0) 2011.04.21
IIS7.x에서 파일 업로드 용량 변환  (0) 2010.11.12
repeater Excel download  (0) 2010.11.12
Repeater FooterTemplate  (0) 2010.11.12

Web.config에 설정
<system.web>
 <httpRuntime executionTimeout="2400" maxRequestLength="102400"  enable="true"/>
</system.web>


CMD에서 실행
%windir%\System32\inetsrv\appcmd.exe set config "Default Web Site" -section:requestFiltering -requestLimits.maxAllowedContentLength:104857600 -commitpath:apphost

'정리없는자료 > .NET' 카테고리의 다른 글

DateTime.Compare 날짜 비교  (0) 2011.12.01
ASP.NET ( C# ) Socket 통신, w3Sockets  (0) 2011.04.21
IIS7.x에서 파일 업로드 용량 변환  (0) 2010.11.12
repeater Excel download  (0) 2010.11.12
Repeater FooterTemplate  (0) 2010.11.12
ASP.NET 특정 일자를 가감  (0) 2008.10.15

리피터 엑셀 다운로드
 public void RptToExcel(System.Web.UI.WebControls.Repeater repeater, string filename)
 {
        repeater.EnableViewState = false;

        System.IO.StringWriter sw= new System.IO.StringWriter();
        System.Web.UI.HtmlTextWriter hw = new System.Web.UI.HtmlTextWriter(sw);
        repeater.RenderControl(hw);

        ExportExcel(sw, filename);
 }
private void ExportExcel(System.IO.StringWriter sw, string filename)
{
        Response.ContentType = "application/vnd.ms-excel";
        Response.AddHeader("Content-Disposition", "attachment;filename="
        + string.Concat(DateTime.Now.ToString("yyyyMMddHHmmss"), ".xls"));
        Response.Charset = "ks_c_5601-1987";
        string data = @"<html><head><style>.text {mso-number-format:\@;} </style>
       <meta http-equiv='content-type' content='text/html; charset=utf-8'></head><body>";
       data += System.Text.RegularExpressions.Regex.Replace(sw.ToString(), "&nbsp;", " ");
        data += "</body></html>";

        Response.Write(data);
        Response.End();
}


rptExcel.DataSource = ds.Tables[0];
rptExcel.DataBind();
rptExcel.Visible = true;
RptToExcel(rptExcel, "name.xls");
rptExcel.Visible = false;

'정리없는자료 > .NET' 카테고리의 다른 글

ASP.NET ( C# ) Socket 통신, w3Sockets  (0) 2011.04.21
IIS7.x에서 파일 업로드 용량 변환  (0) 2010.11.12
repeater Excel download  (0) 2010.11.12
Repeater FooterTemplate  (0) 2010.11.12
ASP.NET 특정 일자를 가감  (0) 2008.10.15
ASP.NET 정상적인 일자인지를 체크  (0) 2008.10.15

바인딩된 데이터가 없을시에
 <FooterTemplate>

<tr runat="server" id="TrEmpty" visible="<%#((System.Data.DataTable)rpt.DataSource).Rows.Count  == 0 ? true : false%>" >
  <td   colspan="5">조회된 데이터가 없습니다</td>
</tr>    

 <FooterTemplate>
 

   public static string DateCalculate(string sDate, int iFG, int iValue)
        {
            DateTime dt = new DateTime(int.Parse(sDate.Substring(0, 4)),
                int.Parse(sDate.Substring(4, 2)),
                int.Parse(sDate.Substring(6, 2)));

            string sTemp = null;
            switch (iFG)
            {
                case 0:
                    sTemp = dt.AddYears(iValue).ToString("yyyymmdd");
                    break;
                case 1:
                    sTemp = dt.AddMonths(iValue).ToString("yyyymmdd");
                    break;
                case 2:
                    sTemp = dt.AddDays(iValue).ToString("yyyymmdd");
                    break;
            }

            return sTemp;
        }

  public static bool ValidDate(string sDate)
        {
            if (sDate.Trim().Length == 8)
            {
                try
                {

                    DateTime datDate = DateTime.ParseExact(sDate, "yyyyMMdd", null);

                    return true;
                }
                catch (Exception)
                {
                    return false;
                }
            }
            else
                return false;
        }

  public static string DayWeek(string dDAte, int tYpe)
        {
            DateTime datDate = new DateTime(int.Parse(dDAte.Substring(0, 4)),
                int.Parse(dDAte.Substring(4, 2)),
                int.Parse(dDAte.Substring(6, 2)));

            int intDay = int.Parse(datDate.DayOfWeek.ToString("d"));


            if (tYpe== 1)
            {
                switch (intDay)
                {
                    case 0: return "일";
                    case 1: return "월";
                    case 2: return "화";
                    case 3: return "수";
                    case 4: return "목";
                    case 5: return "금";
                    case 6: return "토";
                    case 7: return "일";
                    default: return " ";
                }
            }
            else
            {
                switch (intDay)
                {
                    case 0: return "SUN";
                    case 1: return "MON";
                    case 2: return "TUE";
                    case 3: return "WED";
                    case 4: return "THU";
                    case 5: return "FRI";
                    case 6: return "SAT";
                    case 7: return "SUN";
                    default: return " ";
                }
            }
        }

        public static string secTotime(double sTimes)
        {
            int iHour = 0;
            int iMin = 0;
            int iSec = 0;

            iHour = (int)(sTimes / 3600);
            sTimes -= iHour * 3600;

            iMin = (int)(sTimes/ 60);
            dTimes -= iMin * 60;

            iSec = (int)sTimes;

            return iHour.ToString("00") + ":" + iMin.ToString("00") + ":" + iSec.ToString("00");
        }

        public static double timeEmp(string sTime, string eTime)
        {
            if (sTime.Length < 14 || eTime.Length < 14)
                return -1;
            else
            {
                DateTime dtStart = new DateTime(int.Parse(sTime.Substring(0, 4)),
                    int.Parse(sTime.Substring(4, 2)),
                    int.Parse(sTime.Substring(6, 2)),
                    int.Parse(sTime.Substring(8, 2)),
                    int.Parse(sTime.Substring(10, 2)),
                    int.Parse(sTime.Substring(12, 2))
                    );

                DateTime dtEnd = new DateTime(int.Parse(eTime.Substring(0, 4)),
                    int.Parse(eTime.Substring(4, 2)),
                    int.Parse(eTime.Substring(6, 2)),
                    int.Parse(eTime.Substring(8, 2)),
                    int.Parse(eTime.Substring(10, 2)),
                    int.Parse(eTime.Substring(12, 2))
                    );

                TimeSpan tp;

                tp = dtStart - dtEnd;

                if (tp.TotalHours < 0)
                    return 0 - tp.TotalHours;
                else
                    return tp.TotalHours;
            }
        }


        public static string setComma(int ValueS)
        {
            try
            {
                return string.Format("{0:#,##0}", ValueS).Trim();
            }
            catch
            {
                return "";
            }
        }
public static string objC(object obj)
        {
            string strR = "";
            try
            {
                strR= obj.ToString().Trim();
                return strR;
            }
            catch
            {
                return strR;
            }
        }

public static string juminGet(string str)
        {
            string rep = "";
            rep = str.Substring(0, 6) + "-" + str.Substring(6, 7);

            return rep;
        }

        public static int leng(string str)
        {
            int intV = 0;

            for (int j = 0; j < str.Length; j++)
            {
                byte[] tempb= new byte[2];
                tempb= Encoding.Default.GetBytes(str.Substring(j, 1));

                switch (tempb.Length)
                {
                    case 1:
                        intV++;

                        break;
                    case 2:
                        intV+= 2;

                        break;
                }

            }

            return intV ;
        }

        /// <summary>
        /// string[]를 받아서 구분자로 구분하는 문자열리턴
        /// </summary>
        /// <param name="str">문자열 배열</param>
        /// <param name="des">구분자</param>
        /// <returns>문자열</returns>
        public static string getArrayToString(string[] str, string des)
        {
            int count;
            string rep = "";

            count = str.Length;
            for (int i = 0; i < count; i++)
            {
                rep = rep + str[i];
                if (i < count - 1)
                    rep = rep + des;
            }

            return rep;

        }

네이트온 메신져에 보면 미니창 투명도를 조절하여 은밀한 대화를 나눌수가있죠.

폼에 트랙바 하나와 라벨을 올립니다.
트랙바를 더블클릭하여 다음과 같이 작성합니다.

private void trackBar_Scroll(object sender, EventArgs e)
{
          
          int num = 0;
        num = int.Parse(this.trackBar.Value.ToString()) * 10;
        this.lbBar.Text = num.ToString();
          //lbBar 라벨
          this.Opacity = 1.0 - (this.trackBar.Value / 12.0);
}

간단하죠~^^;

잘 정리되있는 자료가있군요.^^;

1. 홀수행을 다른 색으로 보여주고 싶을 때


행마다 특정 배경색을 입혀보고 싶은 분들은 다음과 같이 구현하시면 됩니다. 일단 홀수행을 기준으로 설명하자면 AlternatiogRowsDefaultCellStyle속성에 BackColor를 선언하여 색상을 지정하시면 됩니다.

dbView.AlternatingRowsDefaultCellStyle.BackColor = Color.Aqua;

2. 여러개의 열이나 행을 선택하지 못하도록 막고 싶을 때

기본적으로 여러개의 열과 행을 선택할 수 있는데 이를 막고 한개의 열이나 한개의 행만 선택하도록 하고 싶을 때 다음과 같이 선언하면 됩니다.

dbView.MultiSelect = false;

3. 행단위로 클릭하도록 만들고 싶을 때

기본적으로 열단위로 클릭하도록 처리되어 있는데 이를 행단위로 클릭할 수 있는 기능도 있습니다. 이 기능은 SelectionMode속성에 DataGridViewSelectionMode.FullRowSelect를 설정하면 간단하게 됩니다.

dbView.SelectionMode = DataGridViewSelectMode.FullRowSelect;

참고로 DataGridViewSelectMode열거체이외의 값도 설정하여 열단위로 선택기능을 구현할 수 있고 열단위로 선택기능을 사용시 각 열에 대한 SortMode속성이 Automatic값(기본)으로 설정이 안되어 있으면 사용할 수 없습니다.

4. 행번호 보여주고 싶을 때

각 행의 행번호를 보여주고 싶을 때에는 행을 화면에 보여주는 타이밍인 RowPostPaint이벤트 타이밍에 그 행의 인덱스번호+1형태로 행헤더의 열 안에 넣어주면 끝납니다.

RowPostPaint이벤트핸들러의 2번째 파라미터인 DataGridViewRowPostPaintEventArgs 객체로부터 보여주기 위해 필요한 Graphics객체나 좌표값을 얻을 수 있습니다.

이하 e변수로 받을 수 있는 객체에 대해서 알아보면 다음과 같습니다.

<DataGridViewRowPostPaintEventArgs 객체>
  * e.Graphics - Graphics객체
  * e.RowIndex - 표시중인 행번호 (0부터 시작하기 떄문에 +1필요)
  * e.RowBounds.X 행헤더 열 왼쪽 위 X좌표
  * e.RowBounds.Y 행헤더 열 왼쪽 위 Y좌표
  * e.RowBounds.Height 행헤더 열높이
  * dbView.RowHeadersWidth 행헤더 셀 폭
  * dbView.RowHeadersDefaultCellStyle.Font 사용폰트
  * dbView.RowHeadersDefaultCellStyle.FontColor 폰트 색상
 
private void dbView_RowPostPaint(object sender, DataGridViewRowPostPaintEventArgs e) {

     // RowPointPaint 이벤트핸들러
     // 행헤더 열영역에 행번호를 보여주기 위해 장방형으로 처리
     Rectangle rect = new Rectangle(e.RowBounds.Location.X,

                         e.RowBounds.Location.Y,

                         dbView.RowHeadersWidth - 4,

                         e.RowBounds.Height);
     // 위에서 생성된 장방형내에 행번호를 보여주고 폰트색상 및 배경을 설정
     TextRenderer.DrawText(e.Graphics,

                         (e.RowIndex + 1).ToString(),

                         dbView.RowHeadersDefaultCellStyle.Font,

                         rect,  

                         dbView.RowHeadersDefaultCellStyle.ForeColor,

                         TextFormatFlags.VerticalCenter | TextFormatFlags.Right);

}


5. 특정 행이나 열을 고정시키고 스크롤하지 못하도록 막고 싶을 때

여기서는 2번째 열을 고정시킨 경우를 보여주고 있는데 그리드를 옆으로 스크롤 할 경우 3번째 열보다 우측의 스크롤이 나오고 1번째열과 2번째열은 고정된 형태를 보여줍니다.

- Frozen 속성 : 열 고정시키기 위한 속성으로 이를 고정시키기 위한 열을 지정하고 true값을 선언하면 해당 열의 좌측 열은 전부 고정되어 스크롤 할 없게 됩니다.

dbView.Columns[1].Frozen = true;

- DividerWidth 속성 : 구분선 폭 변경을 할 때 사용하는 속성으로서 이를 통해서 2번째열과 3번째열 사이 구분선을 약간 두껍게 표현하여 보다 직관적으로 구분할 수 있습니다.

dbView.Columns[1].DividerWidth = 3;


6. 그리드 실행될 때 기본 열이 선택된 모습을 보여주고 싶지 않을 때

아주 간단하게 속성하나만 선언하면 되는데 이때 주의해야할 점은 폼_Load이벤트핸들러에서는 효과가 없다는 것입니다. 어느 열도 선택되지 않는 상태로 보여주기 위해서는 폼이 표시된 이후 한번만 발생하는 폼_Shown 이벤트핸들러에서 선언해주는 것이 좋습니다.

        private void Form1_Shown(object sender, EventArgs e)
        {
            //6. 그리드 실행될 때 기본 열이 선택된 모습을 보여주고 싶지 않을 때
            dbView.CurrentCell = null;
        }


7. 특정값을 가진 열을 좀 다르게 보여주고 싶을 때

특정값을 가진 열을 좀더 강조하여 보여주고 싶은 경우가 종종 생깁니다. 이럴 때 유용한 것으로 예제에서는 Bike란 단어가 포함된 열인 경우 빨간색으로 글씨를 보여주도록 설정하였습니다.

특히, 개별적인 열에 대해서 보여주기 위해서는 폼_CellFormating이벤트핸들러를 이용하면 될것같습니다. 본래 이 이벤트핸들러는 특정값을 가진 열의 독립적인 서식을 적용하기 위한 것으로 열 스타일만 변경할 수 있습니다.

CellFormmating이벤트핸들러의 2번째파라미터로 받는 DataGridViewCellFormattingEventArgs객체로부터 그 열의 현재 스타일이나 열의 값을 얻거나 설정할 수 있습니다. 즉, 이것을 통해 열의 값을 확인하고 그 스타일을 변경하는 형태로 개발을 해보려고 합니다. 또한, 이벤트 발생시 열위치는 ColumnIndex속성과 RowIndex속성으로 알 수 있습니다.

private void dbView_CellFormatting(object sender,

DataGridViewCellFormattingEventArgs e) {
{

      // 7. 특정값을 가진 열을 좀 다르게 보여주고 싶을 때
      if (e.ColumnIndex == 1)
      {
            if (e.Value != null)
            {
                 string text = e.Value.ToString();
                 if (text.Contains("Bike"))
                 {
                      e.CellStyle.ForeColor = Color.Red;
                      e.CellStyle.SelectionForeColor = Color.Red;
                  }
              }
         }
  }

8. 헤더열이나 헤더행의 색을 변경하고 싶을 때

헤더행과 헤더열의 색을 변경하고싶은 경우에는 ColumnHeadersDefaultCellStyle속성과 RowHeadersDefaultCellStyle속성을 사용하면 괜찮을 것같습니다.

dbView.ColumnHeadersDefaultCellStyle.BackColor = Color.RosyBrown;
dbView.RowHeadersDefaultCellStyle.BackColor = Color.SeaGreen;

단, 위와 같이 선언하여도 그것이 사용할 수 없는 경우가 있는데 이것은 애플리케이션이 적용하고 있는 Windows XP의 Visual 스타일을 우선적으로 사용하기 때문인데 이 코드는 윈폼을 만들 때 자동으로생성하기 때문에 Application클래스의 EnableVisualStyles메소드를 호출합니다.

dbView.EnableHeadersVisualStyles = false;

그외 열과 행의 사이에 있는 선스타일을 변경할 수 있는데 다음과 같이 선언하게 되면 한개의 라인으로 보여주게 됩니다.

dbView.RowHeadersBorderStyle = DataGridViewHeaderBorderStyle.Single;
dbView.ColumnHeadersBorderStyle = DataGridViewHeaderBorderStyle.Single;

9. 선택한 행이나 열에 대한 값을 확인하고 싶을 때

보통 특정 행을 추가하거나 삭제하고 편집도 하는데 이럴 때 선택된 행이나 열에 대해서 어떤 조작을 하는 경우도 많습니다. 그래서 이번에는 이를 간단하게 처리하는 방법에 대해서 정리해보았습니다. 이 부분에 대한 것을 사용형태만 설명하고 넘어가겟습니다.

아래에서 설명한 것들중에서 같은 클래스명이나 속성명이 Row가 들어가거나 Column이란 단어로 비교되는 것을 알 수 있는데 이것에 의해 열에 대한 행과 똑같은 조작을 할 수 있다는 것을 알 수 있습니다.

- 선택된 열 얻기 : SelectedCells 속성

현재 선택된 열은 SelectedCells속성으로 얻을 수 있고 그리드에서 여러개의 열을 동시에 선택할 수 있기 때문에 이 속성은 DataGridViewSelectedCellCollection클래스 객체로 되어 잇습니다. 여기서는 간단하게 하나의 열을 조작할 경우에 사용되는 형태를 보여줍니다.

foreach (DataGridViewCell cell in dbView.SelectedCells) { }

선택된 열 갯수 얻기을 얻어 위에서 선택된 열을 얻을 수 있는 방법도 있습니다.

SelectedCells.Count

for(int i=0; i<dbView.SelectedCells.Count; i++) { }

또한 MultiSelect속성을 false를 설정한 것은 사용자가 여러개의 행/열을 선택할 수 있도록 할 수 있습니다.

- 선택된 행 얻기 : SelectedRows 속성

행을 선택하여 행정보를 얻는 경우에 필요한 것으로 DataGridViewRow클래스의 객체의 컬렉션은 Selectedows속성으로 얻을 수 있습니다.

foreach(DataGridViewRow row in dbView.SelectedRows) { }

- 특정 셀이나 행이 선택되었는지 확인하는 경우 : Selected 속성

셀이 선택되었다면 true, 셀이 선택되지 않았다면 false로 결과를 보내줍니다.

dbView[x,y].Selected;

특정 행이 선택되었는지 확인하는 경우

dbView.Rows[n].Selected;

- 선택된 행이나 열 설정

데이터 새로고침등의 이벤트로 인해 데이터를 새롭게 보여줄때 현재 위치를 나타내고 싶은 경우에 필요한 것으로 (x,y)위치에 있는 열을 선택한 상태로 두고 싶다면 다음과 같이 선언합니다.

dbView[x,y].Selected = true;

n행의 행을 선택한 상태로 두고 싶은 경우에는 아래와 같이 선언합니다.

dbView.Rows[n].Selected = true;

- 모든 선택된 열을 지울 때 : ClearSelection 메소드

 
10. 열에 보여지는 문자열을 여러행으로 보여주고 싶을 때

열에 표시되는 문자열이 길게 되면 한줄로 보여주지만 오버되면 잘려서 안보여줍니다. 이는 열스타일의 WrapMode속성을 DataGridViewTriState.True(그외 False, NotSet)로 설정하여 셀크기안에서 오버되면 여러행으로 해당 텍스트등을 모두 보여줍니다.

그리드안의 모든 열을 여러행을 보여주고 싶다면, DefaultCellStyle속성의 WrapMode속성에 DataGridViewTriState.True를 설정하는 것을 권장합니다. 이렇게하면 정말 간단하게 구현이 됩니다. ^^

또한, 다음줄로 넘어간 문자열이 발생하면 행의 높이는 자동으로 조절되는데 AutoSizeRowMode속성에 DataGridViewAutoSizeRowsMode.AllCells를 설정할 것을 권장합니다. 이상 이 두가지를 정리하면 다음과 같습니다.

dbView.DefaultCellStyle.WrapMode = DataGridViewTriState.True;
dbView.AutoSizeRowsMode = DataGridViewAutoSizeRowsMode.AllCells;

 

11. 맨 밑까지 스크롤하고 싶을 때

보통 맨 밑에 있는 행을 합계로 보여주거나 응용프로그램 실행시 곧바로 사용자가 새 행을 추가할 있도록 하는 경우가 있는데 이럴때 그리드 맨밑까지 스크롤을 가볍게 해줄 필요가 있습니다. 열단위 표시를 스크롤하기 위한 속성이 3가지가 있는데 다음과 같습니다.

<속성>

FirstDisplayedCell 그리드 왼쪽 위에 표시된 열 얻기/설정

FirstDisplayedScrollingColumnIndex 그리드에 표시된 처음 열 얻기/설정

FirstDisplayedScrollingRowIndex 그리에 표시된 처음 행 얻기/설정

예를 들어 [2,15]의 위치에 있는 열을 FirstDisplayedCell속성으로 설정하면 [2,15]위치의 열에 왼쪽위로 그리드가 스크롤된 상태로 보여집니다.

dbView.FirstDisplayedCell = dbView[2,15];

마지막 행을 표시하기 위해 그리드 맨밑까지 스크롤시키려면 FirstDisplayedScrollingRowIndex속성을 이용하길 권장합니다.

dbView.FirstDisplayedScrollingRowIndex = dbView.Rows.Count - 1;


12. 오토컴플릿 기능을 사용하고 싶을 때

텍스트박스 열은 열 편집 및 새 행을 추가시 텍스트박스를 사용합니다. 이럴때 열편집시 오토컴플릿 기능을 사용할 수 있다는 점입니다.

이는 열이 편집상태가 될 때 발생하는 EditingControlShowing이벤트핸들러가 발생할 때 보여주고 있는 텍스트박스 객체를 얻어 오토컴플릿에 필요한 속성을 설장하는 형태입니다.

실제 이 텍스트박스는 DataGridViewTextBoxEditingControl 클래스의 인스턴스를 만들어 TextBox클래스의 파생클래스로서 TextBox형으로 케스팅합니다.

이렇게 예고로 내놓은 코드는 모든 텍스트박스에 대한 오토컴플릿기능을 설정하고 있기 때문에 어느 열을 사용하더라도 오토컴플릿기능이 작동되며 특정열만 오토컴플릿 기능을 지정할 수도 있습니다. 이 예제에서는

 private void dbView_EditingControlShowing(object sender, DataGridViewEditingControlShowingEventArgs e)
 {
        TextBox tb = e.Control as TextBox;
        if (tb == null)
        {
             return;
         }
        if (dbView.CurrentCell.ColumnIndex == 1)
        {
             tb.AutoCompleteMode = AutoCompleteMode.SuggestAppend;
             tb.AutoCompleteSource = AutoCompleteSource.AllSystemSources;
         }
         else
         {
             tb.AutoCompleteMode = AutoCompleteMode.None;
         }
  }  

 
13. 열안에 문자열 선택하고 싶을 때

열 안에의 문자열을 선택하여 처리하고 싶다면 BeginEdit메소드를 사용하는 것을 권장합니다. 이 이름처럼 열을 편집하기 위한 것으로 파라미터값을 true로 선언하면 열 안의 문자열이 선택된 상태로 편집할 수 있습니다. 만약 false로 선언하면 커서가 문자열은 선택하지 않고 문자열끝에 커서가 있는 상태로 조작을 할 수 있습니다.

 

 // 폼_Load이벤트핸들러가 BeginEdit를 호출할 경우 폼을 먼저 표시할 필요가 있음
 this.Show();
 // 2행 1열 열을 현재 열로 지정
 dbView.CurrentCell = dbView[0, 1];
 // 현재 열을 편집상태로
 dbView.BeginEdit(true);

14. 왼쪽 윗 빈 열에 값 설정하고 싶을 때

왼쪽 맨 윗열은 항상 빈 여백의 열로 남아 있는데 여기에 특정한 표시를 나타내기 위해 값을 넣거나 열 스타일을 변경할 수 있습니다.

이 빈열은 DataGridView컨트롤의 TopLeftHeaderCell속성으로 접근할 수 있고 이 속성값은 헤더 행이나 헤더 열과 동일한 DataGridViewHeaderCell클래스의 객체입니다. 일반적인 열을 나타내는 DataGridViewCell클래스를 상속받은 클래스입니다.

dbView.TopLeftHeaderCell.Value = "매장";

15. 오른쪽버튼 클릭시 열 선택을 할 수 있도록 하고 싶을 때

기본적으로 마우스 오른쪽버튼으로 클릭시 어떠한 조작도 제어되지 않습니다. 그래서 간단하게 클릭시 열을 선택할 수 있도록 하는 방법을 추가해보고자 합니다.

이는 CellMouseClick이벤트핸들러를 생성하여 열을 클릭시 Control클래스로 정의되어 있는 MouseClick이벤트가 추가되어 CellMouseClick이벤트핸들러가 발생하는 형태입니다. 이 이벤트핸들러의 파라미터로는 클릭된 열의 행번호와 열번호를 얻을 있어 클릭되어 진 열을 간단하게 접근하실 수 있습니다.

여기서 보여주는 스타일은 이벤트핸들러를 통해 클릭된 열의 선택상태를 알려주는 것을 아주 간단합니다.

 private void dbView_CellMouseClick(object sender, DataGridViewCellMouseEventArgs e) {
      //오른쪽 버튼 클릭인가?
      if (e.Button == MouseButtons.Right) {
           // 헤더 이외의 열
          if (e.ColumnIndex >= 0 && e.RowIndex >= 0) {
               // 오른쪽 버튼 클릭된 열
               DataGridViewCell cell = dbView[e.ColumnIndex, e.RowIndex];
               cell.Selected = !cell.Selected; // 선택상태 반전
           }
      }

  }  

한가지더 알려드리자면, 두번째 파라미터 DataGridViewCellMouseEventArgs클래스는 MouseClick이벤트핸들러의 파라미터인 MouseEventArgs클래스의 파생클래스입니다. 이 클래스는 마우스의 위치나 클릭된 버튼 종류를 알려주며 클릭된 열의 행번호와 열번호를 리턴해주는 RowIndex속성과 ColumnIndex속성이 추가되어 있고 헤더용 열이나 행이 클릭된 경우 속성은 -1로 처리됩니다.


16. 행 삭제시 확인메세지를 보여주고 싶을 때

행을 선택하고 Del키를 누르면 행을 삭제할 수 있습니다. 이럴 때 행의 삭제시 확인 메세지박스를 보여주는 형태를 구현하고 싶은 분들이 있을 것입니다. 이를 한번 구현해보이도록 하겠습니다.

DataGridView컨트롤에서는 행이 삭제될 때 UserDeletingRow이벤트핸들러가 발생합니다. 따라서 이 타이밍에 확인 메세지박스를 보여주는 것을 좋을 것같습니다. 그리고 한가지 팁으로 여러개의 행을 선택하고 Del키를 누르면 선택되어 있는 각 행별로 UserDeletingRow이벤트핸들러가 발생합니다.

또한 이 UserDeletingRow이벤트핸들러의 두번째 파라미터는 DataGridViewRowCancelEventArgs객체의 Cancel속성을 true로 설정하여 행삭제를 취소할 수 있습니다.

 

private void dbView_UserDeletingRow(object sender, DataGridViewRowCancelEventArgs e) {
       if (MessageBox.Show("삭제하시겠습니까?",

                                 "지정한 행삭제",

                                 MessageBoxButtons.YesNo) == DialogResult.No)
       {
             e.Cancel = true; //삭제 취소
       }
 }  


17. 열 순서를 마음대로 바꾸고 싶을 때

가끔 고객의 요구로 인해 열을 사용자가 원하는 순서대로 배치하고 싶은 경우가 나옵니다.
보통 열 순서변경은 마우스로 열 헤더를 드래그&드롭하여 처리할 수 있습니다.

AllowUserToOrderColumns속성을 true로 하면 간단하게 끝납니다.

dbView.AllowUserToOrderColumns = true;

http://blog.naver.com/gboarder 이곳에서 퍼온 http://blog.naver.com/kdllee 이분의 사이트에서 가져왔어요.

'정리없는자료 > .NET' 카테고리의 다른 글

ASP.NET string[]를 받아서 구분자로 구분, 문자열 리턴  (0) 2008.10.14
C# 폼 투명도 조절  (0) 2008.01.06
C# DataGridView 활용  (0) 2007.12.22
C# ComboBox에 이미지넣기  (0) 2007.12.22
비주얼스튜디오 단축키  (0) 2007.12.20
C# 위임(Delegate)  (0) 2007.12.15
Form1.cs
ComboBoxSe com = new ComboBoxSe(); // 전역
ImageList imageList1 = new ImageList();
imageList1.Images.Add(Image.FromFile(@"C:\...ico"));
imageList1.Images.Add(Image.FromFile(@"C:\...ico"));
com.ImageList = imageList1;
com.Width = 80;
com.Location = new System.Drawing.Point(180, 26);
com.Items.Add(new ComboBoxExItem("이미지", 0));
com.Items.Add(new ComboBoxExItem("이미지", 1));
this.Controls.AddRange(new System.Windows.Forms.Control[] { combo});

ComboBoxSe.cs (상속)
    class ComboBoxSe : ComboBox
    {
        private ImageList imageList;
        public ImageList ImageList{get { return imageList; }set { imageList = value; } }
        public ComboBoxSe()
        {
            DrawMode = DrawMode.OwnerDrawFixed;
        }

        protected override void OnDrawItem(DrawItemEventArgs ea)
        {
            ea.DrawBackground();
            ea.DrawFocusRectangle();

            ComboBoxExItem unit;
            Size imageSize = imageList.ImageSize;
            Rectangle bounds = ea.Bounds;

            try
            {
               생략.............
            }

            base.OnDrawItem(ea);
        }
    }

    class ComboBoxSeunit
    {
        private string stext;
        public string Text{get { return stext; } set { stext = value; }}
        private int simageIndex;
        public int ImageIndex{get { return simageIndex; }set { simageIndex = value; }}

        public ComboBoxSeunit(string text, int imageIndex)
        {
            stext = text;
            simageIndex = imageIndex;
        }

        public override string ToString(){return stext;}
    }

}

'정리없는자료 > .NET' 카테고리의 다른 글

C# 폼 투명도 조절  (0) 2008.01.06
C# DataGridView 활용  (0) 2007.12.22
C# ComboBox에 이미지넣기  (0) 2007.12.22
비주얼스튜디오 단축키  (0) 2007.12.20
C# 위임(Delegate)  (0) 2007.12.15
C# 스레드(thread)  (0) 2007.11.15
디버그/빌드
F5 : 디버그 시작
F9 :디버그 브렉포인트 설정
Ctrl-F9 : 현위치 설정된 브렉포인트 해제
Ctrl-Shift-F9 : 모든 브렉포인트 해
Shift-F5 : 디버그 빠져나오기
Ctrl-F10 : 커서가 있는곳까지 실행
Shift-F11 : 현 함수를 빠져나감.
Shift+Ctrl+B :  전체 빌드(프로젝트가 여러개있을경우 모두 빌드)
Alt+B, C : 해당 프로젝트만 정리.
Alt+B, U : 해당 프로젝트만 빌드.

창관련
Shift+Alt+Enter : 전체 창 (토글 됨)
F4 : 속성창 보여준다.
Ctrl+Alt+X : 리소스에디터 툴박스창
Ctrl+Alt+K : 작업목록 창.
Ctrl-K, Ctrl-H : 바로가기 설정. ( 작업목록 창에서 확인가능 )
Ctrl-K,K : 북마크 설정 / 해제
Ctrl-K,L : 북마크 모두 해제
Ctrl-K,N : 북마크 다음으로 이동
Ctrl-K,P : 북마크 이전으로 이동
Ctrl-K,C : 선택한 블럭을 전부 코멘트
Ctrl-K,U : 선택한 블럭을 전부 언코멘트(코멘트 해제)
Ctrl-F3 : 현재 단어 찾기
  -> F3 : 다음 찾기
Ctrl-F7 : 현 파일만 컴파일
Ctrl-Shift-B : 전체 프로젝트 빌드
Ctrl-F5 : 프로그램 시작
Ctrl-i : 일치하는 글자 연속적으로 찾기
Ctrl+ - (대시문자), Ctrl+Shift+ -  :
Ctrl-F12 : 커서위치 내용의 선언으로 이동
F12 : 커서위치 내용의 정의로 이동
Shift+Alt+F12 : 빠른기호찾기
F12 : 기호찾기
-----------------------------------------------------------------------------------------
Ctrl-M, Ctrl-L : 소스파일의 함수헤더만 보이기 (구현부는 감추고) (토글 키)
Ctrl-M, Ctrl-M : 현재 커서가 위치한 함수를 접는다/편다. (토글 키)
Ctrl-F : 찾기 대화상자
Ctrl-H : 바꾸기 대화상자
Ctrl-Shift-F : 파일들에서 찾기 대화상자
Ctrl-Shift-H : 파일들에서 바꾸기 대화상자
Ctrl-G : 해당 줄로 가기 (별로 필요없음)
Ctrl-K,Ctrl-F : 선택된 영역 자동 인덴트 (VS6의 Alt-F8기능)
Ctrl-] :괄호({,}) 쌍 찾기 : 괄호 앞이나 뒤에서 눌러서 닫거나, 여는 괄호이동
Ctrl-Shift-Spacebar : 함수이름편집중 툴팁으로나오는 함수와매개변수설명이 안나올경우, 강제로 나오게
alt-LButton ->Drag : 원하는 영역의 블럭을 세로로 잡기
Ctrl+Shift+V (히스토리 붙이기) : Ctrl + V와는 달리 클립보드에 있는 복사된내용을 돌아가면서 붙여준다.
Ctrl-Z : 이전으로 되돌리기
Ctrl-Shift-Z : 되돌렸다, 다시 복구하기


'정리없는자료 > .NET' 카테고리의 다른 글

C# DataGridView 활용  (0) 2007.12.22
C# ComboBox에 이미지넣기  (0) 2007.12.22
비주얼스튜디오 단축키  (0) 2007.12.20
C# 위임(Delegate)  (0) 2007.12.15
C# 스레드(thread)  (0) 2007.11.15
C# 윈도우 프로그래밍 예제파일  (0) 2007.11.14
여러개의 메서드를 동시에 호출한 것처럼 처리하기위해 위임(Delegate)형을 사용한다.
위임형은 delegate 키워드를 이용하여 선언한다.
public delegate void 위임이름(인수);

간단한 형태만알아보기 위해서 소스일부생략
public delegate void MyDelegate();
class MyClass{public void MyMethod(int x, int y)}
class MClass{
static void Main(){
MyClass mc = new MyClass();
//MyClass클래스의 인스턴스 mc를 생성합니다.
MyDelegate md = new MyDelegate(mc.MyMethod);
//mc.MyMethod메서드를 MyDelegate의 생성자에 인자 값으로 입력해서 MyDelegate형 md를 생성합니다.
md(3,4);
//위임형 md에 3,4를 입력해서 호출합니다.
}}

다중 위임 및 제거를 위해서는 +=연산자와 -=연산자를 이용한다.
md += new MyDelegate(mc.MyMethod);
md -= new MyDelegate(mc.MyMethod);

ex1)
public delegate void Mydelegate(string message);

    class Program
    {
        //static Mydelegate md = null;
        static event Mydelegate md = null;
        static void Main(string[] args)
        {
            Program p = new Program();
            string message = "한국";
            //p.OnDisplayMessage(message);
            //p.OnDisplayMessage(message);
            //Mydelegate md = null;
                md += new Mydelegate(p.OnDisplayMessage);
                md += new Mydelegate(p.OnDisplayMessage);
                md += new Mydelegate(p.NewOnDisplayMessage);
                //md(message);
                p.CallDelegate(md, message);
                md -= new Mydelegate(p.OnDisplayMessage);
                md -= new Mydelegate(p.OnDisplayMessage);
                if (md != null)
                {
                    md(message);
                }

        }
        private void CallDelegate(Mydelegate md, string msg)
        {
            md(msg);
        }
        private void OnDisplayMessage(string message)
        {
            Console.WriteLine(message);
        }
        private void NewOnDisplayMessage(string message)
        {
            Console.WriteLine(message+"메세지");
        }

    }




'정리없는자료 > .NET' 카테고리의 다른 글

C# ComboBox에 이미지넣기  (0) 2007.12.22
비주얼스튜디오 단축키  (0) 2007.12.20
C# 위임(Delegate)  (0) 2007.12.15
C# 스레드(thread)  (0) 2007.11.15
C# 윈도우 프로그래밍 예제파일  (0) 2007.11.14
C# Array for문 규칙  (0) 2007.11.13
Thread를 선언하기위해 System.Threading 네이스페이스를 추가합니다.
using System.Threading;

Thread의 주요 속성 및 메서드
Priority - 스레드의 우선순위를 나타내는 값을 가져오거나 설정
Abort() - 스레드를 종료하는 메서드
Sleep() - 지정된 수의 밀리초 동안 스레드 수행 중지
Start() - 스레드를 시작하는 메서드

ex1)
public static void Method(){}
static void Main(string[] args){
ThreadStart ts = new ThreadStart(Method);
//Thread 클래스의 생성자에 입력할 ThreadStart 위임형을 생성합니다.
Thread t1 = new Thread(ts);
//ThreadStart 위임형 ts를 인자로 입력해서 Thread형 t1를 생성합니다.
t1.Start();
//Thread형 객체 t1를 실행합니다.
}

'정리없는자료 > .NET' 카테고리의 다른 글

비주얼스튜디오 단축키  (0) 2007.12.20
C# 위임(Delegate)  (0) 2007.12.15
C# 스레드(thread)  (0) 2007.11.15
C# 윈도우 프로그래밍 예제파일  (0) 2007.11.14
C# Array for문 규칙  (0) 2007.11.13
C# string  (0) 2007.11.13
다음과 같은 폼을 생성하여 각각의 기능을 구현한 예제입니다.
BLClass.cs
using System;
using System.Collections.Generic;
using System.Text;
using System.Windows.Forms;

namespace WinListProgram.BL
{
    class BLClass
    {
        public void LBinsert(ListBox lb, string name)
        {
            lb.Items.Add(name);
        }
        public void LBinsert(ListBox lb, string name, bool b)
        {
            if (!b)
            {
                if (lb.Items.Contains(name)) return;
            }
            lb.Items.Add(name);
            object[] oa = new object[lb.Items.Count];
            lb.Items.CopyTo(oa, 0);
            System.Array.Sort(oa);
            lb.Items.Clear();
            lb.Items.AddRange(oa);
        }
        public void LBAllClear(params ListBox[] la)
        {
            foreach (ListBox b in la)
            {
                b.Items.Clear();
            }
        }
        public void SelectMove(ListBox source, ListBox target)
        {
            int no = source.SelectedItems.Count;
            System.Collections.IEnumerator ie;

            ie = source.SelectedItems.GetEnumerator();
            while (ie.MoveNext())
            {
                target.Items.Add(ie.Current.ToString());
            }
            int[] ia = new int[no];
            source.SelectedIndices.CopyTo(ia, 0);
            System.Array.Reverse(ia);
            for (int i = 0; i < ia.Length; i++)
            {
                source.Items.RemoveAt(ia[i]);
            }

        }
    }
}


사용자 삽입 이미지

Form1.cs
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using WinListProgram.BL;

namespace WinListProgram
{
    public partial class Form1 : Form
    {
        public Form1()
           
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            try
            {
                this.listBox1.SelectedIndexChanged -= new System.EventHandler(this.listBox1_SelectedIndexChanged); string name = this.listBox1.SelectedItem.ToString();
                int no = this.listBox1.SelectedIndex;
                this.bc.LBinsert(this.listBox2, name);
                this.listBox1.Items.RemoveAt(no);

                this.listBox1.SelectedIndexChanged += new System.EventHandler(this.listBox1_SelectedIndexChanged);
            }
            catch (Exception)
            { }
        }

        private void button2_Click(object sender, EventArgs e)
        {
            try
            {
                this.listBox2.SelectedIndexChanged -= new System.EventHandler(this.listBox2_SelectedIndexChanged);
                int no = this.listBox2.SelectedIndex;
                string name = this.listBox2.Items[no].ToString();
                this.bc.LBinsert(this.listBox1, name, true);

                this.listBox2.Items.RemoveAt(no);
                this.listBox2.SelectedIndexChanged += new System.EventHandler(this.listBox2_SelectedIndexChanged);
            }
            catch (Exception)
            { }
           
        }

        private void button3_Click(object sender, EventArgs e)
        {
            this.listBox1.SelectedIndexChanged -= new System.EventHandler(this.listBox1_SelectedIndexChanged);
            this.bc.SelectMove(this.listBox1, this.listBox2);
            this.listBox1.SelectedIndexChanged += new System.EventHandler(this.listBox1_SelectedIndexChanged);
        }
       

        private void button4_Click(object sender, EventArgs e)
        {
            this.listBox2.SelectedIndexChanged -= new System.EventHandler(this.listBox2_SelectedIndexChanged);
            this.bc.SelectMove(this.listBox2, this.listBox1);
            this.listBox2.SelectedIndexChanged += new System.EventHandler(this.listBox2_SelectedIndexChanged);
        }

        private void button5_Click(object sender, EventArgs e)
        {
            this.bc.LBAllClear(this.listBox1,this.listBox2);
        }

        private void button6_Click(object sender, EventArgs e)
        {
            string name = this.textBox1.Text;
            if (string.IsNullOrEmpty(name))
            {
                return;
            }
            this.bc.LBinsert(this.listBox1, name, false);
            this.textBox1.Clear();
            ToolTip tp = new ToolTip();
            tp.SetToolTip(this.textBox1,name+ "입력");
            this.textBox1.Focus();
            int no = this.listBox1.Items.Count; //스크롤바 항목선택
            this.listBox1.SelectedIndex = no - 1;
        }

        private void button7_Click(object sender, EventArgs e)
        {
            Application.Exit();
        }

        private void listBox2_SelectedIndexChanged(object sender, EventArgs e)
        {
            try
            {
                this.textBox1.Text = this.listBox2.SelectedItem.ToString();
                this.textBox1.Tag = "listBox2:" + this.listBox2.SelectedIndex.ToString();
            }
            catch (Exception)
            { }
        }
        private void listBox1_SelectedIndexChanged(object sender, EventArgs e)
        {
            try
            {

                this.textBox1.Text = this.listBox1.SelectedItem.ToString();
                this.textBox1.Tag = "listBox1:" + this.listBox1.SelectedIndex.ToString();
            }
            catch (Exception)
            { }
        }

        private void textBox1_KeyDown(object sender, KeyEventArgs e)
        {

            if (e.KeyData == Keys.Enter)//if (e.KeyCode == (char)13)
            {
                this.button6_Click(this, null);
            }

        }

        private void button8_Click(object sender, EventArgs e)
        {

            int no = this.listBox1.Items.Count;
            object[] oa = new object[no];
            this.listBox1.Items.CopyTo(oa, 0);
            foreach (object o in oa)
            {
                if (!this.listBox2.Items.Contains(o)) //중복제거
                    this.listBox2.Items.Add(o);
            }
            this.listBox1.Items.Clear();

        }

        private void button9_Click(object sender, EventArgs e)
        {
            int no = this.listBox2.Items.Count;
            object[] oa = new object[no];
            this.listBox2.Items.CopyTo(oa, 0);
            foreach (object o in oa)
            {
                if (!this.listBox1.Items.Contains(o)) //중복제거
                    this.listBox1.Items.Add(o);
            }
            this.listBox2.Items.Clear();

        }

       
    }
}

'정리없는자료 > .NET' 카테고리의 다른 글

C# 위임(Delegate)  (0) 2007.12.15
C# 스레드(thread)  (0) 2007.11.15
C# 윈도우 프로그래밍 예제파일  (0) 2007.11.14
C# Array for문 규칙  (0) 2007.11.13
C# string  (0) 2007.11.13
C# object  (0) 2007.11.06
Console.WriteLine("2차원배열-----------------------------------");
            char[,]  cd = new char[4,64];
            for(int s = 0;s < 4; s++)
            {
                for(int t = 0; t < 64;t++)
                {
                    cd[s, t] = (char)(64*s+t);
                }
            }
            for (int s = 0; s < 4; s++)
            {
                for (int t= 0; t< 64; t++)
                {
                   Console.Write("{0} ", cd[s,t]);
                }
            } Console.WriteLine();

Console.WriteLine("3차원배열-----------------------------------");
            char[,,] cb = new char[2, 8, 16];
            int k = 0;
            for (int x = 0; x < 2; x++)
            {
                for (int y = 0; y < 8; y++)
                {
                    for (int z = 0; z < 16; z++)
                    {
                        k = 16 * 8 * x + 16 * y + z; cb[x, y, z] = (char)k;
                    }
                }
            } 
            for (int x = 0; x < 2; x++)
            {
                for (int y = 0; y < 8; y++)
                {
                    for (int z = 0; z < 16; z++)
                    {
                        Console.Write("{0} ", cb[x, y, z]);
                    }   Console.WriteLine();
                }
            } 
            Console.WriteLine("{0} {1} {2} {3}space", (char)48, (char)97, (char)65,(char)32);
Console.WriteLine("4차원배열-----------------------------------");
          
            char[, , ,] cc = new char[2, 8, 2, 8];

            for (int a = 0; a < 2; a++)
            {
                for (int b = 0; b < 8; b++)
                {
                    for (int c = 0; c < 2; c++)
                    {
                       for (int d = 0; d < 8; d++)
                    {
                        cc[a, b, c, d] = (char)(8 * 2 * 8 * a + 2 * 8 * b + 8 * c + d);
                    }
                    }
                }
            }
            for (int a = 0; a < 2; a++)
            {
                for (int b = 0; b < 8; b++)
                {
                    for (int c = 0; c < 2; c++)
                    {
                        for (int d = 0; d < 8; d++)
                        {
                            Console.Write("{0,3} ",cc[a, b, c,d]);
                        } Console.WriteLine();
                    }
                }
            }

'정리없는자료 > .NET' 카테고리의 다른 글

C# 스레드(thread)  (0) 2007.11.15
C# 윈도우 프로그래밍 예제파일  (0) 2007.11.14
C# Array for문 규칙  (0) 2007.11.13
C# string  (0) 2007.11.13
C# object  (0) 2007.11.06
C# interface  (0) 2007.11.06

+ Recent posts