欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解iOS14 Widget 開發(fā)相關(guān)及易報錯地方處理

 更新時間:2020年10月12日 14:33:45   作者:奴良  
這篇文章主要介紹了詳解iOS14 Widget 開發(fā)相關(guān)及易報錯地方處理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

首先了解下如何創(chuàng)建

Xcode -> File -> New -> Target 找到 Widget Extension


如果你的 Widget 支持用戶配置屬性,則需要勾選這個(例如天氣組件,用戶可以選擇城市),不支持的話則不用勾選

了解下創(chuàng)建Widget后,系統(tǒng)給我們生成的文件內(nèi)容

下面這個代碼是沒有勾選 Include Configuration Intent 的地方

Provider

// Provider,顧名思義為小組件提供信息得一個struct
struct Provider: TimelineProvider {
  public typealias Entry = SimpleEntry
  
  // 編輯屏幕時,左上角選擇添加小組件時候,第一次展示小組件會走這個方法
  public func snapshot(with context: Context, completion: @escaping (SimpleEntry) -> ()) {
    
  }

  // 這個方法內(nèi)可以進行網(wǎng)絡(luò)請求,拿到的數(shù)據(jù)保存在對應的 entry 中,調(diào)用 completion 之后會到刷新小組件
  public func timeline(with context: Context, completion: @escaping (Timeline<Entry>) -> ()) {
    // 例如這是一個網(wǎng)絡(luò)請求
    Network.request { data in
      let entry = SimpleEntry(date: renderDate, data: data)
      let timeline = Timeline(entries: [entry], policy: .after(nextRequestDate))
      completion(timeline)
    }
  }
}

Entry

官方解釋: A type that specifies the date to display a widget, and, optionally, indicates the current relevance of the widget's content.

// 我的理解是就是存儲小組件的數(shù)據(jù)的一個東西
struct SimpleEntry: TimelineEntry {
  let date: Date
  let data: Data
}

PlacehodlerView

// 這個是一個默認視圖,例如網(wǎng)絡(luò)請求失敗、發(fā)生未知錯誤、第一次展示小組件都會展示這個view
struct PlaceholderView : View {
  
}

WidgetEntryView

// 這個是我們需要布局小組件長什么樣子的view
struct StaticWidgetEntryView : View {
  
}

主入口

@main
struct StaticWidget: Widget {
  private let kind: String = "StaticWidget"

  public var body: some WidgetConfiguration {
    StaticConfiguration(kind: kind, provider: Provider(), placeholder: PlaceholderView()) { entry in
      StaticWidgetEntryView(entry: entry)
    }
    .configurationDisplayName("My Widget")
    .description("This is an example widget.")
  }
}

支持多Widget樣式

@main
struct MainWidgets: WidgetBundle {

  @WidgetBundleBuilder
  var body: some Widget {
    Widget1()
    Widget2()
  }

}

勾選 Include Configuration Intent 之后可能出錯的地方

如果你的app中設(shè)置了 Class Prefix 這下面這個 ConfigurationIntent.self 則需要加上對應的前綴

例如前綴是 XY 則需要修改為 XYConfigurationIntent.self

@main
struct MainWidget: Widget {
  private let kind: String = "MainWidget"

  public var body: some WidgetConfiguration {
    IntentConfiguration(kind: kind, intent: XYConfigurationIntent.self, provider: Provider(), placeholder: PlaceholderView()) { entry in
      IntentWidgetEntryView(entry: entry)
    }
    .configurationDisplayName("My Widget")
    .description("This is an example widget.")
  }
}

處理Widget點擊事件

Widget 支持三種顯示方式,分別是 systemSmall 、 systemMedium 、 systemLarge
small 樣式只能用 widgetUrl 處理

@ViewBuilder
var body: some View {
  ZStack {
    AvatarView(entry.character)
      .widgetURL(url)
      .foregroundColor(.white)
  }
  .background(Color.gameBackground)
}

medium 和 large 可以用 Link 或者 widgetUrl 處理,我們看到里面有四個相同的view,即左邊圖片,右邊文字的,這個view代碼如下(Link方式)

struct RecipeView: View {
  let recipe: RecipeModel
  
  var body: some View {
    Link(destination: URL(string: "你的網(wǎng)址")!) {
      HStack {
        WebImageView(imageUrl: recipe.squareImageUrl)
          .frame(width: 65, height: 65)
        
        Text(recipe.adjName + recipe.name)
          .font(.footnote)
          .bold()
          .foregroundColor(.black)
          .lineLimit(3)
      }
    }
  } 
}

添加 Link 或 widgetUrl 后,點擊每個 RecipeView 都會觸發(fā)事件,這時候你需要在主項目中的 AppDelegate 中的如下方法進行處理

func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey : Any] = [:]) -> Bool {
    
}

關(guān)于Widget中加載網(wǎng)絡(luò)圖片的時機

