.Net Micro Framework研究—让MF支持英文输入法

简介: 目前字符串不仅无法转换为数字,并且没有字符插入功能,所以这个函数也必须自己来实现,此外输入焦点光标也需要自己绘制,好了,先不说难处了,先看看最终成果。

一旦支持了鼠标功能,MF可研究的领域,似乎变得无穷无尽,这也许是我近几天一直陷于此中不能自拔的原因了。
有了鼠标即使没有键盘,我们也可以通过虚拟键盘完成输入工作。这个工作很有意义,也很有挑战性,因为这不是windows平台,也不是Dos平台,这是“一穷二白”的MF平台,所有的工作都得从头做起(实现绘制键盘,向有输入焦点控件发送按键信息,删除,添加字符等等功能)。
目前字符串不仅无法转换为数字,并且没有字符插入功能,所以这个函数也必须自己来实现,此外输入焦点光标也需要自己绘制,好了,先不说难处了,先看看最终成果。
 image.png

这是一个文本输入实例,当文本框有输入焦点时,自动弹出输入面板。
image.png

虚拟键盘上的“Shift”键也是有效的,切换后可以输入符号和大写字母。
image.png
 
当文本框失去输入焦点的时候,虚拟键盘消失。
 
以上应用实现的代码如下:

    //个人信息
    public class YFSelfInfo : YFDialog
    {
        YFLabel[] label=new YFLabel[3];
        YFText[] text=new YFText[3];
        string[] strLabelName = new string[] {"姓名:","单位:","博客:"};
        public YFSelfInfo(string Title, int Left, int Top, int Width, int Height, YFWindowBase Parent): base(Title, Width, Height, Parent)
        {
            //-------------
            for(int i=0;i<3;i++)
            {
                label[i] = new YFLabel(strLabelName[i], 20, ClientRect.Top + 10+30*i,40, 20);
                Children.Add(label[i]);
                text[i] = new YFText("", 70, label[i].Top, 140, 20);
                text[i].Enter += new YFSoft.SPOT.Presentation.YFEventHandler(text_Enter);
                text[i].Leave += new YFSoft.SPOT.Presentation.YFEventHandler(text_Leave);
                Children.Add(text[i]);
            }
        }
        //获得输入焦点时显示输入面板
        void text_Leave(object sender, EventArgs e)
        {
            HideInputPanel();
            this.Height = SystemMetrics.ScreenHeight;
        }
        //失去焦点时隐藏输入面板
        void text_Enter(object sender, EventArgs e)
        {
            ShowInputPanel();
            this.Height = this.InputPanelTop + 1;
        }
        //主窗体鼠标信息
        public override void OnMouseClick(object sender, MouseEventArgs e)
        {
            text_Leave(null, null); //隐藏输入面板
            base.OnMouseClick(sender, e);
        }
}

用户程序是不是很简单?再看看我实现的一个记事本程序
image.png

正在输入界面
image.png
 

菜单功能支持
 
相关代码如下:

    //记事本
    public class YFNote : YFDialog
    {
        YFText text;
        public YFNote(string Title,int Left, int Top, int Width, int Height, YFWindowBase Parent)
            : base(Title, Width, Height, Parent)
        {
            text = new YFText("", ClientRect.Left, ClientRect.Top, ClientRect.Width, ClientRect.Height);
            text.BorderStyle = BorderStyle.None;
            text.Align = false;
            text.Enter += new YFSoft.SPOT.Presentation.YFEventHandler(text_Enter);
            text.Leave += new YFSoft.SPOT.Presentation.YFEventHandler(text_Leave);
            Children.Add(text);
            this.Left = Left;
            this.Top = Top;
            Menu.AddItem(new MenuItem("新建"));
            Menu.AddItem(new MenuItem("保存"));
            Menu.AddItem(new MenuItem("-"));
            Menu.AddItem(new MenuItem("退出"));               
        }
        //获得输入焦点时显示输入面板
        void text_Leave(object sender, EventArgs e)
        {
            HideInputPanel();
            this.Height = SystemMetrics.ScreenHeight;
            text.Height = ClientRect.Height;
        }
        //失去焦点时隐藏输入面板
        void text_Enter(object sender, EventArgs e)
        {
            ShowInputPanel();
            this.Height = this.InputPanelTop+1;
            text.Height = ClientRect.Height;
        }
        //主窗体鼠标信息
        public override void OnMouseClick(object sender, MouseEventArgs e)
        {
            text_Leave(null, null); //隐藏输入面板
            base.OnMouseClick(sender, e);
        }
        //菜单
        public override void OnMenuClick(MenuEventArgs e)
        {
            switch (e.Text)
            {
                case "新建":
                    text.Text = "";
                    break;
                case "保存":
                    MessageBox("不好意思,暂时没有保存功能","记事本", MessageBoxButtons.OK, MessageBoxIcon.Warning);
                    break;
                case "退出":
                    Close();
                    break;
            }
            base.OnMenuClick(e);
        }
 }

