一像素寬的豎線

来源:http://www.cnblogs.com/v2m_/archive/2017/01/15/6288240.html
-Advertisement-
Play Games

設計師很多時候會有一像素線的需求,怎麼去實現有下麵幾種方法。 一、 Image 1. 資源圖片 找設計師要個圖片,用UIImageView 或者 CALayer的方式顯示出來 2. CoreGraphics繪製 用CoreCraphics的方式畫一個 UIImage,然後用1的方法展示出來 此類方法 ...


設計師很多時候會有一像素線的需求,怎麼去實現有下麵幾種方法。

一、 Image

  1. 資源圖片
    找設計師要個圖片,用UIImageView 或者 CALayer的方式顯示出來
  2. CoreGraphics繪製
    用CoreCraphics的方式畫一個 UIImage,然後用1的方法展示出來
    此類方法,記憶體中會多了一個UIImage對象,而且顯示時候也多了一層。

二、drawRect:

  1. path stroke方法(詳見參考1)
  2. path fill方法
    由於現在的 Retina 屏幕,一般 1 point = 2~3 pixels,在 UIView 的 drawRect: 方法中,系統已經設置好 context 的 scale,所以一像素的線寬 是 1.0 / [UIScreen mainScreen].scale
    根據參考2,當有顏色落在兩個 pixel 中間時,由於反鋸齒的特性,會在這兩個 pixel 上都填充上失真顏色的線。
    擴展下,如果在 1 pixel 中繪製 小於 1pixel 的像素,會充滿 1 pixel並且顏色失真;在 2 個pixel 交界的地方繪製小於2 pixel 的線,如果兩邊比例一致,則2個 pixel 都會以同樣失真的顏色繪製,否則比例多的顏色深點,少的淺點;如果跨越很多 pixel 然後邊界超出,比如在 8 個 pixel 中繪製 7 pixel,然後兩邊都有點空餘,那麼就會在兩邊填充失真顏色,中間的是正確的顏色。
    Path中 stroke是根據線(line)的位置,向兩邊各擴散 一半的線寬,所以繪製方法是:使用Path的 moveToPointaddLineToPoint 方法添加一根1 pixel線,然後偏移 目標位置 +0.5 pixel(對應到point 就是 1.0 / [UIScreen mainScreen].scale / 2.0)。
    Path 中 fill 是直接填充框內區域,所以設置好 1 pixel 的區域後,不需要相對目標位置設置偏移。
    對比下下麵兩段代碼,都是畫在第一列 pixel 的

    float u = 1.0 / [UIScreen mainScreen].scale;
    
    UIBezierPath* path = [UIBezierPath bezierPath];
    [path moveToPoint:CGPointMake(u / 2.0, 0)];
    [path addLineToPoint:CGPointMake(u / 2.0, 50)];
    path.lineWidth = u;
    [[UIColor blackColor] set];
    [path stroke];
    float u = 1.0 / [UIScreen mainScreen].scale;
    
    UIBezierPath* path = [UIBezierPath bezierPathWithRect:CGRectMake(0, 0, u, 50)];
    [[UIColor blackColor] set];
    [path fill];

三、Layer

這種方法就是建一個1 pixel寬的layer,然後添加到 UIView 的 layer 上,但是也要註意反鋸齒的問題,也就是說,如果你把這個 layer 的偏移,設置到了 UIView 的兩個 pixel 中間,同樣會看到失真的兩像素線。

    float u = 1.0 / [UIScreen mainScreen].scale;
    CALayer *layer = [CALayer layer];
    layer.frame = CGRectMake(0, 0, 50, u);
    layer.backgroundColor = [UIColor blackColor].CGColor;
    [self.layer addSublayer:layer];

參考
1.http://www.cnblogs.com/smileEvday/p/iOS_PixelVsPoint.html
2.https://developer.apple.com/library/content/documentation/2DDrawing/Conceptual/DrawingPrintingiOS/GraphicsDrawingOverview/GraphicsDrawingOverview.html#//apple_ref/doc/uid/TP40010156-CH14-SW1



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

-Advertisement-
Play Games
更多相關文章
  • 知識點: 1.UIButton使用和事件機制 2.UIImage 3.自定義UIButton UIButton 1.創建方式 按鈕類型 UIButtonTypeCustom 用戶自定義按鈕 UIButtonTypeRoundedRect 系統按鈕 UIButtonTypeDetailDisclosu ...
  • 從這裡開始是UI篇 知識點: 1.常用IOS基本控制項 2.UITouch 常用基本控制項 1.UISegmentedControl:分段控制器 1)創建方式 - (id)initWithItems:(NSArray *)items; items數組中可以有NSString或者是UIImage對象 UI ...
  • MarkDown 一種用於寫作的輕量級【標記語言】。它用簡潔的語法代替排版,而不像一般的文字處理軟體 Word 或者 Pages 有大量的排版、字體設置等。 如果你對文章的樣式沒有太多要求,只註重寫文章本身的話 MarkDown 將會是一個不錯的選擇。 一、 工具 支持 MarkDown 寫作的軟體 ...
  • 一直不想升級Xcode,但是沒辦法項目進度只能升級Xcode8,果然不出所料出現了不少bug, Xcode7運行一直沒有問題,但是在Xcode8上一直輸出AQDefaultDevice (173): skipping input stream 網上查到解決辦法 1.選擇 Product -->Sch ...
  • 假如下麵的一張圖片,是用來做按鈕的背景圖片的,原始尺寸是76 × 40 我們通過代碼將這張圖片設置為按鈕的背景圖片,假如我們將創建好的按鈕的寬高設置為:(W=200, H=50)代碼如下: 結果如下:圖片被拉伸了。 原因分析:是將原是尺寸為76 × 40 的圖片拉伸成了W=200, H=50;解決方 ...
  • 自定義彈框 效果 特點 1.可以定製彈框的樣式和內容。 2.例子中寫了三種不同的彈框樣式,可根據需求增加彈窗樣式。 用法 1.將父類文件夾中的文件拖入自己的工程中,然後定製自己需要的彈窗。(代碼中寫了三個形式彈窗,大家可參考例子編寫自己需要的形式) 2.定製的彈窗都得繼承這個父類,並實現它的方法。 ...
  • 最近在做下拉框,本來想用spinner,可是spinner達不到項目要求,跟同學同事問了一圈,都在用popwindow, 網上看了一下,popwindow挺簡單的,可定製性挺強的,符合我的要求,所以,借鑒網上看的代碼,自己擼了一 遍。寫篇博客以防忘記。 首先,先寫個自定義佈局,代碼如下 <?xml ...
  • 這裡是放代碼的地方嗎? ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...