【UWP应用开发实战】第二弹 移动版秒变桌面版 实践:罗马数计算器

简介:

背景

想想通用应用平台终于诞生了,正好又碰到两个挺有意思的题目:

传送门:LeetCode 12 Integer to Roman(整型数到罗马数)
传送门:LeetCode 13 Roman to Integer(罗马数到整型数)

于是就打算将它们整合成个一个简单的App吧,虽然功能不多,但万一有用户需要呢?常规的计算器功能我没实现,系统自带的已经非常好了。

个人是很喜欢Pivot控件的,可以左右滑动,挺好使的。这里就用它了,和UWP搭配,堪称完美。

界面

具体布局代码我就不细说了,感觉实在没什么好说了,相信看过前面写的Windows App系列文章的童鞋们都可以实现出来了,我就直接上截图了。

先来看看移动版的(补充一个段子吧,微软宣布Windows 10 Mobile中文名叫做Windows 10 移动版,那以后手机岂不是有Windows 10 移动版移动版和Windows 10 移动版联通版了),这里我还留了挺多空格没有使用,后续如果发现有什么功能需要跟进再进行补充了。

这里写图片描述

这里写图片描述

通用应用超赞的亮点

如果你还没有开发过通用应用,那我来教你如何秒变桌面版吧。在下面所示的窗口中,你就可以自由切换了,即便是IoT(Internet of Things)也是可以的喔,还有强大的Surface Hub。

这里写图片描述

切换之后呢?duang……

这里写图片描述



预警……下面是关键部分!



这里写图片描述

但是,用过Windows 10 的童鞋们都知道所有App都是可以随意放大以及缩小的,那么我们也试试呢?

这里写图片描述

这里写图片描述

哈?这是咋回事……

放大设计器后,你就会发现这么小锁喔……

这里写图片描述

何不试试将小锁都锁上呢?我用GIF录制了一段,大家看看,有没有感觉很神奇呢?

相比Android上的各种适配问题,这个简直不要太赞呀!

这里写图片描述

开始筹备

那么就来实现具体功能好啦,其实吧,我感觉这部分都没必要写了,你所需要的就是这4个字符串,用于保存用户输入的字符串和输出,之所以各设置2个是因为这里既需要从阿拉伯数转罗马数,也需要从罗马数转阿拉伯数。

private string _readyToCalc = "";
private string _output = "";

private string _readyToCalc2 = "";
private string _output2 = "";

那么对于要输出的各种数据呢,我就用的ListView,简单易用,还很省事。

<ListView Name="LvOutput" Grid.Row="0" DoubleTapped="LvOutput_DoubleTapped"  />

键入数字(阿拉伯数和罗马数)

点击数字0的Click事件,其他的都是一样的了,共用AddNumber方法而已:

 private void BtnName0_Click(object sender, RoutedEventArgs e)
{
      AddNumber(0);
      TbInput.Text = _readyToCalc;
}

private void AddNumber(int num)
{
      _readyToCalc += num.ToString();
}

点击确定后的事件,也就是开始计算了。计算出_output后将它添加到LvOutput上。

        private void BtnCalc_Click(object sender, RoutedEventArgs e)
        {
            try
            {
                int number = int.Parse(_readyToCalc);

                _output = IntToRoman(number);
                LvOutput.Items?.Add(_output);
            }
            catch (Exception)
            {
                // ignored
            }
            _readyToCalc = "";
            TbInput.Text = "";
        }

相应的清理按钮的事件:

        private void BtnClear_Click(object sender, RoutedEventArgs e)
        {
            _readyToCalc = "";
            TbInput.Text = "";
        }

        private void BtnClearRecord_Click(object sender, RoutedEventArgs e)
        {
            LvOutput.Items?.Clear();
        }

罗马数字的也一样了:

        private void BtnNameI_Click(object sender, RoutedEventArgs e)
        {
            AddRoman("I");
            TbInput2.Text = _readyToCalc2;
        }

        private void AddRoman(string roman)
        {
            _readyToCalc2 += roman;
        }

        private void BtnCalc2_Click(object sender, RoutedEventArgs e)
        {
            try
            {
                _output2 = RomanToInt(_readyToCalc2).ToString();
                LvOutput2.Items?.Add(_output2);
            }
            catch (Exception)
            {
                // ignored
            }
            _readyToCalc2 = "";
            TbInput2.Text = "";
        }

        private void BtnClear2_Click(object sender, RoutedEventArgs e)
        {
            _readyToCalc2 = "";
            TbInput2.Text = "";
        }

        private void BtnClearRecord2_Click(object sender, RoutedEventArgs e)
        {
            LvOutput2.Items?.Clear();
        }

双击复制

对于用户输入的阿拉伯数,应用给转换成了罗马数,但还得用户自己记下来再到其他地方键入,是不是不太合理?所以,这里应该有一个双击复制的功能。

private void LvOutput_DoubleTapped(object sender, DoubleTappedRoutedEventArgs e)
{
    DataPackage dp = new DataPackage();
    if (LvOutput.SelectedItem != null)
    {
        dp.SetText(LvOutput.SelectedItem.ToString());
        Clipboard.SetContent(dp);
    }
}

