YPImagePicker

YPImagePicker

Instagram 风格的 iOS 图片视频选择库

YPImagePicker 是一个用纯 Swift 编写的 iOS 图片和视频选择库。它提供类似 Instagram 的界面,支持从图库选择、拍照、录像等功能,还包括图片裁剪和滤镜。该库高度可定制,支持单选和多选模式,并提供灵活的配置选项。开发者可以轻松集成该库,并根据应用需求进行个性化设置。它还支持自定义相机界面、视频修剪、多语言等功能,并提供简单的API接口,易于使用。

YPImagePickeriOSSwift图片选择器视频选择器Github开源项目
<h1 align="center"> <br><img src="https://yellow-cdn.veclightyear.com/0a4dffa0/a1af38d3-728f-4c9a-a333-97f061047949.png?raw=true" alt="ypimagepicker" width="512"> <br> <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/db6fe187-337e-4e22-8d4b-ad4efae863ab.jpg" width="400px" >

YPImagePicker

YPImagePicker 是一个用纯 Swift 编写的类似 Instagram 的 iOS 照片/视频选择器。它功能丰富且高度可定制,以满足您应用程序的需求。

Language: Swift 5 Version Platform SPM compatible codebeat badge License: MIT GitHub tag

安装 - 配置 - 使用 - 语言 - UI自定义

快速尝试: pod repo update 然后 pod try YPImagePicker

<img src="https://yellow-cdn.veclightyear.com/0a4dffa0/f495f398-ee29-43b4-9822-3f919f0a834c.PNG" width="200px" > <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/c88c4b10-ccd0-4b55-ac7b-97c221015bc8.PNG" width="200px" > <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/1f537b38-8f7c-4653-8f08-b8c70ed6d90f.PNG" width="200px" > <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/fb84f5fa-9650-4991-9c56-9dcd7d82b433.PNG" width="200px" >

只需几行代码就可以使用这些功能!

主要特性

🌅 图库
📷 照片
🎥 视频
✂️ 裁剪
⚡️ 闪光灯
🖼 滤镜
📁 相册
🔢 多选
📏 视频剪辑和封面选择
📐 输出图像尺寸
以及更多...

安装

使用 CocoaPods

首先确保运行 pod repo update 以获取最新可用版本。

pod 'YPImagePicker' 添加到您的 Podfile 并运行 pod install。同时在 Podfile 中添加 use_frameworks!

target 'MyApp'
pod 'YPImagePicker'
use_frameworks!

使用 Swift Package Manager

通过 File > Swift Pakcages > Add Package Dependency... 打开 SPM 依赖管理器。

并插入存储库 URL:

https://github.com/Yummypets/YPImagePicker.git

要在自己的包中添加依赖项,只需在 Package.swift 的依赖项中指定一个包:

.package( name: "YPImagePicker", url: "https://github.com/Yummypets/YPImagePicker.git", .upToNextMajor(from: "5.0.0") )

注意:这需要最低目标 iOS 版本为 12.0

Plist 条目

为了让您的应用访问相机和照片库, 您需要添加这些 plist 条目

  • Privacy - Camera Usage Description(照片/视频)
  • Privacy - Photo Library Usage Description(图库)
  • Privacy - Microphone Usage Description(视频)
<key>NSCameraUsageDescription</key> <string>您的描述</string> <key>NSPhotoLibraryUsageDescription</key> <string>您的描述</string> <key>NSMicrophoneUsageDescription</key> <string>您的描述</string>

配置

所有配置端点都在 YPImagePickerConfiguration 结构体中。 以下是默认值供参考,请随意尝试 :)

var config = YPImagePickerConfiguration() // [在这里编辑配置...] // 用您的配置构建选择器 let picker = YPImagePicker(configuration: config)

常规

config.isScrollToChangeModesEnabled = true config.onlySquareImagesFromCamera = true config.usesFrontCamera = false config.showsPhotoFilters = true config.showsVideoTrimmer = true config.shouldSaveNewPicturesToAlbum = true config.albumName = "DefaultYPImagePickerAlbumName" config.startOnScreen = YPPickerScreen.photo config.screens = [.library, .photo] config.showsCrop = .none config.targetImageSize = YPImageSize.original config.overlayView = UIView() config.hidesStatusBar = true config.hidesBottomBar = false config.hidesCancelButton = false config.preferredStatusBarStyle = UIStatusBarStyle.default config.bottomMenuItemSelectedColour = UIColor(r: 38, g: 38, b: 38) config.bottomMenuItemUnSelectedColour = UIColor(r: 153, g: 153, b: 153) config.filters = [DefaultYPFilters...] config.maxCameraZoomFactor = 1.0 config.fonts..

