반응형

오늘은 가성비 좋은 ASUS PRIME B360M-A STCOM 메인보드를 소개합니다.



ASUS PRIME B360M-A STCOM는 인터넷에서 10만 원 초반 가격에 구입할 수 있습니다.
최신 인텔 8세대 CPU를 사용할 수 있고 LGA 1151v2 소켓을 지원합니다.



ASUS PRIME B360M-A STCOM  박스 전면 사진입니다.
3년 품질 보증을 지원하고 ASUS 공식 직영점 에스티 컴퓨터에서 AS 가능합니다.



ASUS PRIME B360M-A STCOM 박스 하단 좌측에는 제품 특징이 출력되어 있습니다.
눈에 띄는 특징은 VR READY 기능 지원과 인텔 Optane Memory 지원입니다.



ASUS PRIME B360M-A STCOM  박스 하단 우측에는 또 다른 특징이 출력되어 있습니다.



ASUS PRIME B360M-A STCOM  박스 후면 사진입니다.
제품 사양 및 특징이 출력되어 있습니다.
ASUS Fan Xper 2+ 기능은 소프트웨어로 UEFI 바이오스를 통해서 팬을 제어할 수 있다고 합니다.
ASUS 5X Protection III는 높은 내구성을 뜻 한다고 합니다.



ASUS PRIME B360M-A STCOM 박스를 오픈했습니다.



ASUS PRIME B360M-A STCOM 구성품은 본체, 매뉴얼, 설치 드라이버 CD, 백패널, SATA 케이블 2개로 되어 있습니다.



ASUS PRIME B360M-A STCOM  설명서 사진입니다.
기본적인 기능만 사용하시면 설명서는 스킵 하시면 됩니다.



ASUS PRIME B360M-A STCOM  전면 사진입니다.



ASUS PRIME B360M-A STCOM는 6개의 SATA 케이블을 연결할 수 있습니다.
오른쪽 상단부터 1번 ~ 6번까지입니다.
중간 건전지는 보드 세팅이 저장 안 될 경우 교체하시면 됩니다.
ASUS 로고가 각인된 방열판이 있습니다.



ASUS PRIME B360M-A STCOM는 2개의 M.2 슬롯을 지원합니다.
요즘 인텔에서 개발된 Optane Memory를 사용할 수 있어 기존 HDD에 새로운 속도도 함께 느낄 수 있습니다.
ASUS PRIME B360M-A STCOM는 Realtek ALC887 8-channel high definition audio CODEC
을 지원합니다.



ASUS PRIME B360M-A STCOM 그래픽 카드 슬롯 사진입니다.
일반 슬롯에 비해 1.6배 강한 유지력과 1.3배 높은 전단 저항 기능이 있다고 합니다.



ASUS PRIME B360M-A STCOM  CPU 소켓 사진입니다.
LGA 1151 소켓을 사용하고 있으며 지원범위는 8세대 Pentium부터 i7까지입니다.
5000시간의 내구성을 갖는 일본산 캐패시터가 적용되어 있습니다.



ASUS PRIME B360M-A STCOM  Memory 슬롯 사진입니다.
DDR4 4개의 슬롯을 지원하며 최대 64GB까지 확장할 수 있습니다.
DDR4 2666/24000/2133MHz를 사용할 수 있습니다.



ASUS PRIME B360M-A STCOM 후면 포트 사진입니다.
키보드, 마우스 포트, D-sub, DBI-D, HDMI, USB3.1 x 2, Type-C,
USB 2.0 x 2, Gigabit LAN 포트, 오디오 포트로 구성되어 있습니다.



ASUS PRIME B360M-A STCOM  USB 3.1 소켓 사진입니다.
보드에 있는 파란색 케이블을 연결하면 USB 3.1을 사용할 수 있습니다.



