HarmonyOS Sans - 华为把鸿蒙系统自带的字体开放给全社会免费商用了

HarmonyOS Sans - 华为把鸿蒙系统自带的字体开放给全社会免费商用了

最近华为发布了鸿蒙系统并且开源了代码,成为了科技圈的热闻。不过我注意到了,系统内置的字体也是开放免费商用的,来看一下这款字体有什么不一样吧。

关于 HarmonyOS Sans

华为鸿蒙字体 (HarmonyOS Sans) 是华为和汉仪字库合作定制,专门为鸿蒙操作系统设计打造,设计上聚焦于功能性、普适性,字形和之前介绍过的谷歌思源黑体阿里巴巴普惠体以及 OPPO 手机公司的 OPPO SANS 等免费商用字体有点类似,是一款适合阅读的多字重中性字体。

HarmonyOS 字体特性

  • 5种字重粗细调节。HarmonyOS Sans 支持可变特性,让用户选择他们喜欢的字体粗细来进行文本的显示。
  • 支持等宽与变宽两种样式。变宽数字在阅读文本段落中能让阅读体验更加连贯。而等宽数字在强调数值以及数据需要经常变化的表格、时钟数字的 UI 界面使用时,效果会更好。
  • 支持多国语言。HarmonyOS Sans 支持简体中文、繁体中文、拉丁、西里尔、希腊、阿拉伯等5大书写系统,105种语言全球化覆盖。
  • 通用性极佳,中英文混排效果优秀。鸿蒙系统是一款面向全场景的分布式操作系统,无论在手持设备、电视大屏幕还是手表的小屏上, HarmonyOS Sans 鸿蒙字体都具备极强的通用性和协调性。无论是粗体还是细体均需拥有出色的一致性。

harmonyos-sans 5种字重

字形特点

