试验平台:.Net Micro Framework 模拟器

 

目前在VS2005的环境里,还不支持.Net Micro Framework界面的所见即所得绘制,界面制作有三种方式,一是窗体直接绘图,二是Panel+形状对象、三是窗体+控件。第一种做法让人觉得又回到了DOS时代,回到了SCREEN 12的16色的世界里。

 

窗体当前仅能层现一个控件,用Window.Child属性去赋值。

支持的控件主要有Panel、Listbox、Image、Text等,其中Panel可包含多个子控件。

支持的形状对象主要有Ellipse,Line,Polygon,Rectangle等。

支持的绘图函数主要有:

DrawEllipse,DrawImage,DrawLine,DrawPolygon,DrawRectangle,DrawText,SetPixel;

 

本篇内容主要介绍窗体直接绘图,其他相关内容在后面的篇章里陆续介绍。

1、新建项目,请选择window Application,如下图所示

 

 .Net Micro Framework研究—绘图_Net


 

模板自带的代码,是一个window窗体上包含一个Text控件,控件显示的内容就是:Hello World!

2、窗体直接绘图

当前工程,除资源和引用外,其他的代码都可以删除,取而代之的是下面的代码,我尝试用最简单的代码,来表现MF的绘图能力。

 

  1. using System;  
  2.  
  3. using Microsoft.SPOT;  
  4.  
  5. using Microsoft.SPOT.Input;  
  6.  
  7. using Microsoft.SPOT.Presentation;  
  8.  
  9. using Microsoft.SPOT.Presentation.Controls;  
  10.  
  11. using Microsoft.SPOT.Presentation.Media;  
  12.  
  13.    
  14.  
  15. namespace MFWindow  
  16.  
  17. {  
  18.  
  19.     public class Program : Microsoft.SPOT.Application  
  20.  
  21.     {  
  22.  
  23.         public static void Main()  
  24.  
  25.         {     
  26.  
  27.             //创建窗体  
  28.  
  29.             WindowsDrawing win = new WindowsDrawing();  
  30.  
  31.             win.Width = SystemMetrics.ScreenWidth;  
  32.  
  33.             win.Height = SystemMetrics.ScreenHeight;  
  34.  
  35.    
  36.  
  37.             //程序运行  
  38.  
  39.             new Program().Run(win);  
  40.  
  41.         }  
  42.  
  43.         //从Window派生一个类,重载OnRender方法  
  44.  
  45.         internal sealed class WindowsDrawing  :Window  
  46.  
  47.         {  
  48.  
  49.             public override void OnRender(DrawingContext dc)  
  50.  
  51.             {  
  52.  
  53.                 Color c = ColorUtility.ColorFromRGB(128, 0,255);  
  54.  
  55.                 Brush b = new SolidColorBrush(c);  
  56.  
  57.                 Pen p = new Pen(c);  
  58.  
  59.    
  60.  
  61.                 //绘制背景(绘矩形)  
  62.  
  63.                 dc.DrawRectangle(b, p, 0, 0, Width, Height);   
  64.  
  65.                    
  66.  
  67.                 //绘椭圆(刷子无效)  
  68.  
  69.                 b = new SolidColorBrush(Color.White);  
  70.  
  71.                 p=new Pen(Color.Black);  
  72.  
  73.                 dc.DrawEllipse(b, p, 40,20, 40,20);  
  74.  
  75.    
  76.  
  77.                 //绘线(线的粗细参数无效)  
  78.  
  79.                 p = new Pen( ColorUtility.ColorFromRGB(255, 0,0),5);  
  80.  
  81.                 dc.DrawLine(p, 40, 20, 100,80);  
  82.  
  83.    
  84.  
  85.                 //绘矩形(刷子有效,线宽有效)  
  86.  
  87.                 b = new SolidColorBrush(Color.White);  
  88.  
  89.                 p = new Pen(Color.Black,4);  
  90.  
  91.                 dc.DrawRectangle(b, p, 80, 60, 100, 80);  
  92.  
  93.    
  94.  
  95.                 //绘多边行(刷子无效)  
  96.  
  97.                 int[] points = { 10, 230, 30, 210, 0, 180, 30, 130, 50, 130, 80, 180, 50, 210, 70, 230 };  
  98.  
  99.                 b = new SolidColorBrush(Color.White);  
  100.  
  101.                 p = new Pen(ColorUtility.ColorFromRGB(0, 255,0),3);  
  102.  
  103.                 dc.DrawPolygon(b,p, points);  
  104.  
  105.    
  106.  
  107.                 //写文字  
  108.  
  109.                 c= ColorUtility.ColorFromRGB(0, 255, 255);  
  110.  
  111.                 dc.DrawText("http://yfsoft.blog.51cto.com", Resources.GetFont(Resources.FontResources.small), c, 180, 20);  
  112.  
  113.    
  114.  
  115.                 //绘制位图(支持bmp,gif,jpg,png等等图片)  
  116.  
  117.                 dc.DrawImage(Resources.GetBitmap(Resources.BitmapResources.YFMSMVP),230,130);  
  118.  
  119.             }  
  120.  
  121.         }  
  122.  
  123.     }  
  124.  
  125. }  
  126.  

程序运行后的画面如下:

 .Net Micro Framework研究—绘图_Net_02


 

如上面代码中的注释所示,DrawEllipse、DrawLine、DrawPolygon函数对刷子填充和pen的宽度都不支持,目前仅最简单的DrawRectangle函数实现的最好,这说明微软的SDK还是很不完善的,就像串口操作仅支持波特率修改,而不支持奇偶校验、数据位修改一样。估计微软推出SDK3.0或SDK4.0的时候,我想.Net Micro Framework才是成熟的时候。