Real Time 2D Graph

Environment: eMbedded Visual C++ 3.0, Windows 2000, Windows CE Emulator

To Run this application you must have installed eMbedded Visual C++ 3.0

This Article is mainly contributed to develop the 2D Real Time Graph. I was searching the net to develop the graph as shown above. I found that the picture control had been used to draw the graph in Microsoft Visual Studio. To Develop this application, I needed to use the Microsoft eMbedded Visual C++ 3.0.

Historically, I've shown "live" Instrument readings through the constant updating of a numerical value by using constant value array. The Graph shows the real time data from the instrument

This MECGraphCtrl is based on the bitmap repainting concept used in Mark C. Malburg. . It provides significant enhancements through the display of scaling information and plotting of double precision values. The user implementation is described below.

In the control's owner (for example dialog) insert a dummy picture control. Size the Custom Control border to be the desired size of the GraphCtrl. Name the control something that sounds technical, like "IDC_GRAPH_CUSTOM". In the property of the custom control, For class, write GRAPH_CUSTOM. This is the string for the class that should be registered in the Constructor of the Dialog class.

1. Insert the control in the owner class.

Add a member variable of type MECGraphCtrl.

class MECPerformerDlg : public CDialog
  // Construction
  static BOOL RegisterWndClass(HINSTANCE hInstance);
  MECGraphCtrl m_oGraphCtrl;  

2. Register the custom control.

BOOL MECPerformerDlg::OnInitDialog()
  wc.lpszClassName = _T("GRAPH_CUSTOM"); // matches class name 
  wc.hInstance = hInstance;
  wc.lpfnWndProc = ::DefWindowProc;
  //wc.hCursor = LoadCursor(NULL, IDC_ARROW);
  wc.hIcon = 0;
  wc.lpszMenuName = NULL;
  wc.hbrBackground = (HBRUSH) ::GetStockObject(LTGRAY_BRUSH); = CS_GLOBALCLASS; // To be modified
  wc.cbClsExtra = 0;
  wc.cbWndExtra = 0;

3. Create the control.

BOOL MECPerformerDlg::OnInitDialog()
  CRect rect;
  GetDlgItem(IDC_GRAPH_CUSTOM)->GetWindowRect(rect) ;
  ScreenToClient(rect) ;

  // create the control
  m_oGraphCtrl.Create(WS_VISIBLE | WS_CHILD, rect, this) ; 

4. Personalize the Control

Set the vertical range, background color, grid color and plot color.

BOOL MECPerformerDlg::OnInitDialog()
  // determine the rectangle for the control
  CRect rect;
  GetDlgItem(IDC_GRAPH_CUSTOM)->GetWindowRect(rect) ;
  ScreenToClient(rect) ;

  // create the control
  m_oGraphCtrl.Create(WS_VISIBLE | WS_CHILD, rect, this) ; 
  m_oGraphCtrl.SetRange(0, 10, 2) ;

  m_oGraphCtrl.SetYUnits("Volume in ml") ;
  m_oGraphCtrl.SetXUnits("Time in seconds") ;
  m_oGraphCtrl.SetBackgroundColor(RGB(0, 0, 64)) ;
  m_oGraphCtrl.SetGridColor(RGB(192, 192, 255)) ;
  m_oGraphCtrl.SetPlotColor(RGB(0, 255, 0)) ;

5. Use the control.

Call the m_oGraphCtrl.AppendPoint(nRandomX, nRandomY); function with the the data value to be appended to the plot.

values can be modified to achieve different styles of displays.


Download demo project - 59 Kb


  • Need help on Real Time on Windows

    Posted by Legacy on 02/07/2004 12:00am

    Originally posted by: Leslie

    Cool stuffs but how do i implement it and make it runnable on windows? Thank you.

  • Real Time 2D Graph

    Posted by Legacy on 01/15/2004 12:00am

    Originally posted by: aaaac


  • How I can remove the error "a required resource was"

    Posted by Legacy on 07/03/2003 12:00am

    Originally posted by: ashkan

    Dear Sir,
    I draw a graph in dialog with help off Scroll Bar.
    It is necessary that my graph repeated in dialog
    in other words I update my graph with time.
    But I see after a time the error "a required resource was".
    I think that I must reset dialog before draw (or clear previous graph) new graph.
    How can I do that?
    Sincerely yours
    Thanks in advance,

  • Can I run it in PocketPC 2002?

    Posted by Legacy on 06/30/2003 12:00am

    Originally posted by: Rico

    Hi All,

    I have added the code in my program on PocketPC 2002 platform. But the application can't start (I don't see any effect).
    My question is:
    Can I use the code provided in the PocketPC 2002 platform?


  • plot graph

    Posted by Legacy on 03/15/2003 12:00am

    Originally posted by: prashanth

    to plot graph which supports real time values.without using any controls

  • Static Graph

    Posted by Legacy on 09/08/2002 12:00am

    Originally posted by: Shravan


    i Want to draw a graph of 10mm/10mm which is static means same size on 14/15/17 inches /...Moniters and also which should no depend on screen resulution.

    please help me

  • About 2D Graph

    Posted by Legacy on 04/06/2002 12:00am

    Originally posted by: naresh kumar bhutani

    the    source   coding  help  me  about  how  to  display  the    2D  Graph

  • vc6.0

    Posted by Legacy on 03/18/2002 12:00am

    Originally posted by: lorry

    i use vc6.0, and i'm sure i add the code correctly into the
    vc6.0 . After i press the BuildExecute Button (of course there is no error !) --------------------Configuration: performer - Win32 Debug--------------------
    Compiling resources...

    performer.exe - 0 error(s), 0 warning(s)

    BUT there is nothing showing !!!
    the dialog doesn't show !!
    it looks like i have used the ShowWindow(SW_HIDE)
    but i swear i didn't !!

  • Visual C++ 6

    Posted by Legacy on 12/15/2001 12:00am

    Originally posted by: Tng

    How run this code in VC++ 6.

  • visual c++ 5

    Posted by Legacy on 11/21/2001 12:00am

    Originally posted by: fg

    How to run this prog in visual c++ 5


  • Loading, Please Wait ...

Leave a Comment
  • Your email address will not be published. All fields are required.

Top White Papers and Webcasts

  • Today's agile organizations pose operations teams with a tremendous challenge: to deploy new releases to production immediately after development and testing is completed. To ensure that applications are deployed successfully, an automatic and transparent process is required. We refer to this process as Zero Touch Deployment™. This white paper reviews two approaches to Zero Touch Deployment--a script-based solution and a release automation platform. The article discusses how each can solve the key …

  • This report outlines the future look of Forrester's solution for security and risk (S&R) executives working on building an identity and access management strategy for the extended enterprise. We designed this report to help you understand and navigate the major business and IT trends affecting identity and access management (IAM) during the next five years. IAM in 2012 has become a tool not just for security but also for business agility. Competitive challenges push businesses into the cloud and encourage …

Most Popular Programming Stories

More for Developers

RSS Feeds

Thanks for your registration, follow us on our social networks to keep up-to-date