UWP開發入門(六)——對多設備不同解析度顯示效果的討論

来源:http://www.cnblogs.com/manupstairs/archive/2016/01/19/5143414.html
-Advertisement-
Play Games

本篇不涉及具體代碼,而是把實際開發UWP APP的過程中,遇到的不同設備,不同解析度顯示效果差異的問題進行討論。希望能夠拋磚引玉,和各位擦出一些火花。 蜀黍我目前是在做一套牛逼的UWP APP啦,目標是能跑在各種尺寸不同,解析度不同的PC,Phone和Tablet上。無論是從代碼的複雜度還是實...


  本篇不涉及具體代碼,而是把實際開發UWP APP的過程中,遇到的不同設備,不同解析度顯示效果差異的問題進行討論。希望能夠拋磚引玉,和各位擦出一些火花。

  蜀黍我目前是在做一套牛逼的UWP APP啦,目標是能跑在各種尺寸不同,解析度不同的PCPhoneTablet上。無論是從代碼的複雜度還是實現的難度來說,都只希望維護一套代碼。

  在項目的初始階段,美工MMTabletPhone各設計了一套界面,在對UWPAdaptive UI做了一些調研後,認為只要保持界面元素大致相同,以Phone為基準,在Tablet上做一個拉伸就可以了。

  然而在實際開發過程中仍然發現了一些問題。話說美工MMPhone按照640 x 480的解析度設計,Tablet按照Surface Pro 32160 x 1440來設計。

  

  Tablet的話如上圖,SplitView佈局,最左邊是Pane,然後中間再分兩塊內容區域。Phone的界面會藏起Pane,然後兩塊內容區域不再併排顯示。很常見的UI設計,你們都懂的啦。

  首先這兩個屏幕的縱橫比是不一樣的,同時整體佈局也有很大差異。從PhoneTablet佈局的整體切換呢,可以通過UWP新增的AdaptiveTrigger根據屏幕WidthHeight來觸發更新佈局的操作,問題不大。

  但是具體到設置元素大小時就遇到困難了。一開始美工MM貼心的給了兩套Style……這在兩套Style切來切去代碼煩死人不說,這個用戶體驗也不好,視窗拖到一半東西突然Biu~的一聲變大了,怪嚇人的……

  那麼我們就要確定一套Style為基準,同樣的fontSize,同樣的元素尺寸。結果問題出現了,以Tablet 2160 x 1440的設計稿為基準做出來的程式,在1080pPC480p的手機上都顯得碩大無比,所有元素都給打了激素一樣。

  緊急叫停之後,我們告訴美工MM1080p的解析度來做Tablet。然後就發現Tablet看上去正常了,但480pPhone上仍然慘不忍睹碩大無比。同樣的100px的長度,在TabletPhone上竟然不一致。使用Live Tree Explorer測量屏幕的大小發現,Phone的元素尺寸會有一個對應的縮放比例:

解析度

屏幕尺寸

實際長度

比列

640 x   480

4

533.33   x 320

1.5 1

1280 x   720

5

640 x   360

2 1

1920 x   1080

6

768 x   431

