퇴근5분전

WinApi.co.kr 에 존재하는 C언어에 테트리스를 분석해서 만들어낸 테트리스임. (버그 다수 존재 함)

프로그래밍을 하게 되면 반듯이 작성해야지 했던 게임이었는데
만들고 나니 어찌나 기쁘던지...

자료구조도 알고리즘도 프로그램 로직 자체도 서툴렀던 시절
C언어로 된 테트리스 로직을 분석하고 만들어내었을때 비약적인 발전을 할수 있었음.
GDI+라든가 배열사용이라든가, 게임시 동작을 처리 하는 부분에 대해서라든가.
이것도 역시 바둑판 그리기가 사용된다. 배경을 그리고 블럭을 그리는데 사용됨.

사용자 삽입 이미지

<< 테트리스 화면 >>

테트리스 소스임


 

'# 2) .Net ( Vs 2005 ) > WinForm' 카테고리의 다른 글

메뉴] 즐겨찾기 읽어들이기  (0) 2009.05.08
그래픽스. 어디에 그려지는가?  (0) 2009.05.08
아날로그 시계  (0) 2009.05.02
HTML 자동 정렬 프로그램  (0) 2009.05.02
FND를 이용한 디지탈 시계  (0) 2009.05.02

메세지박스

# 6) JavaScript2009. 5. 2. 22:23

사용자 삽입 이미지

<< Web MessageBox >>


자바스크립트를 막 시작하고 재미 붙어서 이거저거 만들때 만들었던 것임.
자바스크립트로 메세지 박스객체를 만들어서 사용함 소스 참조.

테스트용: 블로그안에서 실행해서 그런지 간만에 자바스크립트로 스크롤 값을 가져올수가 없넹... 그냥 폼에 박힌 레이어로 구성함.

결과값 :
사용자 삽입 이미지
사용자 삽입 이미지
사용자 삽입 이미지
사용자 삽입 이미지
사용자 삽입 이미지
사용자 삽입 이미지
소스    

사용자 삽입 이미지
<< 아날로그시계 >>


초단위로 똑딱 똑딱 흐르니 아날로그라고 하긴 그렇지만 ... 뭐 어쨌거나...

분,초는 360도를 60으로 나눠서 초당 6도씩 이동시키며
시는 360도를 12로 나눠서 30도씩 이동시킴. ㅡ.,ㅡ;;

시계 표시는 행렬 로테이션을 이용해서 표시함

초 각 : Convert.ToSingle(this.secPin.IdentityRadian(DateTime.Now.Second) * 6);
분 각 : Convert.ToSingle( this.minPin.IdentityRadian(DateTime.Now.Minute) * 6);
시 각 : Convert.ToSingle( (this.hourPin.IdentityRadian(DateTime.Now.Hour)%12)* 5 * 6);


'# 2) .Net ( Vs 2005 ) > WinForm' 카테고리의 다른 글

그래픽스. 어디에 그려지는가?  (0) 2009.05.08
테트리스  (0) 2009.05.02
HTML 자동 정렬 프로그램  (0) 2009.05.02
FND를 이용한 디지탈 시계  (0) 2009.05.02
FND( SevenSegment )  (0) 2009.05.02

 이 프로그램은 수성정보통신에 처음 입사했을 당시 계시던 부장님이 DB 프로시져에 HTML코드를 직접 넣어 뿌리다보니 HTML 태그가 안맞아서 오류가 많이 생겨서 그걸 정리하기 위해 만들어 드렸던 프로그램임.

 이때는 정규식도 모를때고 한참 알고리즘 공부할때라서..
HTML파싱을 좀 독특하게 했음. 그래프 알고리즘을 적용해서 만들었음. 참 특이했던 것임.

  에피소드 : DB만 하실줄 아시던 부장님이 웹프로그래머가 DB 데이타를 받아서 다시 그걸 테이블태그를 붙여서 플래이스홀더 컨트롤에 바인딩 하는것을 보고 DB에서 다 해줄테니 그냥 붙여넣으라고 했다는... 웹프로그래머는 asp.net 1년차 였음. 나역시 윈폼1년하고 웹폼을 배워보고자 들어가서 보았을때 첨엔 asp.net은 그렇게 작업하는줄 알았음...


사용자 삽입 이미지
* 정렬 후 긴 소스같은경우 해당 위치를 보기 위해 빨간선으로 위치를 알수 있도록 표시


ps : 다 구현하고 프로젝트 끝나갈 무렵 vs2005에 보니 정렬기능이 있더라눈... 쿨럭!

'# 2) .Net ( Vs 2005 ) > WinForm' 카테고리의 다른 글