关于复制图片,这里还有一部分,传送门:Windows App开发之集成设置、帮助、搜索和共享 ,请自行找到第三部分“使用粘贴板”。

如何进行计算呢

    public enum Roman
    {
        M = 1000,
        CM = 900,
        D = 500,
        CD = 400,
        C = 100,
        XC = 90,
        L = 50,
        XL = 40,
        X = 10,
        IX = 9,
        V = 5,
        IV = 4,
        I = 1
    };
public int RomanToInt(string s)
{
    int result = 0;
    Type R = typeof(Roman);
    string first, second;
    if (s.Length > 1)
    {
        first = s.Substring(0, 1); second = s.Substring(0, 2);
    }
    else
    {
        first = s.Substring(0, 1); second = "";
    }
    foreach (var r in Enum.GetNames(R).Reverse())
    {
        while ((r.Length == 1 && first == r) || (r.Length == 2 && second == r))
        {
            result += int.Parse(Enum.Format(R, Enum.Parse(R, r), "d"));
            int lenR = r.Length, lenS = s.Length;
            if (lenS - lenR < 1)
                s = "";
            else
                s = s.Substring(lenR, lenS - lenR);

            if (s.Length > 1)
            {
                first = s.Substring(0, 1); second = s.Substring(0, 2);
            }
            else if (s.Length == 1)
            {
                first = s.Substring(0, 1); second = "";
            }
            else
            {
                first = ""; second = "";
            }
        }
    }
    return result;
}

public string IntToRoman(int num)
{
    string result = "";
    Type R = typeof(Roman);

    foreach (var r in Enum.GetNames(R).Reverse())
    {
        while (num >= int.Parse(Enum.Format(R, Enum.Parse(R, r), "d")))
        {
            result += r.ToString();
            num -= int.Parse(Enum.Format(R, Enum.Parse(R, r), "d"));
        }
    }
    return result;
}

结语

自我感觉写这篇博客的时间比写这个App的时间还要短,不过为了发布到应用商店所花的时间还是略长的……

大家可以下载看看,传送门:罗马数计算器

大家有什么建议或意见欢迎告诉我(邮箱在博客左侧边栏),一起改进这个应用,当然了,如果你自己写一遍然后发到应用商店我也不介意。

Okbye……

号外

求投票或转发支持呀……希望我不要死得太惨了……

请点击这里:投票

投票从10号开始一直持续到20号,拜托各位了!

1449457627_5655.jpg
——————当然你也可以直接点击图片啦

目录
相关文章
|
6月前
|
数据库连接 Android开发
安卓android期末项目之纸牌游戏之三
安卓android期末项目之纸牌游戏之三
64 0
|
4月前
|
定位技术 API 开发者
【Godot引擎开发】简单基础,外加一个小游戏DEMO
【Godot引擎开发】简单基础,外加一个小游戏DEMO
|
7月前
|
编解码 芯片
实战贴:开源GUI STemWin在小熊派上的移植(显示很漂亮、很细腻,棒!)
实战贴:开源GUI STemWin在小熊派上的移植(显示很漂亮、很细腻,棒!)
286 2
|
8月前
|
区块链 Python
桌面太单调?用Python做个“冰墩墩雪容融”桌面部件(好玩又有趣)
桌面太单调?用Python做个“冰墩墩雪容融”桌面部件(好玩又有趣)
138 0
|
8月前
|
小程序
云开发(微信-小程序)笔记(十六)---- 评论
云开发(微信-小程序)笔记(十六)---- 评论
89 0
|
图形学 数据安全/隐私保护
还在用Unity开发游戏?那你就out了,试试用Unity做一个答题系统吧
大家都支持Unity是用来做游戏开发,比如说做2D游戏、3D游戏,或者工业虚拟仿真软件的开发。 其他Unity可以做的有很多,比如答题系统。 本篇就介绍答题系统的开发 这个答题系统,可以从文本文档中提取题目和分数,然后绑定到UI上,在答题的过程中,自动判断分数,自动判断正确率。 目的是实现一个可快速导入到项目中使用的小模块。
|
Android开发
21天打卡Andoid学到的一些小知识-第十一十二天
今天我们学习打卡的内容是:Android 10.0 Launcher3 禁止首屏时钟AppWidget拖动到其他屏这个知识。
72 0
|
安全 Android开发
21天打卡Andoid学到的一些小知识-第十九二十二十一天
今天我们学习打卡的内容是:android 10.0 去掉未知来源弹窗 默认授予安装未知来源权限
68 0
|
Android开发
21天打卡Andoid学到的一些小知识-第十五十六天
学习的最大理由是想摆脱平庸 今天我们学习打卡的内容是:Android 10.0 app获取不到序列号解决方案
79 0
|
存储 图形学
Unity实战之王者荣耀段位计算
Unity实现王者荣耀段位计算
Unity实战之王者荣耀段位计算