一个无依赖的 React 图像裁剪工具。
如果 React Crop 不能满足您的需求,可以看看 Pintura(我们的赞助商)。它具有裁剪、旋转、滤镜、注释等更多功能。
npm i react-image-crop --save
yarn add react-image-crop
pnpm add react-image-crop
该库适用于所有现代浏览器。不支持 IE。
引入主 js 模块:
import ReactCrop from 'react-image-crop'
引入 dist/ReactCrop.css
或 ReactCrop.scss
。
import 'react-image-crop/dist/ReactCrop.css' // 或 scss: import 'react-image-crop/src/ReactCrop.scss'
import ReactCrop, { type Crop } from 'react-image-crop' function CropDemo({ src }) { const [crop, setCrop] = useState<Crop>() return ( <ReactCrop crop={crop} onChange={c => setCrop(c)}> <img src={src} /> </ReactCrop> ) }
查看 sandbox 演示 获取更完整的示例。
<link href="https://unpkg.com/react-image-crop/dist/ReactCrop.css" rel="stylesheet" /> <script src="https://unpkg.com/react-image-crop/dist/index.umd.cjs"></script>
注意,使用 <script>
标签全局导入脚本时,需要通过 ReactCrop.Component
访问组件。
onChange: (crop: PixelCrop, percentCrop: PercentCrop) => void
每次裁剪变化时的回调函数(即在拖动/调整大小时会多次触发)。传递当前裁剪状态对象。
注意,您 必须 实现此回调并更新裁剪状态,否则不会有任何变化!
<ReactCrop crop={crop} onChange={(crop, percentCrop) => setCrop(crop)} />
crop
和 percentCrop
可以互换。crop
使用像素,percentCrop
使用百分比来定位和调整大小。百分比裁剪对图像/媒体调整大小具有抗性。
crop?: Crop
从无裁剪开始:
const [crop, setCrop] = useState<Crop>() <ReactCrop crop={crop} onChange={c => setCrop(c)}> <img src={src} /> </ReactCrop>
从预选裁剪开始:
const [crop, setCrop] = useState<Crop>({ unit: '%', // 可以是 'px' 或 '%' x: 25, y: 25, width: 50, height: 50 }) <ReactCrop crop={crop} onChange={c => setCrop(c)}> <img src={src} /> </ReactCrop>
⚠️ 手动设置时,必须确保裁剪在边界内并符合宽高比。使用百分比时,宽高比可能会很棘手。您可以使用 centerCrop
和 makeAspectCrop
辅助函数。查看 如何使裁剪居中? 或 CodeSanbox 演示 获取示例。
aspect?: number
裁剪的宽高比,例如 1
表示正方形,16 / 9
表示横向。省略/传递 undefined 表示自由形状裁剪。
minWidth?: number
最小裁剪宽度,以像素为单位。
minHeight?: number
最小裁剪高度,以像素为单位。
maxWidth?: number
最大裁剪宽度,以像素为单位。
maxHeight?: number
最大裁 剪高度,以像素为单位。
keepSelection?: boolean
如果传入true,则当用户点击选择区域外部时,无法禁用选择。
disabled?: boolean
如果为true,则用户无法调整大小或绘制新的裁剪区域。容器还会添加"ReactCrop--disabled"类以供用户样式设置。
locked?: boolean
如果为true,则用户无法创建或调整裁剪区域大小,但仍可拖动现有的裁剪区域。容器还会添加"ReactCrop--locked"类以供用户样式设置。
className?: string
要添加到主ReactCrop元素的类名字符串。
style?: React.CSSProperties
要传递给图像包装器元素的内联样式对象。
onComplete?: (crop: PixelCrop, percentCrop: PercentCrop) => void
在调整大小、拖动或微调后触发的回调。传递当前的裁剪状态对象。
percentCrop
是百分比形式的裁剪。典型用例是保存它,以便无论图像大小如何(例如在桌面上保存,然后在图像较小的移动设备上使用),都可以恢复用户的裁剪。
onDragStart?: (e: PointerEvent) => void
用户开始拖动或调整大小时触发的回调。适用于操作此组件外部的元素。
onDragEnd?: (e: PointerEvent) => void
用户在拖动或调整大小后释放光标或触摸时触发的回调。
renderSelectionAddon?: (state: ReactCropState) => React.ReactNode
在裁剪选择区域内渲染自定义元素。
ruleOfThirds?: boolean
在裁剪区域显示三分法线。默认为false
。
circularCrop?: boolean
将裁剪区域显 示为圆形。如果aspect
不是1
(正方形),则圆形会变形为椭圆形。默认为false
。
这不是库的一部分,但这里有一个示例 CodeSandbox 演示。
你可能会发现某些图像旋转不正确。很遗憾,这是一个浏览器范围的问题,与本库无关。你需要在传入图像之前修复它。
你可以使用以下库来加载图像,它会为你纠正旋转:https://github.com/blueimp/JavaScript-Load-Image/
你可以在这里阅读有关此主题的问题:https://github.com/sekoyo/react-image-crop/issues/181
如果你正在寻找一个完整的开箱即用的图像编辑器,它已经处理了EXIF旋转,可以考虑使用 Pintura。
<h3>如何过滤、旋转和注释?</h3>这个库deliberately轻量级和简约,以便你可以在其基础上构建功能。如果你希望开箱即用地执行更高级的图像编辑,可以考虑使用 Pintura。
最简单的方法是使用百分比单位:
crop: { unit: '%', width: 50, height: 50, x: 25, y: 25 }
居中一个纵横比裁剪更棘手,特别是在处理%
时。不过,提供了两个辅助函数:
<ReactCrop crop={crop} aspect={16 / 9}> <img src={src} onLoad={onImageLoad} /> </ReactCrop>
makeAspectCrop
创建所需的纵横比,然后使用centerCrop
将其居中:function onImageLoad(e) { const { naturalWidth: width, naturalHeight: height } = e.currentTarget const crop = centerCrop( makeAspectCrop( { // 你不需要传递完整的裁剪到 // makeAspectCrop 或 centerCrop。 unit: '%', width: 90, }, 16 / 9, width, height ), width, height ) setCrop(crop) }
同时记得在更改时使用percentCrop设置你的裁剪:
const onCropChange = (crop, percentCrop) => setCrop(percentCrop)
你的aspect
属性应设置为相同的值:<ReactCrop aspect={16 / 9} ... />
。
要进行开发,运行pnpm install && pnpm dev
并在浏览器中打开localhost服务器。更新代码后它将重新加载。准备好后,打开一个拉取请求。
AI辅助编程,代码自动修复
Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。
最强AI数据分析助手
小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。
像人一样思考的AI智能体
imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。
AI数字人视频创作平台
Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。
一站式AI创作平台
提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作
AI办公助手,复杂任务高效处理
AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!
AI小说写作助手,一站式润色、改写、扩写
蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。
全能AI智能助手,随时解答生活与工作的多样问题
问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。
实时语音翻译/同声传译工具
Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。
一键生成PPT和Word,让学习生活更轻松
讯飞智文是一个 利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。
最新AI工具、AI资讯
独家AI资源、AI项目落地
微信扫一扫关注公众号