2.5 1

 

  也就是480pPhone實際Width只有320px。我們以480pxWidth設計出來的界面,實際比1080pLumia 1520真實Width 431px還要大。

  但是這個縮放比列卻又對文字無效,無效……無效……,fontSize寫了多大,在各種屏幕上都是一個尺寸。當時蜀黍感覺蛋都要碎了。20151231日啊,蜀黍破天荒的加班了啊,因為第二年要給其他兄弟還有美工MM一個交代啊!

  苦思冥想啊,白頭髮都多了好幾根……最終還是決定把問題簡單粗暴化,採用640 x 460來設計Phone,即以720pPhone為基準。之所以捨棄480p是考慮lumia 530之類的老舊設備即將淘汰,Win10m最低端的Lumia 550也是720p了。

  然後保持Phone 720p設計稿上的元素和字體大小不變,平移到1080pTablet畫布上再次進行佈局。基本就等於將兩份640 x 360大小的手機屏幕左右放置到1920 x 1080Tablet上。再做一些間距的調整,實際效果經多方研究表示可以接受。

  如果用戶使用了480p的低端Phone1366 x 768的古董PC,那看上去的元素大小會稍稍放大。好在720p相對480p的跨度較小,理論上字元串和圖片被截斷的可能性不大。

  當用戶使用了1080p以上的PhoneSurface Pro 4這樣的Tablet,元素會顯得更為細小精緻,但針對觸摸優化的UI絕對比視網膜屏MacBook上針對鍵鼠的軟體來的要大。每次看公司同事的MacBook屏幕感覺我眼睛都要瞎了……(順便黑一下,他們經常去修Mac……質量麽……)

  那麼本篇就到這裡,雖然寫得簡單了點,但你真要寫跨設備多分辨的UWP APP,嘿嘿還是從頭再好好看一遍吧……

  另外打個廣告,後面打算延續本篇的討論,針對具體頁面或控制項給出實例分析,到時候要來點贊哦。當然我也可能挖坑不填……謝謝


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1. 用Response.Write方法 代碼如下: Response.Write(""); 此方法缺陷就是不能調用腳本文件中的自定義的函數,只能調用內部函數,具體調用自定義的函數只能在Response.Write寫上函數定 義,比如 Response.Write("");2.用Client...
  • 雖然我已經可以使用很多種編程語言進行工作,但我的工作常常會要求我快速掌握一門新的語言。我沒有選擇去閱讀幾百頁的程式手冊,而是快速瀏覽10到15頁的教程(可以在Google中搜索),並把程式語言的語法參考說明印在小卡片上(在google里搜索language to learn+reference ca...
  • C#導出PDF功能是開發中經常遇到的功能,我們採用第三方的組件,比如iTextSharp,aspose等,還能搜到一些開源的類庫,但是對於一些內容複雜樣式豐富的PDF,我們希望通過傳入一個URL直接生成一個PDF,並且不能與網頁原版差異太大,Pechkin倒是不錯,相對來說差異很小。在 Nuget ...
  • 存儲過程存儲過程一直存在於任何一種關係型資料庫中,如微軟的SQL Server.存儲過程是包含在資料庫中的一些代碼,通常為數據執行一些操作,它能為數據密集型計算提高性能,也能執行一些為業務邏輯. 當你使用數據的時候,有時你會通過存儲過程來獲取它們.在本章, 我們探討一些EF在使用存儲過程時,需要關註...
  • 通常情況下Server是無狀態的,在ASP.NET Web API中,我們可以讓服務端響應體中產生ETag屬性,起到緩存的作用。大致實現原理是:1、服務端的響應體中返回一個ETag屬性2、客戶端通過If-None-Match屬性把ETag的屬性值傳遞給服務端3、服務端返回304狀態碼響應體中返回ET...
  • 9-7. 在WCF服務中序列化代理問題從一個查詢里返回一個動態代理對象,想要把它序列為一個POCO(Plain-Old CLR Objects)對象.實現基於POCO實體對象, 在運行時,EF會為每個實體自動生成一個派生類型,被稱為動態代理對象,代理對象會為POCO類重載很多虛擬屬性來註入執行操作的...
  • 關於Ajax說法錯誤的是( )。(選擇一項)MVC是一種流行的軟體設計模式,它把系統分為三個模塊。三個模塊為( )。在ASP.NET中,關於WebService的說法正確的是( ).NET中Object類是所有類的基類,用戶自定義的類部預設地繼承這個類。以下選項不屬於Object類的方法的是( )。...
  • 訂單揀貨完成後,需要把訂單裝箱打包,並列印客戶地址信息。訂單打包的操作流程先是掃描訂單號,然後掃描商品條碼。 1.訂單打包 列印包裝箱面單 2.訂單發貨 訂單打包完成後就等待發貨,快遞公司來拉貨的時候,進行訂單發貨交接,訂單發貨界面如下
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...