pteal79/rapid-camera-capture 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

pteal79/rapid-camera-capture

最新稳定版本:1.0.0

Composer 安装命令:

composer require pteal79/rapid-camera-capture

包简介

A NativePHP plugin for persistent camera capture — take multiple photos in one session, saved to mobile_public disk with UUID filenames.

README 文档

README

A NativePHP plugin that opens a persistent camera interface on iOS. The user can tap Take Photo repeatedly to capture multiple images — the camera stays open between shots. Each captured image is saved to the mobile_public disk with a UUID filename and an ImageCaptured event is dispatched to PHP after every capture.

Platform: iOS only.

Installation

composer require pteal79/rapid-camera-capture

# Publish the plugins provider (first time only)
php artisan vendor:publish --tag=nativephp-plugins-provider

# Register the plugin
php artisan native:plugin:register pteal79/rapid-camera-capture

# Verify
php artisan native:plugin:list

Requirements

iOS Permissions

The following is added to your app's Info.plist automatically via the plugin manifest:

Key Description
NSCameraUsageDescription Required for camera access

Usage

Open the Camera

use PTeal79\RapidCameraCapture\Facades\RapidCameraCapture;

RapidCameraCapture::open();

The camera interface is presented full-screen. The user can tap Take Photo as many times as they like. Each photo is saved immediately. The camera closes when the user taps Close.

Handle Captured Images (Livewire)

use Native\Mobile\Attributes\OnNative;
use PTeal79\RapidCameraCapture\Events\ImageCaptured;

#[OnNative(ImageCaptured::class)]
public function onImageCaptured(string $filename, string $path): void
{
    // $filename — UUID-based, e.g. "550e8400-e29b-41d4-a716-446655440000.jpg"
    // $path     — absolute path on the device filesystem

    // Serve the image via the mobile_public disk:
    $url = Storage::disk('mobile_public')->url($filename);
    $this->photos[] = $url;
}

Events

ImageCaptured

Fired after every successful photo capture, before the camera is ready for the next shot.

Property Type Description
filename string UUID filename, e.g. {uuid}.jpg
path string Absolute path to the file on device

JavaScript Usage

import { RapidCameraCapture, Events } from '@pteal79/rapid-camera-capture';
import { On, Off } from '#nativephp';

// Open the camera
await RapidCameraCapture.open();

// React to each captured image
const handler = ({ filename, path }) => {
    console.log('New photo:', filename);
};

On(Events.ImageCaptured, handler);

// Clean up
Off(Events.ImageCaptured, handler);

How It Works

The plugin uses AVCaptureSession with AVCapturePhotoOutput and AVCaptureVideoPreviewLayer for a live, persistent camera preview. Unlike UIImagePickerController, the session stays active so the user can capture an unlimited number of photos in one session. Each JPEG is written to the app's mobile_public storage directory with a UUID filename, then LaravelBridge.shared.send dispatches the ImageCaptured event back to PHP.

License

MIT

统计信息

  • 总下载量: 3
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 7
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: Swift

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-04-14

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固