ASUS PRIME B360M-A STCOM은 RGB LED 컨트롤러인 Aura Sync 가 적용되어 있습니다.
RGB LED 튜닝이 가능해서 더욱더 화려한 PC를 만나실 수 있습니다.



ASUS PRIME B360M-A STCOM  후면 사진입니다.
가장 큰 특징은 우측 하단에 전원이 들어올 경우 LED가 점등되는 LED 일루미네이션이 적용되어 있습니다.



ASUS PRIME B360M-A STCOM  CPU 설치 사진입니다.



ASUS PRIME B360M-A STCOM  CPU 펜 설치 사진입니다.



ASUS PRIME B360M-A STCOM  메모리 설치 사진입니다.



ASUS PRIME B360M-A STCOM 오디오 케이블 연결 사진입니다.



ASUS PRIME B360M-A STCOM  USB 케이블 연결 사진입니다.



ASUS PRIME B360M-A STCOM  전원 케이블 연결 사진입니다.



ASUS PRIME B360M-A STCOM  그래픽 카드 설치 사진입니다.



ASUS PRIME B360M-A STCOM을 설치하고 전원을 켜니까 LED 일루미네이션이 동작합니다.



ASUS PRIME B360M-A STCOM  바이오스 화면입니다.
PC 정보, FAN 상태, SATA 정보를 한눈에 확인 가능합니다.



ASUS PRIME B360M-A STCOM   MAIN 탭 사진입니다.
언어 설정 등 기본적인 설정을 할 수 있습니다.



ASUS PRIME B360M-A STCOM  바이오스 Ai Tweaker 모드 사진입니다.



ASUS PRIME B360M-A STCOM  바이오스 고급 모드 사진입니다.
다양한 구성을 확인할 수 있습니다.
기본적으로 이런 게 있구나 하고 보시면 될 거 같습니다.



ASUS PRIME B360M-A STCOM  바이오스 모니터 모드 사진입니다.
온도, 전압을 확인할 수 있습니다.



ASUS PRIME B360M-A STCOM  바이오스 부팅 모드 사진입니다.



ASUS PRIME B360M-A STCOM  바이오스 Tool 모드 사진입니다.



ASUS PRIME B360M-A STCOM  설치 후 OS를 재 설치했습니다.
WIN 10에서는 그냥 사용해도 되지만 그래도 가비지 드라이버를 삭제하기 위해서 포맷을 선택했습니다.
하드웨어 모니터 프로그램을 사용해서 전체적으로 상태를 확인했습니다.



3D MARK 테스트 사진입니다.
6189점이 나왔습니다.



최근에 구매한 배틀필드 1 실행 사진입니다.

ASUS PRIME B360M-A STCOM는 8000시간 이상 테스트를 통해서
내구성이 좋은 제품으로 안심하고 사용할 수 있습니다.
최신 인텔 8세대 칩셋을 지원하고 있어 더욱 높은 사양을 사용할 수 있습니다.
또한 1000개 이상의 구성요소 호환성 테스트를 거쳐서 다양한 환경에 자유롭게 사용할 수 있습니다.
Optane Memory를 지원하는 M.2 소켓이 2개 있어 확장성이 좋습니다.

가성비 좋으면서 다양한 튜닝을 즐기고 싶다면 ASUS PRIME B360M-A STCOM  한번 검색해보세요.

"이 체험기는 (주)에스티컴퓨터와 다나와 체험단 행사를 통해 제품을 제공받아 작성하였습니다."

  


반응형

'IT 나라 > 프로그램 이야기' 카테고리의 다른 글

무료 로고 만들기 cooltext  (1) 2020.01.21
자마린(Xamarin) ABI 오류 해결 방법  (0) 2020.01.17
Sumatra PDF  (0) 2018.04.10
이클립스에서 PHP 사용하기  (0) 2018.03.26
Visual Studio code에서 Go 실행하기  (0) 2018.02.02
반응형