當我們在func timeline(withcompletion)這個方法中請求到數(shù)據(jù)拿到圖片鏈接后,必須同步把圖片解析出來,否則直接讓對應的WidgetView去load url 是加載不出來的

正確的寫法

Struct Model {
 ...
 let image: UIImage
}

func timeline(with context: Context, completion: @escaping (Timeline<LFPlanEntry>) -> ()) {
  Network.request { data in
    // 解析圖片
    var image: UIImage? = nil
    if let imageData = try? Data(contentsOf: url) {
      image = UIImage(data: imageData)
    }
    let model = Model(image: image ?? defalutImage) // 這里給個默認圖片
    let entry = SimpleEntry(date: entryDate, data: model)
    let timeline = Timeline(entries: [entry], policy: .atEnd)
    completion(timeline)
  }
}

Struct WidgetView: View {
  
  let model: Model

  @ViewBuilder
  var body: some View {
    Image(uiImage: model.image)
          .resizable()
  }

}

錯誤的寫法(直接丟url給view去加載)

struct WidgetView : View {
  
  let model: Model

  @State private var remoteImage : UIImage? = nil
  
  let defaultImage = UIImage(named: "default")!
  
  var body: some View {
    Image(uiImage: self.remoteImage ?? defaultImage)
      .onAppear(perform: fetchRemoteImage)
  }
  
  func fetchRemoteImage() {
    guard let url = URL(string: model.url) else { return }
    URLSession.shared.dataTask(with: url){ (data, response, error) in
      if let image = UIImage(data: data!){
        self.remoteImage = image
      } else {
        print(error ?? "")
      }
    }.resume()
  }
}

基于我們的app做出來的簡單效果圖

Widget相關(guān)資料

Widgets

Creating a Widget Extension

Keeping a Widget Up To Date

Making a Configurable Widget

到此這篇關(guān)于詳解iOS14 Widget 開發(fā)相關(guān)及易報錯地方處理的文章就介紹到這了,更多相關(guān)iOS14 Widget開發(fā)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • iOS開發(fā)探索多線程GCD常用函數(shù)

    iOS開發(fā)探索多線程GCD常用函數(shù)

    這篇文章主要為大家介紹了iOS開發(fā)探索多線程GCD常用函數(shù)的使用示例介紹,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • 詳解IOS中如何實現(xiàn)瀑布流效果

    詳解IOS中如何實現(xiàn)瀑布流效果

    說到瀑布流, 或許大家都不陌生, 瀑布流的實現(xiàn)也有很多種! 從scrollView 到 tableView 書寫的瀑布流, 然后再到2012年iOS6 蘋果API新加進的collectionView進行的瀑布流封裝! 確實,不論是寫起來還是用起來都要方便很多!那么下面一起來看看IOS中具體如何實現(xiàn)瀑布流效果。
    2016-08-08
  • iOS開發(fā)中簡單實用的幾個小技巧

    iOS開發(fā)中簡單實用的幾個小技巧

    大家可能都知道,在開發(fā)過程中我們總會遇到各種各樣的小問題,有些小問題并不是十分容易解決。在此我就總結(jié)一下,我在開發(fā)中遇到的各種小問題,以及我的解決方法,也算是些小技巧吧,分享給大家,方便大家在iOS開發(fā)的時候能夠參考借鑒,下面有需要的朋友一起來看看吧。
    2016-11-11
  • iOS實現(xiàn)帶動畫的環(huán)形進度條

    iOS實現(xiàn)帶動畫的環(huán)形進度條

    這篇文章主要為大家詳細介紹了iOS實現(xiàn)帶動畫的環(huán)形進度條,同時帶數(shù)字同步效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • 移動端固定輸入框在底部會被鍵盤遮擋的解決方法(必看篇)

    移動端固定輸入框在底部會被鍵盤遮擋的解決方法(必看篇)

    下面小編就為大家分享關(guān)于移動端固定輸入框在底部會被鍵盤遮擋的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • iOS橫屏彈鍵盤的高度錯誤異常解決

    iOS橫屏彈鍵盤的高度錯誤異常解決

    這篇文章主要給大家介紹了關(guān)于iOS橫屏彈鍵盤的高度錯誤異常解決的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • IOS collectionViewCell防止復用的兩種方法

    IOS collectionViewCell防止復用的兩種方法

    這篇文章主要介紹了IOS collectionViewCell防止復用的兩種方法的相關(guān)資料,需要的朋友可以參考下
    2016-11-11
  • iOS本地推送簡單實現(xiàn)代碼

    iOS本地推送簡單實現(xiàn)代碼

    這篇文章主要為大家詳細介紹了iOS本地推送簡單實現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • iOS二維碼的生成代碼

    iOS二維碼的生成代碼

    這篇文章主要為大家詳細介紹了iOS二維碼的生成代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • iOS開發(fā)微信支付的方法

    iOS開發(fā)微信支付的方法

    這篇文章主要為大家詳細介紹了iOS開發(fā)微信支付的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01

最新評論