程序也超简单,但功能还是蛮强大的,我们下面看看虚拟键盘的相关代码,实现思路和鼠标功能一样,也是直接借助基类的虚拟函数,向指定的窗体和控件发送按键消息。
核心代码如下:

public void TransactKey(KeyState state, object sender, MouseEventArgs e)
    {
        //向控件发送按键消息
        if (this.Parent != null)
        {
            Keys key = Keys.None;
            int keyValue=0;
            char _char = (char)0;
 
            YFButton b = (YFButton)sender;
            if (b.Text == "" || b.Text=="En" || b.Text=="Cn") return;
 
            Button btn = Button.None;
            switch (b.Text)
            {
                case "Tab":
                    key = Keys.Tab;
                    break;
                case "Caps":
                    key = Keys.CapsLock;
                    break;
                case "Shift":
                    key = Keys.Select;
                    break;
                case "Ent":
                    key = Keys.Enter;
                    btn = Button.Select;
                    break;
                case "Esc":
                    key = Keys.Escape;
                    break;
                case "Ins":
                    key = Keys.Insert;
                    break;
                case "Del":
                    key = Keys.Delete;
                    break;
                case "Menu":
                    key = Keys.Menu;
                    btn = Button.Menu;
                    break;
                case "↑":
                    key = Keys.Up;
                    btn = Button.Up;
                    break;
                case "←":
                    key = Keys.Left;
                    btn = Button.Left;
                    break;
                case "↓":
                    key = Keys.Down;
                    btn = Button.Down;
                    break;
                case "→":
                    key = Keys.Right;
                    btn = Button.Right;
                    break;
                case "<-":
                    key = Keys.Back;
                    btn = Button.Back;
                    break;
                default:
                    _char = b.Text[0];
                    key = (Keys)b.Name[0];
                    break;
            }
            keyValue = (int)key;
 
            //向当前有输入焦点的窗口发送系统按键消息
            if (btn!= Button.None)
            {
                if ((state & KeyState.Down) > 0) Parent.GetFocus().OnButtonDownEx(new ButtonEventArgs(null, null, new TimeSpan(), btn));
                if ((state & KeyState.Up) > 0) Parent.GetFocus().OnButtonUpEx(new ButtonEventArgs(null, null, new TimeSpan(), btn));                   
            }
 
            //获得输入焦点的控件
            YFControl c = this.Parent.Children.GetFocus();
            if (c != null)
            {
                if ((state & KeyState.Down) > 0) c.OnKeyDown(sender, new KeyEventArgs(key, keyValue, button[41].Checked, button[28].Checked, button[55].Checked));
                if ((state & KeyState.Press) > 0 && _char != (char)0) c.OnKeyPress(sender, new KeyPressEventArgs(_char));
                if ((state & KeyState.Up) > 0) c.OnKeyUp(sender, new KeyEventArgs(key, keyValue, button[41].Checked, button[28].Checked, button[55].Checked));
            }
 
            //父窗体要求接收按键消息
            if (Parent.KeyPreview)
            {
                if ((state & KeyState.Down) > 0) Parent.OnKeyDown(Parent, new KeyEventArgs(key, keyValue, button[41].Checked, button[28].Checked, button[55].Checked));
                if ((state & KeyState.Press) > 0 && _char != (char)0) Parent.OnKeyPress(Parent, new KeyPressEventArgs(_char));
                if ((state & KeyState.Up) > 0) Parent.OnKeyUp(Parent, new KeyEventArgs(key, keyValue, button[41].Checked, button[28].Checked, button[55].Checked));
            }
        }
}

   以上仅仅实现的是英文输入,中文输入怎么做?似乎要困难的多,此外粘贴、复制功能要不要做?总之有很多很多的东西值得我们去探索去实现,这一切,似乎我们在走Microsoft的老路,要在MF平台上实现一个Micro Windows!说到这我想到一个笑话,有一个人给上帝进行打赌说他也能造人。上帝问他,你怎么做,他说,我先用泥土捏一个…,“等等,”上帝打断了他,“你要用你自己的泥土”。