pdf 파일을 설치 없이 간편하게 확인할 수 있는 Sumatra PDF를 소개합니다.
 Sumatra PDF는 오픈 소스 포터블 실행 파일을 지원하고 있어
설치 없이 pdf를 오픈할 수 있습니다.



상기 사이트로 이동해서 "Download for here"를 클릭합니다.



Sumatra PDF를 사용하기 위해서 Portable 파일을 다운로드합니다.
x64일 경우 아래쪽 링크를 클릭합니다.



링크를 클릭하면 자동으로 Sumatra PDF를 다운로드합니다.



다운로드 파일을 압축 풀기를 실행합니다.



보시는 것처럼 한 개의 파일만 있습니다.



압축을 풀고 생성된 Sumatra PDF 실행 파일입니다.



Sumatra PDF 실행 파일을 클릭하면 Sumatra PDF가 바로 실행됩니다.
문서 열기를 클릭해서 pdf를 선택합니다.



Sumatra PDF  확인 결과 상위 버전 pdf 파일도 잘 출력됩니다.

간단하게 pdf 파일을 확인하고 싶다면 Sumatra PDF 한번 검색해보세요.

이상입니다.


반응형
반응형

오늘은 이클립스에서 PHP 설치 방법을 알아보겠습니다.



먼저 이클립스를 실행해서 메뉴에 있는 "Help" -> "Install New Software"를 클릭해주세요.



"Work with"에 "http://download.eclipse.org/releases/버전" url을 입력 후
아래쪽에 php를 입력하면 리스트가 활성화됩니다.



활성화된 PHP 패키지를 선택하고 아래쪽에 있는 "Next"를 클릭합니다.



PHP 인스톨 정보가 선택되고 다시 "Next"를 클릭합니다.



License 동의를 선택하고 "Finish"를 클릭하면
PHP가 설치됩니다.



PHP 설치 후 이클립스를 재시작하면 PHP를 선택할 수 있습니다.
Open Perspective를 설정하기 위해서 이클립스 상단 오른쪽 아이콘을 클릭합니다.



PHP를 선택하면 이클립스 UI가 변경됩니다.



Project에서 PHP Project를 클릭합니다.



PHP 프로젝트명을 설정하고 "Finish" 버튼을 클릭하면 PHP Project가 실행됩니다.
이상으로 마치겠습니다.


반응형

'IT 나라 > 프로그램 이야기' 카테고리의 다른 글

ASUS PRIME B360M-A STCOM  (0) 2018.08.23
Sumatra PDF  (0) 2018.04.10
Visual Studio code에서 Go 실행하기  (0) 2018.02.02
Go 언어 설치 방법  (0) 2018.02.01
MFC Dialog Class Name 변경 방법  (0) 2017.08.22
반응형

Visual Studio code를 사용하기 전에 Go를 설치해야 합니다.
Go 설치는 주소를 참고해주세요.
http://jazzkim12.blog.me/221198504157


1. Visual Studio code 설치하기 위해서 다운로드 사이트로 이동합니다.
https://code.visualstudio.com/


왼쪽에 있는 다운로드를 클릭해서 Visual Studio code를 설치합니다.

2. Visual Studio code 실행 후 Ctrl + Shift + p 실행 후 Install Extensions를 입력 후 엔터
    Go for Visual Studio Code를 설치합니다.




3. Go 설치 정보를 확인합니다.
cmd를 실행 후 "go env"를 실행합니다.



정보 중 GOPATH 폴더에 연동 모듈을 다운로드해야 합니다.

4. 다운로드 프로그램을 설치합니다.
 https://git-scm.com/download/win

Git이 설치 안되어 있으면 다운로드 입력시 아래 사진처럼 error가 출력됩니다.


정상적으로 다운로드 시는 Error 목록이 출력 안됩니다.
전 GOPATH가 정상적으로 되어 있어도 안되었습니다.
그래서 설치된 "Gtt CMD"를 사용하니 정상적으로 실행되었습니다.

