当前位置: 首页 > news >正文

网页的响应式布局seo教程视频论坛

网页的响应式布局,seo教程视频论坛,wordpress当前版本,一个人做网站赚钱注#xff1a;此文适合于对rust有一些了解的朋友 iced是一个跨平台的GUI库#xff0c;用于为rust语言程序构建UI界面。 iced的基本逻辑是#xff1a; UI交互产生消息message#xff0c;message传递给后台的update#xff0c;在这个函数中编写逻辑#xff0c;然后通过…注此文适合于对rust有一些了解的朋友 iced是一个跨平台的GUI库用于为rust语言程序构建UI界面。   iced的基本逻辑是 UI交互产生消息messagemessage传递给后台的update在这个函数中编写逻辑然后通过View函数更新UI。 Take the result of our view logic and layout its widgets. 获取视图逻辑的结果并布局其小部件。Process events from our system and produce messages for our update logic. 处理来自系统的事件并为我们的更新逻辑生成消息。Draw the resulting user interface. 绘制生成的用户界面。 下面我们将通过举例来说明iced如何显示一个窗口以及如何在窗口上显示中文。 一、如何用iced构建窗口 我们构建一个基本窗口窗口有一个按钮一个文本框一个标签在文本框输入字符点击按钮后标签上显示相同内容。 UI实例预览 1 导入库 use iced::widget::{button, column, text, text_input}; use iced::{Alignment, Element, Sandbox, Settings};2、配置Cargo.toml [dependencies] iced0.10这样使用cargo check时会自动安装iced库。 3、构建窗口程序 主函数 pub fn main() - iced::Result { Counter::run(Settings::default()) //此处为使用默认窗口设置}定义数据结构 //创建结构体struct struct Counter{value: String,value2:String, }定义消息 #[derive(Debug, Clone)] //为下方的enum添加特性trait enum Message {Showtext,InputChanged(String), }实现一个实例 //sandbox是一个trait impl Sandbox for Counter { //impl将sandbox添加给Counter,使Counter具有了sandbox的一些特性type Message Message; fn new() - Self { //初始化sandbox返回初始值Self { value: String::new(),value2:String::new(),}}fn title(self) - String { //返回sandbox的标题String::from(iced_UI)}fn update(mut self, message: Message) { //此处书写更新逻辑程序所有UI交互会在这里处理match message {Message::Showtext { let ssself.value; self.value2ss.to_string(); }Message::InputChanged(value) {self.valuevalue;}}}fn view(self) - ElementMessage { column![text_input(enter some string,self.value).on_input(Message::InputChanged).padding(10).size(16),button(push).on_press(Message::Showtext).padding(2).width(40), text(format!(enter text:{},self.value2)).size(16), ].spacing(10).padding(6).align_items(Alignment::Center).into()}}完整代码 use iced::widget::{button, column, text, text_input}; use iced::{Alignment, Element, Sandbox, Settings};pub fn main() - iced::Result {Counter::run(Settings::default()) //此处为使用默认窗口设置}//创建结构体struct struct Counter{value: String,value2:String, }#[derive(Debug, Clone)] //为下方的enum添加特性trait enum Message {Showtext,InputChanged(String), }//sandbox是一个trait impl Sandbox for Counter { //impl将sandbox添加给Counter,使Counter具有了sandbox的一些特性type Message Message;fn new() - Self { //初始化sandbox返回初始值Self { value: String::new(),value2:String::new(),}}fn title(self) - String { //返回sandbox的标题String::from(iced_UI)}fn update(mut self, message: Message) { //此处书写更新逻辑程序所有UI交互会在这里处理match message {Message::Showtext { let ssself.value; self.value2ss.to_string(); }Message::InputChanged(value) {self.valuevalue;}}}fn view(self) - ElementMessage { column![text_input(enter some string,self.value).on_input(Message::InputChanged).padding(10).size(16),button(push).on_press(Message::Showtext).padding(2).width(40), text(format!(enter text:{},self.value2)).size(16), ].spacing(10).padding(6).align_items(Alignment::Center).into()}}cargo run以上代码演示如下 由于涉及rust和iced两个方面的应用在此仅就iced的相关使用作一下说明至于对rust的代码有疑问的可以参考rust的官方手册。 impl Sandbox for Counter{}这里的sandbox是iced库提供的一个简单的应用特性它是一个trait有update、view、run等函数功能此处update和view是两个有点对应的功能当你在UI操作部件时会产生交互消息messageupdate就是接受message的你可以在update函数下编写你的逻辑 此例中我的逻辑是当在文本框输入信息时实时文本会传给之前定义好的一个数据即value。当点击按钮时会将文本框的数据传给另一个数据value2然后value2是和用于显示的文本框绑定的。 fn update(mut self, message: Message) { //此处书写更新逻辑程序所有UI交互会在这里处理match message { Message::Showtext { let ssself.value; self.value2ss.to_string(); }Message::InputChanged(value) {self.valuevalue;}}}value2通过view函数显示到UI界面。 下面的代码是其中一句这里将text部件绑定了一个值self.value2即前面定义的value2。 text(format!(enter text:{},self.value2)).size(16), 二、如何在iced窗口显示中文 但是上面的程序有个小小的不足就是窗口无法显示中文字符比如我将按钮的名称由push改成开始 button(开始)再运行的话 可以看到上图中按钮的名字变成了乱码这是因为在窗口的设定时使用了默认参数 pub fn main() - iced::Result {Counter::run(Settings::default()) //此处为使用默认窗口设置 }就是此处的Settings而iced的默认窗口参数中字体使用的是SansSerif。因此不支持中文字符所以如果想要在UI界面用中文来表示各个部件的名称或注释需要更改字体。 所以此处我们对上面的程序进行修改以便窗口可以显示中文其实就是修改字体的设置。 首先需要添加导入 use iced::Font; use iced::font::Family;然后修改主函数中的run函数的Settings pub fn main() - iced::Result { //Counter::run(Settings::default()) //此处为使用默认窗口设置 let ffMicrosoft YaHei; //设置自定义字体Counter::run(Settings {default_font:Font{ //设置自定义字体用于显示中文字符family:Family::Name(ff),..Font::DEFAULT},..Settings::default()}) }和之前的主函数对一下可以发现这里我先定义了一个字符串用来表示字体的名字此处是微软雅黑字体。 然后在Settings中将关于字体的default_font单独设置。 设置好后我们再来cargo run一下 可以看到中文字符能正常显示了。 对上面的主函数我们再做一下修改使窗口启动时的尺寸按照我们想要的来即自定义窗口尺寸 先添加导入 use iced::window;然后主函数 pub fn main() - iced::Result { //Counter::run(Settings::default()) //此处为使用默认窗口设置 let ffMicrosoft YaHei; //设置自定义字体Counter::run(Settings {window:window::Settings{ //设置自定义窗口尺寸size:(600,400),..window::Settings::default()},default_font:Font{ //设置自定义字体用于显示中文字符family:Family::Name(ff),..Font::DEFAULT},..Settings::default()}) }这样一来窗口启动时不会按照默认的来而是按照自己设定来显示。
http://www.yutouwan.com/news/432986/

