Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mym0404/react-native-pencil-kit
🎨 iOS PencilKit Component for React Native
https://github.com/mym0404/react-native-pencil-kit
apple draw drawing ios pencil pencil-kit pencilkit react react-native react-native-draw react-native-pencil-kit react-native-pencilkit sketch
Last synced: 3 months ago
JSON representation
🎨 iOS PencilKit Component for React Native
- Host: GitHub
- URL: https://github.com/mym0404/react-native-pencil-kit
- Owner: mym0404
- License: mit
- Created: 2024-04-29T22:08:27.000Z (9 months ago)
- Default Branch: main
- Last Pushed: 2024-07-04T08:21:03.000Z (7 months ago)
- Last Synced: 2024-10-03T16:15:56.294Z (4 months ago)
- Topics: apple, draw, drawing, ios, pencil, pencil-kit, pencilkit, react, react-native, react-native-draw, react-native-pencil-kit, react-native-pencilkit, sketch
- Language: Objective-C++
- Homepage:
- Size: 6.54 MB
- Stars: 15
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
React Native Pencil Kit
iOS Easy & Robust Pencil Kit Porting
**React Native Pencil Kit** is a full API support iOS PencilKit framework porting.
![preview](https://raw.githubusercontent.com/mym0404/image-archive/master/202405040325760.webp)
## Getting Started
```shell
yarn add react-native-pencil-kit
```Link `PencilKit.framework` in the Xcode application project settings
![xcode](https://raw.githubusercontent.com/mym0404/image-archive/master/202405041628753.webp)
> With Fabric, we should access c++ functions and we should use objective-c++.
> This prevents us from Apple SDK framework module importing and we cannot link PencilKit automatically at now.
> If you are using `use_frameworks!`(dynamic linking), this configuration is maybe not required.## Usage
```tsx
import PencilKitView, { type PencilKitRef, type PencilKitTool } from 'react-native-pencil-kit';```
> [!NOTE]
> You can explore full example! [Full Example](https://github.com/mym0404/react-native-pencil-kit/blob/main/example/src/App.tsx)## Props
| Props | Description | Default |
|-----------------------------------|--------------------------------------------------------------------------------------------------------------------------------|---------|
| alwaysBounceVertical | A Boolean value that determines whether bouncing always occurs when vertical scrolling reaches the end of the content. | true |
| alwaysBounceHorizontal | A Boolean value that determines whether bouncing always occurs when horizontal scrolling reaches the end of the content view. | true |
| isRulerActive | A Boolean value that indicates whether a ruler view is visible on the canvas. | false |
| drawingPolicy | The policy that controls the types of touches allowed when drawing on the canvas. This properties can be applied from iOS 14.0 | default |
| backgroundColor | The canvas background color | none |
| isOpaque | Whether the canvas is opaque | true |
| toolPickerVisibilityDidChange | Tells the delegate that the tool picker UI changed visibility. | |
| toolPickerIsRulerActiveDidChange | Tells the delegate that the ruler active state was changed by the user. | |
| toolPickerFramesObscuredDidChange | Tells the delegate that the frames the tool picker obscures changed. | |
| toolPickerSelectedToolDidChange | Tells the delegate that the selected tool was changed by the user. | |
| canvasViewDidBeginUsingTool | Called when the user starts using a tool, eg. selecting, drawing, or erasing. | |
| canvasViewDidEndUsingTool | Called when the user stops using a tool, eg. selecting, drawing, or erasing. | |
| canvasViewDrawingDidChange | Called after the drawing on the canvas did change. | |
| canvasViewDidFinishRendering | Called after setting `drawing` when the entire drawing is rendered and visible. | |## Commands
| Method | Description | Etc |
|------------------------------------------------------------------------------------------|--------------------------------------------------------|------------------------------------------------------------------------------------|
| `clear(): void` | Clear canvas | |
| `showToolPicker(): void` | Show Palette | |
| `hideToolPicker(): void` | Hide Palette | |
| `redo(): void` | Redo last drawing action | |
| `undo(): void` | Undo last drawing action | |
| `saveDrawing(path: string): Promise` | Save drawing data into file system, return base64 data | |
| `getBase64Data(): Promise` | Get current drawing data as base64 string form | |
| `getBase64PngData(options: { scale?: number }): Promise` | Get current drawing data as base64 png form | `scale = 0` means use default `UIScreen.main.scale` |
| `getBase64JpegData(options: { scale?: number; compression?: number }): Promise` | Get current drawing data as base64 jpeg form | `scale = 0` means use default `UIScreen.main.scale`. default compression is `0.93` |
| `loadDrawing(path: string): Promise` | Load drawing data from file system | |
| `loadBase64Data(base64: string): Promise` | Load base64 drawing data into canvas | Use base64 get from `getBase64Data()` |
| `setTool(params: { toolType: PencilKitTool; width?: number; color?: ColorValue }): void` | Set `PencilKitTool` type with width and color | |## Tools
```tsx
- pen
- pencil
- marker
- monoline // ios 17
- fountainPen // ios 17
- watercolor // ios 17
- crayon // ios 17
- eraserVector // width is supported from 16.4
- eraserBitmap // width is supported from 16.4
- eraserFixedWidthBitmap // ios 16.4
```## Utils
Use `PencilKitUtil` for using utilty functions.
- `getAvailableTools(): string[]`
- `isPencilKitAvailable(): boolean`## Troubleshooting
- Pencilkit is not rendered
- This package supports only equal or greater than 14.0 version.
- This package supports only Fabric.## Contributing
- [Contributing](https://github.com/mym0404/react-native-pencil-kit/blob/main/CONTRIBUTING.md)
- [Issues](https://github.com/mym0404/react-native-pencil-kit/issues)
- [PRs](https://github.com/mym0404/react-native-pencil-kit/pulls)
- [Code of Conduct](https://github.com/mym0404/react-native-pencil-kit/blob/main/CODE_OF_CONDUCT.md)## License
- See [LICENSE](/LICENSE)
---
Built and maintained by MJ Studio.