테트리스  (0) 2009.05.02
아날로그 시계  (0) 2009.05.02
FND를 이용한 디지탈 시계  (0) 2009.05.02
FND( SevenSegment )  (0) 2009.05.02
데이타베이스 브라우져 ver2  (0) 2009.05.02

앞서 설명한 FND를 컨트롤로 만들어두었던것을
이용해서 시계를 만들었음.

사용자 삽입 이미지

다시봐도 나름 잘 만들었넹...

'# 2) .Net ( Vs 2005 ) > WinForm' 카테고리의 다른 글

아날로그 시계  (0) 2009.05.02
HTML 자동 정렬 프로그램  (0) 2009.05.02
FND( SevenSegment )  (0) 2009.05.02
데이타베이스 브라우져 ver2  (0) 2009.05.02
처음 만든 이미지 뷰어  (0) 2009.05.02

사용자 삽입 이미지

<< FND >>


FND는 LED를 위와같이 배열하여 하나의 디스플레이 소자로써 숫자나 영문 표시를 한다.

실제 부품 핀 번호를 위에 A~ G까지 써놓았고 여기에 Com 단자와 Dot표시 Led가 존재한다.

다만 프로그래밍에서 제외시켰음.


이 프로그래밍은 C#을 막 시작해서 5달째쯤 되어 시간이 좀 되던중에 디지탈 숫자 표시에 관련된
얘기를 듣고 마침 객체지향에 대해 막 궁금해 하던 시절에 이걸 만들었었다. 아 ~ 옛날이여~~

 내가 전자과라서 전자 부품은 거의 모두 알고 있었던 시절이었으니 부품에 대해 그리 사전조사가 필요없었고. 당시 객체 지향에 맞는 코드를 만들어보고자 위 FND를 설계후 디지탈 시계를 만들었었음.


    /// <summary>
    /// fillup: 채우다,
    /// BackColor : 바탕색,
    /// UserColor : 사용자 정의색
    /// </summary>
    enum FillUp {BacKColor,UserColor};
    enum SegmentArray {a,b,c,d,e,f,g};


//핀 번호와 Led 표시상태를 구분짓는 값이다. Led가 On, Off되면서 숫자가 표시되므로
이 값을 위처럼 구분짓는다.

        /// <summary>
        /// 모서리 옵셋값
        /// </summary>
        float angleoffsetvalue = 9f;
        public float AngleOffsetValue
        {
            get { return angleoffsetvalue;  }
            set { angleoffsetvalue = value;
            CVPointSegments.Calculat(this.Size, angleoffsetvalue, thinkness);
            }
        }

// 이것은 Led 하나의 다각형 그림을 그릴때 그 모서리를 뽀족하게 할것인지 말것인지를 결정하는 값이다.

  /// <summary>
        /// 세그먼트 두께 값.
        /// </summary>
        float thinkness = 7f;
        public float SegmentThinkness
        {
            get { return thinkness;  }
            set { thinkness = value;
            CVPointSegments.Calculat(this.Size, angleoffsetvalue, thinkness);
            }
        }

// 이것은 세그먼트 표시되는 Led표시부의 두께 값이다.

        /// <summary>
        /// 외곽선 유무 기본값 : true
        /// </summary>
        Boolean  displayouterwall = true;
        public Boolean DisplayOuterWall
        {
            get {return displayouterwall;  }
            set {displayouterwall = value; }
        }
// 이것은 표시될때 Led의 외곽선 표시임.

        /// <summary>
        /// 디스플레이~~!! 될 번호... 숫자 0~ 9 가운데...
        /// </summary>
        int displayIndex = 0;
        public int DisplayNumber
        {
            get { return displayIndex;  }
            set {
                    displayIndex = value % 10;
                }
        }
// 표시될 숫자

        /// <summary>
        /// Segment 컬러.
        /// </summary>
        Color   usercolor = Color.Red;
        public Color UserColor{
            get {return usercolor;}
            set {usercolor  = value;}
        }
// Led 색상이 되겠다.

        string[][] DisplayNumbers = new string[10][]
            {
                 new string[] {"a","b","c","d","e","f"}, // 0
                 new string[] {"b","c"}, // 1
                 new string[] {"a","b","g","d","e"}, // 2
                 new string[] {"a","b","c","d","g"}, // 3
                 new string[] {"b","c","g","f"}, // 4
                 new string[] {"a","f","g","c","d"}, // 5
                 new string[] {"a","f","g","c","d","e"}, // 6
                 new string[] {"a","b","c"}, // 7
                 new string[] {"a","b","c","d","e","f","g"}, // 8
                 new string[] {"a","b","c","d","g","f"} // 9
            };

위 표시는 숫자값에 따른 켜질 Led다!