5. "Get CMD"를 실행 후 아래 명령어를 입력 후 엔터를 입력합니다.
go get -u -v github.com/nsf/gocode
go get -u -v github.com/rogpeppe/godef
go get -u -v github.com/zmb3/gogetdoc
go get -u -v github.com/golang/lint/golint
go get -u -v github.com/lukehoban/go-outline
go get -u -v sourcegraph.com/sqs/goreturns
go get -u -v golang.org/x/tools/cmd/gorename
go get -u -v github.com/tpng/gopkgs
go get -u -v github.com/newhook/go-symbols
go get -u -v golang.org/x/tools/cmd/guru
go get -u -v github.com/cweill/gotests/...
go get -u -v golang.org/x/tools/cmd/godoc
go get -u -v github.com/fatih/gomodifytags 



정상적으로 설치되었다면 다운로드가 실행됩니다.



다운로드 후 GOPATH bin 폴더로 이동하면 다수의 exe가 생성됩니다.

6. go Debugger 설치하기
"Git CMD"를 실행 후
go get github.com/derekparker/delve/cmd/dlv
상기 명령어를 실행합니다.

7. GOPATH 아래 src 폴더에서 test.go 파일을 생성하고 아래 코드를 입력합니다.

package main 
import "fmt" func 
main() { 
 fmt.Print("hello. Go world \n") 
 fmt.Print("Test1234") 
}



저장 후 'F5'를 클릭하면 컴파일 되면서 디버그 콘솔에 출력됩니다.
이상으로 마치겠습니다.

[참고 사이트]
https://blog.naver.com/icarus_buk/220969321927
http://realmojo.tistory.com/147


반응형

'IT 나라 > 프로그램 이야기' 카테고리의 다른 글

Sumatra PDF  (0) 2018.04.10
이클립스에서 PHP 사용하기  (0) 2018.03.26
Go 언어 설치 방법  (0) 2018.02.01
MFC Dialog Class Name 변경 방법  (0) 2017.08.22
C# TOPMOST MessageBox 사용하기  (0) 2017.07.31
반응형

오늘은 구글에서 개발한 Go 언어 설치 방법을 알아보겠습니다.
Windows10 x64에서 설치했습니다.



Go 언어를 설치하기 위해서는 
https://golang.org/



우측에 있는 Download Go를 클릭하면 다운로드 페이지로 이동합니다.
https://golang.org/dl/



다운로드 페이지로 이동하면서 go1.9.3.wwindows-amd64.msi가 다운로드 됩니다.



Go 언어 설치 파일 go1.9.3.wwindows-amd64.msi를 더블클릭합니다.



Go 언어 설치 경로를 입력합니다.
기본 C 드라이브에 설정됩니다.



Go 언어 설치 완료 화면입니다.



환경 변수를 확인하기 위해서 시스템에서 '고급 시스템 설정'을 클릭합니다.



시스템 속성에서 '환경 변수'를 클릭합니다.



위 사진처럼 환경 변수 편집에 'C\Go\bin' 경로가 있으면 정상적으로 설치된 겁니다.
자동 등록이 되어 매우 편리합니다.
Go 언어 설치를 마치겠습니다.


반응형
반응형

오늘은 MFC Dialog Class Name 변경 방법을 알아보겠습니다.













프로젝트 생성 후  리소스 뷰로 이동합니다.
프로젝트.rc를 선택하고 속성을 클릭하면 MFC Mode 필드를 False로 변경합니다.














변경하고 싶은 Dialog를 선택 후 속성을 클릭합니다.

상단에 보이는 Class Name를 변경합니다.




다시 프로젝트.rc를 선택 후 MFC Mode를 True로 변경합니다.






프로젝트.rc파일을 텍스트로 확인하면 CLASS 명이 변경된 것을 확인할 수 있습니다.