相关文章:

  • 南京建设工程交易中心网站网站开发介绍ppt
  • 怎么推广一个网站企业建设网站好吗
  • 惠阳网站优化郑州快速网站优化公司首选
  • 做网站销售门窗怎么做jsp电子商务网站建设实验
  • 宁波海曙建设局网站住房和城乡建设厅网站办事大厅
  • dede网站转移河北seo基础知识
  • 找网络公司做网站需要注意的网站详细报价
  • 易语言 做的网站中国菲律宾两国双园
  • 阿土伯网站做产品推广咋样平安河南建设网站
  • 利用小米路由器mini做网站牛商网是干什么的
  • 美容行业培训网站建设花桥网站建设
  • 网站维护页面南通高端网站建设机构
  • wordpress 本地配置文件杭州网站优化效果
  • 重庆网站建设 cqhtwl广州百度竞价托管
  • 揭西网站建设新葡京网址网站建设
  • 自己做的网站怎么链接火车头采集刷赞网站推广软件
  • 四川建设部网站做西装的网站
  • 公司的网站怎么做推广树莓派 做网站
  • 青岛网站设计皆挺青岛博采网络安康市信息平台
  • 三只松鼠的网站建设的意义深圳知名seo公司
  • 实体店会员卡管理系统沈阳网站排名优化
  • 网站开发人才需求腾讯广告投放推广平台价格
  • 怎么仿照别人网站平面设计公司属于什么行业
  • 做 个收废品网站互动式网站开发
  • 毛站小说网站如何做书源
  • 响应式网站外包青岛网络优化哪家专业
  • 佛山网站建设技术托管木材模板.网站
  • 配资网站开发长沙网站建设电话
  • 上海青浦房地产网站建设中信建设有限责任公司内江分公司
  • 网站网页设计工作内容云上铺会员管理系统官网