위에만 봐도 FND의 실제 동작을 가늠할 수 있지 아니한가?

위에는 동작관련된것이고.

아래는 세그먼트 표시관련된 것.


            //                                                      |offset|
            //                  sp2******************sp3
            //         sp1******************************sp4         <== 세그먼트 1개
            //                  sp6******************sp5
            //    halfhinkness : 두께의 절반.
            //
이것이 기본 컨셉이었다!!
오~~ 그땐 그래도 머리가 잘 돌았나부다. 하하하!!

사용자 삽입 이미지

<< 외곽선 사용여부 >>


사용자 삽입 이미지

<< FND 색 변경 >>



사용자 삽입 이미지

<< AngleOffSet 값 변경 >>

실제 존재하는 부품 동작 그대로를 프로그래밍 해보았음.



 

'# 2) .Net ( Vs 2005 ) > WinForm' 카테고리의 다른 글

HTML 자동 정렬 프로그램  (0) 2009.05.02
FND를 이용한 디지탈 시계  (0) 2009.05.02
데이타베이스 브라우져 ver2  (0) 2009.05.02
처음 만든 이미지 뷰어  (0) 2009.05.02
폼간 데이타 전달  (0) 2009.05.02

사용자 삽입 이미지


게임횟수

로또 소스임

'# 6) JavaScript' 카테고리의 다른 글

메뉴] 자바스크립트로 만든 메뉴 객체  (0) 2009.05.09
자바스크립트 Array사용  (0) 2009.05.08
자바스크립트 디버거  (0) 2009.05.08
웹 에서 F1키 사용하기.  (0) 2009.05.08
메세지박스  (0) 2009.05.02

로컬로 Window모드로 데이타베이스에 접근하고자 할때!

Integrated Security=SSPI;Persist Security Info=False;Initial Catalog={데이타베이스명};Data Source=localhost


'# 2) .Net ( Vs 2005 ) > 기타' 카테고리의 다른 글

PWD 암호화 객체.  (0) 2009.05.08
인터페이스와델리게이트조합1  (2) 2009.05.08
큐브~  (0) 2009.05.02
XML 컨트롤...  (0) 2009.05.02
DB Connection Factory  (0) 2009.05.01

이건 데이타베이스 브라우져 버젼2 로써
앞에 블로깅 한 것에 이전버젼으로 초기에 만들어졌던 브라우져보다 조금 독특한 방식으로 동작됨.

사용자 삽입 이미지
<< 프로그램 설정 관련 화면 >>

사용자 삽입 이미지
<< Insert 관련 화면 >>
* 수정이나 삭제 역시 이화면으로 사용됨.

UI는 정말 어쩔수 없는듯 함.


제작의도!
 원래는 취업의도로 부족한 경력을 조금이라도 어필해보고자 만들었던 것이고
1년정도 C#을 했던 경험과 공부했던 지식들을 모아서 만들었었음.

 이 프로그램은 DB와 상호 작용시 프로시져를 이용하며, 그때 만들어져있던 프로시져생성기와 더블어 사용하게되며 프로시져를 제작 후 해당 프로시져를 프로그램에 등록하게 되면 자동으로 UI를 표출하고 데이타를 가져와서 뿌려주고 추가 수정 삭제 작업역시 동일하게 구현이 됨.

 이 기능들을 바탕으로 조금더 나은 UI를 그려내고자 작업하다가 이번에 새로운 브라우져가
만들어졌었다.

UI참... 거시기 하네~~


'# 2) .Net ( Vs 2005 ) > WinForm' 카테고리의 다른 글

FND를 이용한 디지탈 시계  (0) 2009.05.02
FND( SevenSegment )  (0) 2009.05.02
처음 만든 이미지 뷰어  (0) 2009.05.02
폼간 데이타 전달  (0) 2009.05.02
그리드뷰 컨트롤  (0) 2009.05.02

사용자 삽입 이미지

기능1 : 단순한 이미지 뷰어 기능
기능2 : 알집을 이용해서 압축된 이미지 파일 관리

지정된 폴더내에 알집을 이용해서 풀어놓고 볼수 있게되며
파일 관리 한곳에 몰아놓을수 있어서 쉬워짐.

다시만든다고 하면... 좀더 멋지게 나오겠지??????


'# 2) .Net ( Vs 2005 ) > WinForm' 카테고리의 다른 글

FND( SevenSegment )  (0) 2009.05.02
데이타베이스 브라우져 ver2  (0) 2009.05.02
폼간 데이타 전달  (0) 2009.05.02
그리드뷰 컨트롤  (0) 2009.05.02
SMS TextLength 비교  (0) 2009.05.01