= Readme
Discord - habeebweeb#6577
:toc:
:toclevels: 4
:pluginname: MeidoPhotoStudio
:photomode: Studio Mode
:config: BepInEx\config{backslash}{pluginname}
{pluginname} is an alternative to {photomode}.
Source can be found https://git.coder.horse/habeebweeb/COM3D2.MeidoPhotoStudio/src/dev[here]
_A full manual, which goes into more depth, will be included when {pluginname} 1.0.0 offcially releases._
== Installation
=== Requirements
{pluginname} is a BepInEx plugin. Get the latest release https://github.com/BepInEx/BepInEx/releases[here].
=== Installation
Move the contents of the `BepInEx` folder into `COM3D2\BepInEx`
== Files
{pluginname} reads and writes files to and from `{config}`.
[horizontal]
Translations:: Contains translation files.
Environments:: Contains saved environments.
Scenes:: Contains saved scenes.
Presets:: Contains poses and hand and face presets
+
_Sample presets are included._
Database:: Contains databases that {pluginname} uses.
+
--
`bg_ignore_list.json`:: List of BGs to ignore when building prop list.
`extra_dogu.json`:: List of extra props that I can't find through nei files
`mm_pose_list.json`:: Collection of in game poses to display.
`face_slider_limits.json`:: Upper limit of face slider values
_Each database file has comments at the top with further information._
--
`cache.dat`:: Cache file for menu files. (Generated at runtime).
`MeidoPhotoStudio.cfg`:: Configuration file. (Generated at runtime).
`mpstempscene`:: A save file that's made when pressing `Ctrl + S`.
NOTE: Environments, scenes, and each preset folder can have single level deep folders within them to allow for grouping.
== Hotkeys
=== Main
[%header, cols="1a, 3"]
|===
| Key | Action
| `F6`
| Activate/deactivate {pluginname} (Only in daily and edit mode)
| `Tab`
| Toggle main window
| `M`
| Toggle message box
| `H`
| Undress all maids
| `F8`
| Hide/show <>
|===
=== Camera
[%header, cols="2a, 3"]
|===
| Key | Action
| `Q + R`
| Reset camera
| `Q + S`
| Save camera
| `Q + A`
| Load saved camera
| `Q + 1-5`
| Switch to another camera
| `Shift + Scroll`
| Zoom camera faster
| `Shift + Middle Drag`
| Pan camera faster
|===
=== Drag Handles
==== General
[%header, cols="2a, 3"]
|===
| Key | Action
| `A + Left Click`
| Select object
| `D + Left Click`
| Delete object
| `C + Drag`
| Scale object
| `C + Double Click`
| Reset object scale
|===
==== Movement
[%header, cols="2a, 3"]
|===
| Key | Action
| `Z + Drag`
| Move object along XZ plane
| `Z + Control + Drag`
| Move object along the y axis
| `Z (+ Control) + Double Click`
| Reset object position
|===
==== Rotation
[%header, cols="2a, 3"]
|===
| Key | Action
| `X + Drag`
| Rotate object along XZ axis
| `Z + Shift + Drag`
| Rotate object along the *world* Y axis
| `X + Shift + Drag`
| Rotate object along its *local* Y axis
| `X + Double Click`
| Reset object rotation
|===
==== Scaling
[%header, cols="2a, 3"]
|===
| Key | Action
| `C + Drag`
| Scale object
| `C + Double Click`
| Reset object scale
|===
==== Maid
[%header, cols="2a, 3a"]
|===
| Key | Action
| `Drag`
|
* Move arms and legs
** Moving from the hand/foot will move the arm/leg like a chain
** Moving from the elbow/knee will rotate the arm/leg using the shoulder/hip as the pivot point
* Move shoulders
| `Alt + Drag`
|
.All along XZ axis
* Rotate torso
* Rotate pelvis
* Rotate head
* Rotate hands/feet
| `Alt + Shift + Drag`
|
.All along local y axis
* Rotate torso
* Rotate pelvis
* Rotate head
* Rotate hands/feet
* Rotate arms/legs (when dragging on elbow/knee respectively)
| `Control + Alt + Drag`
|
* Move both eyes (When dragging on face)
* Move each breast
| `Control + Alt + Shift + Drag`
|
* Move eyes in opposite directions
* Rotate breasts
| `Control + Alt + Double Click`
| Reset eyes and breasts position
| `Control + Drag`
| Rotate forearm/calf using elbow/knee as pivot point
| `Space`
| Rotate fingers/toes
| `Shift + Space`
| Rotate base of fingers/toes along local y axis
| `A + Left Click`
|
* Make selected maid the active maid and switch to pose tab (When clicking on torso)
* Make selected maid the active maid and switch to face tab (When clicking on face)
|===
== Changelog
=== {pluginname}.1.0.0-beta.3.1
==== Fixes
* Fix memory leak when saving scenes to a file
* Handle errors when saving scenes to prevent {pluginname} from locking up
* Fix issue where {pluginname} crashes when trying to save a non-existent background
** SceneCaputre hides the background by destroying it so it caused issues for {pluginname}
=== {pluginname}.1.0.0-beta.3
==== Fixes
* Fix face tab sliders/toggles doing nothing when using face shapekeys in ShapeAnimator
* Fix face blush toggles doing nothing
==== Changes
* Make bone mode drag handles way smaller and more transparent
==== Enhancements
* Add spine as attach points for props
==== New Features
* Add camera Z rotation and FOV slider
* Add camera slots
** There are 5 slots that function similarly to quick save slots
** Cameras can be switched between through the GUI or by holding `Q + (1..5)`
* Add textfield and reset button to some sliders
** textfield and reset buttons were added to the camera pane and lights pane
* Add clothing mask radio buttons to change dressing for individual maids
** Functions the same way as pushing `H` to change all the maid's dressing
* Add user configurable face slider limits
** `Config\MeidoPhotoStudio\Database\face_slider_limits.json` has been added