config.library.options = nil config.library.onlySquare = false config.library.isSquareByDefault = true config.library.minWidthForItem = nil config.library.mediaType = YPlibraryMediaType.photo config.library.defaultMultipleSelection = false config.library.maxNumberOfItems = 1 config.library.minNumberOfItems = 1 config.library.numberOfItemsInRow = 4 config.library.spacingBetweenItems = 1.0 config.library.skipSelectionsGallery = false config.library.preselectedItems = nil config.library.preSelectItemOnMultipleSelection = true

视频

config.video.compression = AVAssetExportPresetHighestQuality config.video.fileType = .mov config.video.recordingTimeLimit = 60.0 config.video.libraryTimeLimit = 60.0 config.video.minimumTimeLimit = 3.0 config.video.trimmerMaxDuration = 60.0 config.video.trimmerMinDuration = 3.0

画廊

config.gallery.hidesRemoveButton = false

默认配置

// 为所有选择器设置默认配置 YPImagePickerConfiguration.shared = config // 然后像这样使用默认配置: let picker = YPImagePicker()

在iPad上显示选择器时,选择器只支持一种尺寸,你应该在显示之前设置它:

let preferredContentSize = CGSize(width: 500, height: 600);
YPImagePickerConfiguration.widthOniPad = preferredContentSize.width;

// 现在你可以在对话框、弹出窗口等中以首选尺寸显示选择器

使用方法

首先要导入 import YPImagePicker

选择器只有一个回调 didFinishPicking,使你能够处理所有情况。让我们看一些典型的使用案例 🤓

单张照片