在保障字体体验的功能性前提下,HarmonyOS Sans 在人文和现代中找到新的平衡。在短笔画时保持横平竖直,简约无装饰,撇捺弯钩长笔画中融入书法的笔势美学,带来全新的视觉感受。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lYXLkecu-1627658630819)(https://img.thosefree.com/wp-content/uploads/2021/06/harmony-sans-6.gif)]

harmonyos-sans 笔画特点

在排版设计中常见的“字体不协调”问题之一就是中英文混合的排版,鸿蒙字体对此做出了针对性的优化,把西文字体设计得更显大更显宽,与中文对齐的匹配度更高,细看起来更加和谐。

harmony-sans 英文字形

和其他类似字体比较

字体应用效果

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tiWhyBpd-1627658630823)(https://img.thosefree.com/wp-content/uploads/2021/06/harmonyos-sans-4.jpg)]

harmonyos-sans 应用例子

使用场景和用途

HarmonyOS Sans 易读性强,字型简约富有科技感,在各种不同尺寸的屏幕上都能获得清晰的显示效果,既适合用于设计制作、平面印刷,也可用于阅读,显示大量文字也依然干净清爽。拥有5种字重,用在正文阅读通透流畅,粗细结合的标题也更醒目。

而对于移动 UI 界面设计来说,HarmonyOS Sans 本身优化了显示效果和协调性,特别是对数字的优化(比如时钟显示的冒号,往往需要手动调整),使得对 UI 作品整体气质有所提升,因此也可以用在效果图或作品集中。

当然了,你也可以设置为日常的办公文档字体,也可以下载用来替换自己手机设备的默认字体,即使没有华为设备,也能体验一下鸿蒙系统的文字显示效果。鸿蒙字体的格式为 .ttf,可以在 Android、WindowsmacOSLinux 等系统上使用。

免费商用说明

华为鸿蒙字体 (HarmonyOS Sans) 是随鸿蒙系统发布的中西文字体,有华为联合汉仪字库专为鸿蒙系统设计,现在华为将其公开发布,任何个人和公司都可以免费下载使用,包括商用。

需要注意的是,windows 系统内置的微软雅黑字体以及 macOS 内置的平方字体都是不能商用的,用在设计或者印刷上会面临侵权风险。喜欢这一类中性字体的,除了思源黑体阿里巴巴普惠体,现在又多了一款鸿蒙系统字体可以选择了。

原文链接:https://www.thosefree.com/harmonyos-sans

帮我用HTML和python写一个web程序 HTML实现如下功能:标题是“一键通系统”,副标题是“零一技术 × 华为云服务”,居中对齐,加粗。有三个输入框和一个输出框,三个输入框的名称分别是“密保号码”“手机号一”“手机号二”,输出框的名称是“中转号码”,输出框只用来输出,不能填写任何内容。输入框和输出框的大小一样。还有一个“提交按钮”,用于提交数据。三个输入框是必填的,不填写完整不允许提交,并提醒。运用你的能力将这个页面设计的好看。 Python实现如下功能: 第一步,读取HTML页面“密保号码”输入的内容,和data.csv中的的数据做比对,如果“密保号码”的内容在第一列,则对变量time赋值数字5,如果“密保号码”的内容在第二列,则对变量time赋值数字10,如果“密保号码”的内容在第三列,则对变量time赋值数字30,如果“密保号码”的内容在第四列,则对变量time赋值数字60,如果在这四列中都不存在,则在输出框中输出“密保号码错误”,并终止程序执行。 第二步,读取手机号码一和手机号码二,分别赋值给phone1和phone2。 第三步,将time,phone1和phone2这三个参数发送到华为云服务端获取请求。 第四步:将第一步读取到的“密保号码”放在log.csv中,并记录存入的时间。 并一步一步教我怎么实现HTML和python的连接并运行这个web程序,文件夹怎么设置,各个文件怎么放。
06-10
好的,让我们一步一步来实现这个功能。 首先,我们需要创建一个文件夹来存放我们的代码和数据文件。我们可以在文件夹中创建以下文件: - index.html:包含我们的 HTML 页面代码。 - main.py:包含我们的 Python 代码。 - data.csv:包含密保号码和对应的时间值。 - log.csv:记录密保号码存储的日志。 下面是 HTML 代码,你可以将其复制到 index.html 文件中。 ```html <!DOCTYPE html> <html> <head> <title>一键通系统 - 零一技术 × 华为云服务</title> <style> body { font-family: Arial, sans-serif; background-color: #f2f2f2; margin: 0; padding: 0; } h1 { text-align: center; font-size: 36px; font-weight: bold; margin-top: 50px; } h2 { text-align: center; color: #666; font-size: 24px; font-weight: normal; margin-top: 20px; margin-bottom: 50px; } form { width: 500px; margin: 0 auto; background-color: #fff; padding: 20px; border-radius: 5px; box-shadow: 0 0 10px rgba(0,0,0,0.2); } label { display: block; margin-bottom: 10px; font-size: 18px; font-weight: bold; color: #333; } input[type="text"] { width: 100%; padding: 10px; font-size: 16px; border: 1px solid #ccc; border-radius: 5px; margin-bottom: 20px; box-sizing: border-box; } input[type="submit"] { display: block; margin: 0 auto; background-color: #4CAF50; color: #fff; font-size: 18px; font-weight: bold; border: none; padding: 10px 20px; border-radius: 5px; cursor: pointer; } .error { color: red; font-size: 16px; font-weight: bold; margin-top: 20px; } .output { width: 100%; padding: 10px; font-size: 16px; border: 1px solid #ccc; border-radius: 5px; box-sizing: border-box; margin-bottom: 20px; } </style> </head> <body> <h1>一键通系统</h1> <h2>零一技术 × 华为云服务</h2> <form method="post"> <label for="security-code">密保号码 *</label> <input type="text" id="security-code" name="security-code" required> <label for="phone-1">手机号一 *</label> <input type="text" id="phone-1" name="phone-1" required> <label for="phone-2">手机号二 *</label> <input type="text" id="phone-2" name="phone-2" required> <input type="submit" value="提交"> </form> <div class="output"></div> <script> document.querySelector('form').addEventListener('submit', function(event) { event.preventDefault(); var securityCode = document.getElementById('security-code').value; var phone1 = document.getElementById('phone-1').value; var phone2 = document.getElementById('phone-2').value; var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function() { if (xhr.readyState === 4 && xhr.status === 200) { document.querySelector('.output').textContent = xhr.responseText; } }; xhr.open('POST', '/submit'); xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); xhr.send('security-code=' + encodeURIComponent(securityCode) + '&phone-1=' + encodeURIComponent(phone1) + '&phone-2=' + encodeURIComponent(phone2)); }); </script> </body> </html> ``` 接下来,我们来编写 Python 代码。你可以将以下代码复制到 main.py 文件中。 ```python from http.server import BaseHTTPRequestHandler, HTTPServer import csv import urllib.parse import json import datetime # 读取 data.csv 文件 with open('data.csv', 'r') as f: reader = csv.reader(f) data = {} for row in reader: data[row[0]] = int(row[1]) # 定义处理 POST 请求的函数 def handle_post_request(params): # 读取密保号码 security_code = params.get('security-code') if not security_code: return '密保号码不能为空' # 根据密保号码查找对应的时间值 time = data.get(security_code) if not time: return '密保号码错误' # 读取手机号码 phone1 = params.get('phone-1') phone2 = params.get('phone-2') if not phone1 or not phone2: return '手机号码不能为空' # 向华为云服务端发送请求 # 在这里填写你的代码,调用华为云服务的 API 并获取响应 # 将密保号码和当前时间写入 log.csv 文件 with open('log.csv', 'a', newline='') as f: writer = csv.writer(f) writer.writerow([security_code, datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')]) # 返回中转号码 return '中转号码:123456789' # 定义处理请求的类 class RequestHandler(BaseHTTPRequestHandler): def do_POST(self): # 解析 POST 请求参数 content_length = int(self.headers['Content-Length']) post_data = self.rfile.read(content_length) params = urllib.parse.parse_qs(post_data.decode('utf-8')) # 处理请求并返回响应 response = handle_post_request(params) self.send_response(200) self.send_header('Content-type', 'text/plain') self.end_headers() self.wfile.write(response.encode('utf-8')) # 启动 HTTP 服务器 def run(server_class=HTTPServer, handler_class=RequestHandler, port=8000): server_address = ('', port) httpd = server_class(server_address, handler_class) print('Starting httpd on port %d...' % port) httpd.serve_forever() if __name__ == '__main__': run() ``` 最后,我们需要在命令行中进入我们的文件夹,并运行 Python 代码。在命令行中输入以下命令: ``` python main.py ``` 这将启动一个 HTTP 服务器,监听端口 8000。然后在浏览器中输入 http://localhost:8000,就可以看到我们的页面了。 当你填写完三个输入框并点击提交按钮时,页面将向我们的 HTTP 服务器发送 POST 请求,并将输入框中的内容作为参数传递给我们的 Python 代码。我们的 Python 代码将读取这些参数,并根据密保号码查找对应的时间值。然后,它将向华为云服务端发送请求,获取中转号码,并将密保号码和当前时间写入 log.csv 文件。最后,它将返回中转号码,并将其显示在输出框中。 希望这个示例能够帮助你理解如何使用 HTML 和 Python 来开发 Web 程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值