
Un recorte de imágenes para iOS como en la aplicación Contactos con soporte para la orientación del paisaje.
RSKIMAGECROPPER requiere iOS 12.0 o posterior.
Para agregar el paquete RSKImageCropper a su proyecto XCode, seleccione Archivo> PAQUETES SWIFT> Agregar dependencia del paquete e ingrese la URL del repositorio.
https://github.com/ruslanskorb/RSKImageCropper.git
Agregue el Pod RSKImageCropper a su podfile.
pod 'RSKImageCropper'
Ejecute pod install desde Terminal, luego abra el archivo .xcworkspace de su aplicación para iniciar Xcode.
Importe el encabezado RSKImageCropper.h . Por lo general, esto debería escribirse como #import <RSKImageCropper/RSKImageCropper.h>
Agregue el proyecto ruslanskorb/RSKImageCropper a su Cartfile.
github "ruslanskorb/RSKImageCropper"
Ejecute carthage update , luego siga los pasos adicionales necesarios para agregar los marcos iOS y/o Mac a su proyecto.
Importe el marco/módulo rskimagecropper.
@import RSKImageCropper#import <RSKImageCropper/RSKImageCropper.h> Importar el encabezado de clase.
# import < RSKImageCropper/RSKImageCropper.h >Simplemente cree un controlador de vista para el recorte de imágenes y configure el delegado.
- ( IBAction )onButtonTouch:(UIButton *)sender
{
UIImage *image = [UIImage imageNamed: @" image " ];
RSKImageCropViewController *imageCropViewController = [[RSKImageCropViewController alloc ] initWithImage: image];
imageCropViewController. delegate = self;
[ self .navigationController pushViewController: imageCropViewController animated: YES ];
} RSKImageCropViewControllerDelegate proporciona tres métodos delegados. Para usarlos, implementa el delegado en su controlador de vista.
@interface ViewController () <RSKImageCropViewControllerDelegate>Luego implementa las funciones delegadas.
// Crop image has been canceled.
- ( void )imageCropViewControllerDidCancelCrop:(RSKImageCropViewController *)controller
{
[ self .navigationController popViewControllerAnimated: YES ];
}
// The original image has been cropped. Additionally provides a rotation angle used to produce image.
- ( void )imageCropViewController:(RSKImageCropViewController *)controller
didCropImage:(UIImage *)croppedImage
usingCropRect:( CGRect )cropRect
rotationAngle:( CGFloat )rotationAngle
{
self. imageView . image = croppedImage;
[ self .navigationController popViewControllerAnimated: YES ];
}
// The original image will be cropped.
- ( void )imageCropViewController:(RSKImageCropViewController *)controller
willCropImage:(UIImage *)originalImage
{
// Use when `applyMaskToCroppedImage` set to YES.
[SVProgressHUD show ];
} RSKImageCropViewControllerDataSource proporciona tres métodos de fuente de datos. El método imageCropViewControllerCustomMaskRect: solicita a la fuente de datos un recto personalizado para la máscara. El método imageCropViewControllerCustomMaskPath: solicita a la fuente de datos una ruta personalizada para la máscara. El método imageCropViewControllerCustomMovementRect: solicita a la fuente de datos para un RECT personalizado en el que se puede mover la imagen. Para usarlos, implementa la fuente de datos en su controlador de vista.
@interface ViewController () <RSKImageCropViewControllerDataSource>Luego implementa las funciones de origen de datos.
// Returns a custom rect for the mask.
- ( CGRect )imageCropViewControllerCustomMaskRect:(RSKImageCropViewController *)controller
{
CGSize aspectRatio = CGSizeMake ( 16 . 0f , 9 . 0f );
CGFloat viewWidth = CGRectGetWidth (controller. view . frame );
CGFloat viewHeight = CGRectGetHeight (controller. view . frame );
CGFloat maskWidth;
if ([controller isPortraitInterfaceOrientation ]) {
maskWidth = viewWidth;
} else {
maskWidth = viewHeight;
}
CGFloat maskHeight;
do {
maskHeight = maskWidth * aspectRatio. height / aspectRatio. width ;
maskWidth -= 1 . 0f ;
} while (maskHeight != floor (maskHeight));
maskWidth += 1 . 0f ;
CGSize maskSize = CGSizeMake (maskWidth, maskHeight);
CGRect maskRect = CGRectMake ((viewWidth - maskSize. width ) * 0 . 5f ,
(viewHeight - maskSize. height ) * 0 . 5f ,
maskSize. width ,
maskSize. height );
return maskRect;
}
// Returns a custom path for the mask.
- (UIBezierPath *)imageCropViewControllerCustomMaskPath:(RSKImageCropViewController *)controller
{
CGRect rect = controller. maskRect ;
CGPoint point1 = CGPointMake ( CGRectGetMinX (rect), CGRectGetMaxY (rect));
CGPoint point2 = CGPointMake ( CGRectGetMaxX (rect), CGRectGetMaxY (rect));
CGPoint point3 = CGPointMake ( CGRectGetMaxX (rect), CGRectGetMinY (rect));
CGPoint point4 = CGPointMake ( CGRectGetMinX (rect), CGRectGetMinY (rect));
UIBezierPath *rectangle = [UIBezierPath bezierPath ];
[rectangle moveToPoint: point1];
[rectangle addLineToPoint: point2];
[rectangle addLineToPoint: point3];
[rectangle addLineToPoint: point4];
[rectangle closePath ];
return rectangle;
}
// Returns a custom rect in which the image can be moved.
- ( CGRect )imageCropViewControllerCustomMovementRect:(RSKImageCropViewController *)controller
{
if (controller. rotationAngle == 0 ) {
return controller. maskRect ;
} else {
CGRect maskRect = controller. maskRect ;
CGFloat rotationAngle = controller. rotationAngle ;
CGRect movementRect = CGRectZero ;
movementRect. size . width = CGRectGetWidth (maskRect) * fabs ( cos (rotationAngle)) + CGRectGetHeight (maskRect) * fabs ( sin (rotationAngle));
movementRect. size . height = CGRectGetHeight (maskRect) * fabs ( cos (rotationAngle)) + CGRectGetWidth (maskRect) * fabs ( sin (rotationAngle));
movementRect. origin . x = CGRectGetMinX (maskRect) + ( CGRectGetWidth (maskRect) - CGRectGetWidth (movementRect)) * 0 . 5f ;
movementRect. origin . y = CGRectGetMinY (maskRect) + ( CGRectGetHeight (maskRect) - CGRectGetHeight (movementRect)) * 0 . 5f ;
movementRect. origin . x = floor ( CGRectGetMinX (movementRect));
movementRect. origin . y = floor ( CGRectGetMinY (movementRect));
movementRect = CGRectIntegral (movementRect);
return movementRect;
}
} Construya y ejecute el proyecto RSKImageCropperExample en xcode para ver RSKImageCropper en acción. Divertirse. Bifurca y envía solicitudes de extracción. Encuentre ganchos para la personalización.
RSKImageCropper no requiere un manifiesto de privacidad. Según la información recibida de Apple, debemos evitar agregar un manifiesto de privacidad vacío a nuestros marcos.
Ruslan Skorb
Este proyecto está disponible bajo la licencia MIT. Consulte el archivo de licencia para obtener más información. Se agradece la atribución al vincular a la página del proyecto.