Dialog App InitInstance로 이동합니다.
Dialog가 생성되기 전에 아래 코드를 추가합니다.

WNDCLASS wc; ::GetClassInfo(AfxGetInstanceHandle(), _T("#32770"), &wc); wc.lpszClassName = _T("@CLASSNAME"); AfxRegisterClass(&wc);




컴파일 후 Spy++로 확인하면 Class Name이 변경된 것을 확인할 수 있습니다.
Class Name 변경 후 App에 코드를 추가 안 할 경우 Class Name을 확인할 수 없어 Dialog가 안 보이게 됩니다.
이상입니다.
감사합니다.


반응형

'IT 나라 > 프로그램 이야기' 카테고리의 다른 글

Visual Studio code에서 Go 실행하기  (0) 2018.02.02
Go 언어 설치 방법  (0) 2018.02.01
C# TOPMOST MessageBox 사용하기  (0) 2017.07.31
XmlSerializer 사용법  (0) 2017.03.17
COM 래퍼 클래스 만들기  (0) 2017.01.20
반응형

Form 사용 시 속성이 Topmost일 경우 MessageBox가 하위로 숨는 경우가 발생 할 수 있다.




일반적으로 Form에서 사용할 경우.

MessageBox.Show("하이 Topmsot");


변경

MessageBox.Show(this, "하이 Topmsot");


2개 이상 프로세스를 사용할 경우 하위 프로세스에서 MessageBox를 사용하면 하위로 숨는 문제가 발생할 수 있다.


하위 프로세스가 Topmost속성이 아니므로, 새로운 Form을 생성해서 Topmost속성을 추가하면 정상적으로 동작합니다.


MessageBox.Show(new Form { TopMost = true }, "하이 Topmsot");


반응형

'IT 나라 > 프로그램 이야기' 카테고리의 다른 글

Go 언어 설치 방법  (0) 2018.02.01
MFC Dialog Class Name 변경 방법  (0) 2017.08.22
XmlSerializer 사용법  (0) 2017.03.17
COM 래퍼 클래스 만들기  (0) 2017.01.20
C# COM 모듈 C++에서 사용하기  (1) 2017.01.13
반응형

안녕하세요. 오늘은 C# XmlSerializer 사용법에 대해서 알아보겠습니다.

XmlSeralizer Class는 xml 정보를 Deserialize하여 지정된 Class에 정보를 복사하는 Class입니다.



XmlSerializer Class MSDN입니다.


XmlSerializer 생성자 입니다.




메서드입니다.




이벤트입니다.




XmlSerializer을 사용하기 위해서는 먼저 Xml생성해야 합니다.

Serializable되어야 하므로 사용 Class와 동일한 구조로 작성해 줍니다.

 

1
2
3
4
5
6
7
8
9
<?xml version="1.0"?>
  <Item>
    <Item1>Item1 A</Item1>
    <Item2>Item1 B</Item2>
    <Item3>Item1 C</Item3>
    <Page>1</Page>
  </Item>
</Config>
cs

xml에 보이는 Config가 기본 Class 이름입니다.

하위 로드는 Item, Item1, Item2, Item3, Page입니다.

Class구성시 같은 구조로 되어 있어야 정상 동작합니다.


1
2
3
4
5
6
7
8
9
10
11
12
13
14
[Serializable]
public class Config : XmlPersistableObject
{
      public Config() { Item = new ItemObject(); }
      public ItemObject Item;
}
 
public class ItemObject
{
      public string Item1 { get; set; }
      public string Item2 { get; set; }
      public string Item3 { get; set; }
      public int Page { get; set; }
}
cs

XmlPeristableObject Class를 상속 받아서 Xml 직접 제어하는 Class입니다.

Xml과 동일한 구조입니다.


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
public class XmlPersistableObject
{
      public static T Load<T>(string szFileName) where T : XmlPersistableObject, new()
      {
          T result = default(T);
          using (FileStream stream = File.OpenRead(szFileName))
          {
              result = new XmlSerializer(typeof(T)).Deserialize(stream) as T;
          }
          return result;
      }
 
