奔五的人学iOS:swift获取网页并解析需要的内容(1)

12 篇文章 0 订阅
12 篇文章 0 订阅

前言

为了能够写出有价值的应用,除了游戏,即便是游戏也需要网络支持才能让用户产生粘性,游戏中比较获取的等级、积分等如果只保存在手机上,则无法与其他好友进行比较和互动,让我们的应用(或游戏)的互动性大打折扣。如果应用的内容完全由自己来产生,则需要开发服务端、接口,还需要服务器或者虚拟空间,更主要的还运营人员,更有甚者还要编辑、枪手等等,作为一个普通的开发人员,如果按这样的思路那就无法出产品了。
在信息时代,信息无处不在,我们即使没有这些资源,也不用怕,我们信奉拿来主义,将网络上的信息拿来展示即可,当然在拿别的信息时,最好也提供信息的出处,如果信息明显提示不给其他人使用,那就最好别拿。
今天我们就来看看如何从网络获取需要的网页并解析出需要的内容。

我们将通过本文获得以下能力
- pod简单使用
- 通过AFNetworking抓取网页
- 通过DJRefresh分页加载
- 通过Hpple进行页面解析


pod的简单使用

  • pod init
    用xcode生成一个新的工程Top4Geek,在控制台进入工程所在目录,在命令行下输入:
    pod init
    会在工程目录下生成podfile文件
  • podfile编写
    我们使用文本编辑器打开podfile文件,里面已经添加了部分内容,我们按以下内容进行修改
platform :ios, '8.0'
use_frameworks!

target 'Top4Geek' do
    pod 'DJRefresh'
    pod 'AFNetworking'
    pod 'MBProgressHUD'
    pod 'hpple',:git => 'https://github.com/topfunky/hpple.git'
    pod 'SwiftyJSON', :git => 'https://github.com/SwiftyJSON/SwiftyJSON.git'
end

在这里,我们使用csdn的极客头条来完成这个练习,需要的组件有:

组件功能
DJRefresh下拉、上拉加载分页内容
AFNetworking获取网页内容
MBProgressHUD加载时界面提示
hpplehtml解析工具
SwiftyJSONjson解析工具

- pod update
然后在控制台输入命令
pod update
cocoapods会为我们下载各组件并重新生成一个Top4Geek.xcworkspace项目组文件,我们打开这个Top4Geek.xcworkspace项目组文件,以后对项目的组织均通过该项目组工程文件。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
iOS 15 中,可以使用 AVFoundation 中的 AVAssetReader 来解析视频每帧,然后将每帧呈现到 SwiftUI 中的 View 上。 首先,您需要创建一个 AVAssetReader 对象,并为其提供一个 AVAsset 对象。然后,创建一个 AVAssetReaderTrackOutput 对象,并将其添加到 AVAssetReader 上,以便从视频中读取帧。 接下来,您可以使用 AVAssetReaderTrackOutput 的 copyNextSampleBuffer() 方法来获取视频中的下一帧。将返回的 CMSampleBuffer 转换为 CGImage,然后将其呈现到 SwiftUI View 上的 UIImageView 中。 以下是一个简单的示例代码,它演示了如何在 SwiftUI 中解析视频每帧: ```swift import SwiftUI import AVFoundation struct VideoPlayerView: View { let videoURL: URL var body: some View { VideoPlayer(url: videoURL) .onAppear { let asset = AVAsset(url: videoURL) let reader = try! AVAssetReader(asset: asset) let track = asset.tracks(withMediaType: .video)[0] let output = AVAssetReaderTrackOutput(track: track, outputSettings: nil) reader.add(output) reader.startReading() while let sampleBuffer = output.copyNextSampleBuffer() { let imageBuffer = CMSampleBufferGetImageBuffer(sampleBuffer)! let ciImage = CIImage(cvPixelBuffer: imageBuffer) let cgImage = CIContext().createCGImage(ciImage, from: ciImage.extent)! let uiImage = UIImage(cgImage: cgImage) let imageView = UIImageView(image: uiImage) // Do something with imageView CMSampleBufferInvalidate(sampleBuffer) } } } } ``` 注意,此示例仅演示了如何解析视频每帧,并将其呈现到 UIImageView 中。您需要根据自己的需求适当地调整代码,以便将每帧呈现到您的 SwiftUI View 上。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

蜜友

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值