let picker = YPImagePicker() picker.didFinishPicking { [unowned picker] items, _ in if let photo = items.singlePhoto { print(photo.fromCamera) // 图像来源(相机或图库) print(photo.image) // 用户最终选择的图像 print(photo.originalImage) // 用户选择的原始图像,未经过滤 print(photo.modifiedImage) // 转换后的图像,可能为nil print(photo.exifMeta) // 打印原始图像的exif元数据 } picker.dismiss(animated: true, completion: nil) } present(picker, animated: true, completion: nil)

单个视频

// 在这里我们配置选择器只显示视频,不显示照片 var config = YPImagePickerConfiguration() config.screens = [.library, .video] config.library.mediaType = .video let picker = YPImagePicker(configuration: config) picker.didFinishPicking { [unowned picker] items, _ in if let video = items.singleVideo { print(video.fromCamera) print(video.thumbnail) print(video.url) } picker.dismiss(animated: true, completion: nil) } present(picker, animated: true, completion: nil)

如你所见,singlePhotosingleVideo 辅助方法可以帮助你处理单一媒体,这在很多情况下都很常见,同时使用相同的回调来处理所有用例 \o/

多选

要启用多选,请确保在配置中设置 library.maxNumberOfItems,如下所示:

var config = YPImagePickerConfiguration() config.library.maxNumberOfItems = 3 let picker = YPImagePicker(configuration: config)

然后你可以在同一个回调中处理多选:

picker.didFinishPicking { [unowned picker] items, cancelled in for item in items { switch item { case .photo(let photo): print(photo) case .video(let video): print(video) } } picker.dismiss(animated: true, completion: nil) }

处理取消事件(如果需要)

picker.didFinishPicking { [unowned picker] items, cancelled in if cancelled { print("选择器被取消") } picker.dismiss(animated: true, completion: nil) }

就是这样!

语言

🇺🇸 英语, 🇪🇸 西班牙语, 🇫🇷 法语 🇷🇺 俄语, 🇵🇱 波兰语, 🇳🇱 荷兰语, 🇧🇷 巴西葡萄牙语, 🇹🇷 土耳其语, 🇸🇾 阿拉伯语, 🇩🇪 德语, 🇮🇹 意大利语, 🇯🇵 日语, 🇨🇳 中文, 🇮🇩 印度尼西亚语, 🇰🇷 韩语, 🇹🇼 繁体中文(台湾), 🇻🇳 越南语, 🇹🇭 泰语, 🇨🇿 捷克语, 🇮🇷 波斯语。

如果你的语言不受支持,你仍然可以通过 configuration.wordings API 自定义文字:

config.wordings.libraryTitle = "图库" config.wordings.cameraTitle = "相机" config.wordings.next = "确定"

更好的是,你可以提交一个问题或拉取请求,附上你的 Localizable.strings 文件来添加新语言!

UI 自定义

我们尽量保持原生风格,所以这主要通过原生API实现。

导航栏颜色

let coloredImage = UIImage(color: .red) UINavigationBar.appearance().setBackgroundImage(coloredImage, for: UIBarMetrics.default) // UIImage+color 辅助方法 https://stackoverflow.com/questions/26542035/create-uiimage-with-solid-color-in-swift

导航栏字体

let attributes = [NSAttributedString.Key.font : UIFont.systemFont(ofSize: 30, weight: .bold) ] UINavigationBar.appearance().titleTextAttributes = attributes // 标题字体 UIBarButtonItem.appearance().setTitleTextAttributes(attributes, for: .normal) // 导航栏按钮字体

导航栏文字颜色

UINavigationBar.appearance().titleTextAttributes = [NSAttributedString.Key.foregroundColor : UIColor.yellow ] // 标题颜色 UINavigationBar.appearance().tintColor = .red // 左侧导航栏按钮 config.colors.tintColor = .green // 右侧导航栏按钮(操作)

原始项目与作者

这个项目最初受到 Fusuma 的启发 考虑到大量的代码、设计变更以及随时间添加的所有额外功能,这个项目从一个分支演变成了一个独立的单独仓库,也是为了便于发现。 原始 Fusuma 作者是 ytakz

核心团队

<a href="https://github.com/S4cha"> <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/f1167cb5-958a-43f1-b451-22e1711a20bb.png" width="70px"> </a> <a href="https://github.com/NikKovIos"> <img src="https://yellow-cdn.veclightyear.com/0a4dffa0/002d39e2-f9fb-4ef3-8205-b4184ab7eff4.png" width="70px"> </a> ## 贡献者 🙏 [ezisazis](https://github.com/ezisazis)、 [hanikeddah](https://github.com/hanikeddah)、 [tahaburak](https://github.com/tahaburak)、 [ajkolean](https://github.com/ajkolean)、 [Anarchoschnitzel](https://github.com/Anarchoschnitzel)、 [Emil](https://github.com/heitara)、 [Rafael Damasceno](https://github.com/DamascenoRafael)、 [cenkingunlugu](https://github.com/https://github.com/cenkingunlugu)、 [heitara](https://github.com/heitara)、 [portellaa](https://github.com/portellaa)、 [Romixery](https://github.com/romixery)、 [shotat](https://github.com/shotat)、 [shalamowww](https://github.com/shalamowww)

特别感谢 ihtiht 设计的酷炫logo!

以各种方式帮助我们的人 👏

userdarEvgeniyMehdiMahdlooom-hauserdarChintanWeappeddieespinalviktorgardartgdelarosacwestMobileTinyikVivekthakur647tomasbykowskiartemsmikhtheolofdongdong3344MHX792CIronfoundersonGuerrixZedd0202mohammadZ74SalmanGhumsaniwegweiser6BilalAkramKazimAhmadJustinBeBoySashaMeyerGShushanikCez95PalandosebastienboulogneJigneshParekh7165DeepakepaisaAndreiBoariunathankonrad1wawilliams003pngo-hypewellPawanManjanidevender54321Didar1994relaxsusrestoflash

依赖

YPImagePicker 依赖 prynt/PryntTrimmerView 来提供视频裁剪和封面功能。非常感谢 @HHK1 将其开源 :)

Objective-C 支持

我们不支持 Objective-C,这也不在我们的计划之内。 Swift 是未来,放弃 Objective-C 是保持这个库开发速度的必要代价 :)

许可证

YPImagePicker 基于 MIT 许可发布。 详情请查看 LICENSE

Swift 版本

  • Swift 3 -> 版本 1.2.0
  • Swift 4.1 -> 版本 3.4.1
  • Swift 4.2 -> 版本 3.5.2
  • Swift 5.0 -> 版本 4.0.0
  • Swift 5.1 -> 版本 4.1.2
  • Swift 5.3 -> 版本 4.5.0

编辑推荐精选

TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
蛙蛙写作

蛙蛙写作

AI小说写作助手,一站式润色、改写、扩写

蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。

AI辅助写作AI工具蛙蛙写作AI写作工具学术助手办公助手营销助手AI助手
问小白

问小白

全能AI智能助手,随时解答生活与工作的多样问题

问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。

热门AI助手AI对话AI工具聊天机器人
Transly

Transly

实时语音翻译/同声传译工具

Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

下拉加载更多