      public void Save<T>(string szFileName) where T : XmlPersistableObject
      {
          using (FileStream stream = new FileStream(szFileName, FileMode.CreateNew))
          {
              new XmlSerializer(typeof(T)).Serialize(stream, this);
          }
      }
}
cs


XmlSerializer 사용 Class입니다.

T를 사용해서 작성한 Class를 Deserialize하거나 Serialize합니다.


1
2
3
4
5
6
7
8
string szXmlPath = Application.StartupPath + "\\configXml.xml";
Config cnf = new Config();
cnf.Item.Item1 = "Item1 A";
cnf.Item.Item2 = "Item1 B";
cnf.Item.Item3 = "Item1 C";
cnf.Item.Page = 1;
cnf.Save<Config>(szXmlPath);
Config loadxml = Config.Load<Config>(szXmlPath);
cs


사용 예제 입니다.


XmlSerializer을 사용하면 손 쉽게 xml을 컨트롤 할 수 있습니다.


이상입니다.






반응형
반응형

안녕하세요. 오늘은 요즘 핫 게임 Pokemon GO GPS연동하기를 알아보겠습니다.

테스트 하드웨어는 홍미 노트3 프로입니다.

먼저 구글 스토어에서 GPS를 사용하기 위한 앱을 설치해야 합니다.

 

 

 

Fly GPS로 검색 합니다.

Fly GPS는 3M정도로 빠르게 설치됩니다.

기본적으로 Pokemon GO는 설치 되어 있어야 합니다.

 

Fly GPS를 실행 하기 전에 안드로이드 개발자 모드를 활성화 합니다.

 

 

 

설정 –> 휴대전화 정보에서 MIUI버전 탭을 5번 정도 클릭하면,

개발자 모드가 활성화 됩니다.

 

 

 

추가설정에서 개발자 옵션을 클릭합니다.

 

 

 

모의 위치 앱 선택에서 Fly GPS를 선택합니다.

Fly GPS를 종료하면 기존 GPS를 사용하니 걱정 안 하셔도 됩니다.

 

 

 

Fly GPS앱을 실행하고 원하는 위치를 검색하면 이동합니다.

GPS를 실행하기 위해서 왼쪽 아래 재생 버튼을 클릭하면 GPS가 변경됩니다.

Fly GPS를 사용하기 위해서는 GPS 신호가 없는 곳에서 하셔야 합니다.

또한 대륙 이동은 하지 마십시오.

 

 

Fly GPS를 실행 후 Pokemon GO화면으로 이동하면 이동 컨트롤러가 활성화 됩니다.

이동은 항상 북쪽 기준으로 이동 됩니다.

이제 컨트롤러를 이용해서 원하시는 위치로 이동하시면 많은 포켓몬을 수집하실 수 있습니다.

이 방법은 한시적일 수 있으니, 적당하게 이용하시면 좋을 꺼 같습니다.

감사합니다.

반응형
반응형

안녕하세요. 오늘은 COM 래퍼 크래스 만드는 방법을 배워보겠습니다.

OCX를 만들게 되면 일반적으로 웹에서 사용하지만,

간혹 OCX를 프로그램에서 사용해야 하는 경우가 있습니다.

이럴때 자동으로 UI에서 래퍼 클래스가 생성되지만

안될 경우 혼란에 빠지게 됩니다. ㅠㅠ




OCX를 직접 사용하기 위해서는 래퍼 클래스를 이용해서 노출된 인터페이스에 접근하게됩니다.

래퍼 클래스는 OCX를 개발할 때 생성된 GUID를 이용해서 접근합니다.



1
2
3
#include "StdAfx.h"
#include "Activex_TESTCtrl.h"
IMPLEMENT_DYNCREATE(Activex_TESTCtrl, CWnd)
cs