相关文章
|
1月前
使用的是.NET Framework 4.0,并且需要使用SMTP协议发送电子邮件
使用的是.NET Framework 4.0,并且需要使用SMTP协议发送电子邮件
39 1
|
21天前
|
开发框架 缓存 监控
NET Framework 到 .NET 5/6 的迁移是重大的升级
本文详细介绍了从 .NET Framework 4.8 迁移到 .NET 5/6 的过程,通过具体案例分析了迁移策略与最佳实践,包括技术栈评估、代码迁移、依赖项更新及数据库访问层的调整,强调了分阶段迁移、保持代码可维护性及性能监控的重要性。
44 3
|
29天前
|
机器学习/深度学习 编解码 算法
【小样本图像分割-4】nnU-Net: Self-adapting Framework for U-Net-Based Medical Image Segmentation
《nnU-Net: 自适应框架用于基于U-Net的医学图像分割》是一篇2018年的论文,发表在Nature上。该研究提出了一种自适应的医学图像分割框架nnU-Net,能够自动调整模型的超参数以适应不同的数据集。通过2D和3D U-Net及级联U-Net的组合,nnU-Net在10个医学分割数据集上取得了卓越的性能,无需手动调整。该方法强调数据增强、预处理和训练策略等技巧,为医学图像分割提供了一个强大的解决方案。
59 0
【小样本图像分割-4】nnU-Net: Self-adapting Framework for U-Net-Based Medical Image Segmentation
winform .net6 和 framework 的图表控件,为啥项目中不存在chart控件,该如何解决?
本文讨论了在基于.NET 6和.NET Framework的WinForms项目中添加图表控件的不同方法。由于.NET 6的WinForms项目默认不包含Chart控件,可以通过NuGet包管理器安装如ScottPlot等图表插件。而对于基于.NET Framework的WinForms项目,Chart控件是默认存在的,也可以通过NuGet安装额外的图表插件,例如LiveCharts。文中提供了通过NuGet添加图表控件的步骤和截图说明。
winform .net6 和 framework 的图表控件,为啥项目中不存在chart控件,该如何解决?
|
3月前
|
开发框架 缓存 前端开发
实战.NET Framework 迁移到 .NET 5/6
从.NET Framework 迁移到.NET 5/6 是一次重要的技术革新,涵盖开发环境与应用架构的全面升级。本文通过具体案例详细解析迁移流程,包括评估现有应用、利用.NET Portability Analyzer 工具识别可移植代码、创建新项目、逐步迁移代码及处理依赖项更新等关键步骤。特别关注命名空间调整、JSON 序列化工具更换及数据库访问层重构等内容,旨在帮助开发者掌握最佳实践,确保迁移过程平稳高效,同时提升应用性能与可维护性。
112 2
|
3月前
|
开发框架 JSON 监控
实战指南:从 .NET Framework 迁移到 .NET 5/6 的策略与最佳实践
【8月更文挑战第28天】从 .NET Framework 迁移到 .NET 5/6 是一次重要的技术升级,涉及开发环境与应用架构的改进。本文通过具体案例分析,介绍迁移策略与最佳实践,帮助开发者顺利完成转变。
74 1
|
3月前
|
缓存 程序员
封装一个给 .NET Framework 用的内存缓存帮助类
封装一个给 .NET Framework 用的内存缓存帮助类
|
3月前
|
XML JSON 程序员
总结一下 .NET FrameWork 和 .NET Core 创建的项目的不同点
总结一下 .NET FrameWork 和 .NET Core 创建的项目的不同点
|
3月前
分享一份 .NET Core 简单的自带日志系统配置,平时做一些测试或个人代码研究,用它就可以了
分享一份 .NET Core 简单的自带日志系统配置,平时做一些测试或个人代码研究,用它就可以了