Activex_TESTCtrl.cpp 파일 입니다.


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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
#pragma once
 
// 컴퓨터에서 Microsoft Visual C++를 사용하여 생성한 IDispatch 래퍼 클래스입니다.
 
// 참고: 이 파일의 내용을 수정하지 마십시오. Microsoft Visual C++에서
//  이 클래스를 다시 생성할 때 수정한 내용을 덮어씁니다.
 
/////////////////////////////////////////////////////////////////////////////
// CActivex_test01ctrl1 래퍼 클래스입니다.
 
class Activex_TESTCtrl : public CWnd
{
protected:
    DECLARE_DYNCREATE(Activex_TESTCtrl)
public:
    CLSID const& GetClsid()
    {
        static CLSID const clsid                        
            = { 0x2d12f2e40x1c6f0x475a, { 0x180x320x190xef0xef0x9a0x170x58} };
        return clsid;
    }
    virtual BOOL Create(LPCTSTR lpszClassName, LPCTSTR lpszWindowName, DWORD dwStyle,
        const RECT& rect, CWnd* pParentWnd, UINT nID, 
        CCreateContext* pContext = NULL)
    { 
        return CreateControl(GetClsid(), lpszWindowName, dwStyle, rect, pParentWnd, nID); 
    }
 
    BOOL Create(LPCTSTR lpszWindowName, DWORD dwStyle, const RECT& rect, CWnd* pParentWnd, 
        UINT nID, CFile* pPersist = NULL, BOOL bStorage = FALSE,
        BSTR bstrLicKey = NULL)
    { 
        return CreateControl(GetClsid(), lpszWindowName, dwStyle, rect, pParentWnd, nID,
            pPersist, bStorage, bstrLicKey); 
    }
 
    // 특성입니다.
public:
 
 
    // 작업입니다.
public:
 
    // _DActiveX_Test01
 
    // Functions
    //
 
    void Fun()
    {
        InvokeHelper(0x01, DISPATCH_METHOD, VT_EMPTY, NULLNULL);
    }
 
    
    // Properties
    BSTR GetFunIP()
    {
        BSTR site;
        InvokeHelper(0x02, DISPATCH_PROPERTYGET, VT_BSTR, (void*)&site, NULL);
        return site;
    }
 
    void SetFunIP(LPCTSTR newVal)
    {
        static BYTE parms[] = VTS_BSTR;
        InvokeHelper(0x02, DISPATCH_PROPERTYPUT, VT_BSTR, NULL, parms, newVal);
    }
 
    
 
};
 
cs


Activex_TESTCtrl.h 파일 입니다.


CSLID는 OCX에 등록된 GUID를 복사하면 됩니다.


생성된 래퍼 클래스는 DDX_Control 함수를 사용해서 직접 연결하면 사용 가능합니다.


OCX에 설정된 메서드 또는 속성에 접근하기 위해서는 InvokeHelper 함수를 사용해야 합니다.


InvokeHelper함수는 wFlags를 통해 지정된 컨텍스트에서 dwDispID를 통해 지정된 개체 메서드 또는 속성을 호출합니다.



InvokeHelper 함수 구문입니다.


5개 이상 매개 변수를 사용하고 있으며 가장 중요한 메서드는 dwDispID입니다.

dwDispID를 OCX개발 시 설정 된 ID이며 ID가 다를 경우 "형식 오류" 를 리턴 합니다.



vtRet인수의 가능한 VARENUM 열거형입니다.

설정 된 값을 설정 후 접근하면 됩니다.


이렇게 래퍼 클래스를 만들면 쉽게 COM을 접근해서 사용 가능합니다.


자동 생성이 안된다고 당황하지 마시고 안되면 그냥 위 내용을 복사해서 사용하시면 됩니다.


그럼 즐거운 주말 보내십시오.


감사합니다.


반응형

+ Recent posts