mirror of
https://github.com/overte-org/community-apps.git
synced 2025-04-05 21:22:00 +02:00
Add the "Camera Snap-Pro" (tabletCam) application.
Add the "Camera Snap-Pro" (tabletCam) application.
This commit is contained in:
parent
b86532f43e
commit
36bc6d75d2
13 changed files with 2491 additions and 0 deletions
|
@ -152,6 +152,15 @@ var metadata = { "applications":
|
|||
"jsfile": "home/app_home.js",
|
||||
"icon": "home/appicon_i.png",
|
||||
"caption": "HOME"
|
||||
},
|
||||
{
|
||||
"isActive": true,
|
||||
"directory": "tabletCam",
|
||||
"name": "Camera Snap-Pro",
|
||||
"description": "The Camera 'Snap-Pro' allows you to take high quality in-world photos and selfies (Low, Normal, 4K, and 'EXTREME' resolution). It has two cameras on the tablet, front-facing/rear-facing, and one detachable to allow more flexibility. It supports different aspect ratio formats: 8x10, 2x3, 9x16 and 'Square'. It comes with an Optical Zoom, a trigger on the VR hand controller and other features.",
|
||||
"jsfile": "tabletCam/tabletCam_app.js",
|
||||
"icon": "tabletCam/appIcons/snap-pro-i.svg",
|
||||
"caption": "SNAP-PRO"
|
||||
}
|
||||
]
|
||||
};
|
||||
|
|
77
applications/tabletCam/README.md
Normal file
77
applications/tabletCam/README.md
Normal file
|
@ -0,0 +1,77 @@
|
|||
# Tablet Cam
|
||||
|
||||
## Note
|
||||
|
||||
This was a personal project by [Zach Fox](https://github.com/zfox23/), a member of the High Fidelity Experiences Team. It has not undergone the same code review or QA process as the rest of the projects in this repository.
|
||||
|
||||
## Description
|
||||
|
||||
The Tablet Cam app allows you to **easily take selfies and regular photos in High Fidelity/Overte** using your Tablet or hand controllers!
|
||||
|
||||
## Features
|
||||
|
||||
- **Front-facing and rear-facing** cameras and flashes with optional **custom positioning**
|
||||
- Works in **Desktop Mode and in VR Mode**
|
||||
- **Persistent "Camera Roll"** for reviewing photos that you recently took
|
||||
- Optical **zoom**
|
||||
- Photo **quality settings**: Low, Normal, 4k, and _EXTREME_!
|
||||
- **Aspect ratio settings**: 8x10, 2x3, 9x16, Square
|
||||
- Editable photo directory
|
||||
|
||||
## Changelog
|
||||
|
||||
### v2.4 (2022-08-22) by Alezia Kurdis
|
||||
|
||||
- Fixed a but in HMD where the rear-facing camera was pointed to the tablet instead of the scene.
|
||||
- Replaced the camera model by a new one (nicer and less heavy, 198k instead of 576k, less but more optimal polygons, 1 PBR material.)
|
||||
- Renamed the tool: Camera Snap-Pro
|
||||
- Replaced the icons for something more easy to identify as a device to take picture ("camera"), as an advance version of the "Snap" app.
|
||||
- Add a notice in the settings page to informe the user about the trigger on the thumbstick of the right VR hand controller.
|
||||
|
||||
### v2.3 (2019-10-15)
|
||||
|
||||
- Removed unnecessary tone curve correction present in captured Tablet Cam output image.
|
||||
- Adjusted y-offset of Desktop-mode selfie cam to better serve Virtual You avatars.
|
||||
- Added `"Head"` as a backup joint to `"HeadTop_End"` for certain operations.
|
||||
|
||||
### v2.2 (2019-07-09)
|
||||
|
||||
- Fixed a hack in which the secondary camera feed was darkened to compensate for it being rendered too light.
|
||||
- If your camera looks too light, it means you have an older version of Interface (pre PR #15862) and should go back to the previous version of this script.
|
||||
- If your camera looks too dark, it means you have a newer version of Interface (post PR #15682) and should update to the current version of this script.
|
||||
|
||||
### v2.1 (2019-06-27)
|
||||
|
||||
- We've moved the code for this project into a new remote folder, which necessitated a version bump. There are no changes to functionality.
|
||||
|
||||
### v2.0 (2019-04)
|
||||
|
||||
**I've made some huge changes in v2.0!**
|
||||
|
||||
- In Desktop mode, when using the rear-facing camera and while you're using Third Person Camera, Tablet Cam will now be parented to Interface's Third Person Camera!
|
||||
- The camera's viewpoint can now be detached from its default position! Snap a photo from a unique viewpoint.
|
||||
- Fixed a bug that caused zoom settings to be saved incorrectly between restarts.
|
||||
- Fixed a bug that caused the camera preview to show up as a corrupted image in HMD mode.
|
||||
- Fixed a bug that caused the position of the rear-facing camera to be incorrect in HMD mode.
|
||||
- Switched Overlay usage to Local Entities.
|
||||
- Now you can use Tablet Cam in Desktop mode while "Desktop Tablet becomes Toolbar" is unchecked - although I'm not sure why you'd want to do that. :)
|
||||
- Fixed some interface bugs.
|
||||
|
||||
### v1.1 (2019-02)
|
||||
|
||||
- Fixed a bug that caused Tablet Cam to erroneously appear on the Tablet after switching domains when it was previously active.
|
||||
|
||||
### Tablet Cam v1.0 (2019-01)
|
||||
|
||||
- Tablet Cam v1.0 is an update to Selfie Cam v1.0. It is a complete overhaul of the app. All of its features are new!
|
||||
|
||||
### Selfie Cam v1.0 (2018-12)
|
||||
|
||||
- Initial Release!
|
||||
|
||||
## Attributions
|
||||
- "snap.wav" from "Camera Shutter, Fast, A.wav" by InspectorJ (www.jshaw.co.uk) of Freesound.org
|
||||
- "switchCams.svg" from "rotate camera" by Diego Naive from the Noun Project
|
||||
- "orientation.svg" from "orientation" by Atif Arshad from the Noun Project
|
||||
- "camera.fbx" from "Digital camera" by Nick Ladd: https://poly.google.com/view/4A3SYVh_smq
|
||||
- "camera-a.svg" and "camera-i.svg" from "Selfie" by Path Lord from the Noun Project
|
226
applications/tabletCam/appIcons/snap-pro-a.svg
Normal file
226
applications/tabletCam/appIcons/snap-pro-a.svg
Normal file
|
@ -0,0 +1,226 @@
|
|||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||
|
||||
<svg
|
||||
width="50"
|
||||
height="50"
|
||||
viewBox="0 0 13.229167 13.229167"
|
||||
version="1.1"
|
||||
id="svg5"
|
||||
inkscape:version="1.1.1 (3bf5ae0d25, 2021-09-20)"
|
||||
sodipodi:docname="snap-pro-a.svg"
|
||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
xmlns:svg="http://www.w3.org/2000/svg"
|
||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||
xmlns:cc="http://creativecommons.org/ns#"
|
||||
xmlns:dc="http://purl.org/dc/elements/1.1/">
|
||||
<title
|
||||
id="title7500">snap-pro-a</title>
|
||||
<sodipodi:namedview
|
||||
id="namedview7"
|
||||
pagecolor="#ffffff"
|
||||
bordercolor="#666666"
|
||||
borderopacity="1.0"
|
||||
inkscape:pageshadow="2"
|
||||
inkscape:pageopacity="0.0"
|
||||
inkscape:pagecheckerboard="0"
|
||||
inkscape:document-units="mm"
|
||||
showgrid="false"
|
||||
showguides="false"
|
||||
units="px"
|
||||
width="50px"
|
||||
inkscape:zoom="6.0007856"
|
||||
inkscape:cx="65.408102"
|
||||
inkscape:cy="39.828118"
|
||||
inkscape:window-width="1628"
|
||||
inkscape:window-height="932"
|
||||
inkscape:window-x="1690"
|
||||
inkscape:window-y="22"
|
||||
inkscape:window-maximized="0"
|
||||
inkscape:current-layer="layer1" />
|
||||
<defs
|
||||
id="defs2">
|
||||
<symbol
|
||||
id="u"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 14.656,-0.875 c -0.76172,0.39844 -1.5547,0.69531 -2.375,0.89062 -0.8125,0.19531 -1.6641,0.29688 -2.5469,0.29688 -2.6562,0 -4.7617,-0.73828 -6.3125,-2.2188 -1.5547,-1.4883 -2.3281,-3.5039 -2.3281,-6.0469 0,-2.5508 0.77344,-4.5664 2.3281,-6.0469 1.5508,-1.4883 3.6562,-2.2344 6.3125,-2.2344 0.88281,0 1.7344,0.10156 2.5469,0.29688 0.82031,0.19922 1.6133,0.49609 2.375,0.89062 v 3.2969 c -0.76172,-0.51953 -1.5117,-0.89844 -2.25,-1.1406 -0.74219,-0.23828 -1.5234,-0.35938 -2.3438,-0.35938 -1.4688,0 -2.625,0.46875 -3.4688,1.4062 -0.83594,0.9375 -1.25,2.2344 -1.25,3.8906 0,1.6484 0.41406,2.9375 1.25,3.875 0.84375,0.9375 2,1.4062 3.4688,1.4062 0.82031,0 1.6016,-0.11719 2.3438,-0.35938 0.73828,-0.23828 1.4883,-0.61719 2.25,-1.1406 z"
|
||||
id="path824" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="b"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 10.719,-8.7031 c -0.33594,-0.15625 -0.66797,-0.26953 -1,-0.34375 -0.32422,-0.082031 -0.65625,-0.125 -1,-0.125 -0.98047,0 -1.7344,0.32031 -2.2656,0.95312 -0.53125,0.625 -0.79688,1.5273 -0.79688,2.7031 V -3e-5 h -3.8125 v -11.969 h 3.8125 v 1.9688 c 0.48828,-0.78125 1.0508,-1.3477 1.6875,-1.7031 0.64453,-0.36328 1.4102,-0.54688 2.2969,-0.54688 0.13281,0 0.27344,0.0078 0.42188,0.01563 0.14453,0.01172 0.36328,0.03125 0.65625,0.0625 z"
|
||||
id="path827" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="a"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 13.781,-6.0156 v 1.0938 H 4.8435 c 0.09375,0.89844 0.41406,1.5703 0.96875,2.0156 0.55078,0.44922 1.3281,0.67188 2.3281,0.67188 0.80078,0 1.625,-0.11719 2.4688,-0.35938 0.84375,-0.23828 1.7109,-0.59766 2.6094,-1.0781 v 2.9531 c -0.90625,0.33594 -1.8125,0.58984 -2.7188,0.76562 -0.9063,0.17578 -1.8125,0.26562 -2.7188,0.26562 -2.1562,0 -3.8398,-0.54688 -5.0469,-1.6406 -1.1992,-1.1016 -1.7969,-2.6484 -1.7969,-4.6406 0,-1.9453 0.58594,-3.4766 1.7656,-4.5938 1.1758,-1.125 2.8008,-1.6875 4.875,-1.6875 1.875,0 3.375,0.57031 4.5,1.7031 1.1328,1.125 1.7031,2.6367 1.7031,4.5312 z M 9.8435,-7.2812 c 0,-0.72656 -0.21484,-1.3125 -0.64062,-1.75 -0.41797,-0.44531 -0.96875,-0.67188 -1.6562,-0.67188 -0.74219,0 -1.3438,0.21094 -1.8125,0.625 -0.46094,0.41797 -0.74609,1.0156 -0.85938,1.7969 z"
|
||||
id="path830" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="d"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 7.2031,-5.3906 c -0.80469,0 -1.4062,0.13672 -1.8125,0.40625 -0.39844,0.27344 -0.59375,0.67188 -0.59375,1.2031 0,0.48047 0.16016,0.85938 0.48438,1.1406 0.32031,0.27344 0.77344,0.40625 1.3594,0.40625 0.71875,0 1.3203,-0.25391 1.8125,-0.76562 0.48828,-0.51953 0.73438,-1.1719 0.73438,-1.9531 v -0.4375 z m 5.8438,-1.4375 V 0 H 9.1875 v -1.7656 c -0.51172,0.71875 -1.0898,1.2461 -1.7344,1.5781 -0.63672,0.33203 -1.418,0.5 -2.3438,0.5 -1.2422,0 -2.2461,-0.35938 -3.0156,-1.0781 -0.77344,-0.72656 -1.1562,-1.6719 -1.1562,-2.8281 0,-1.3945 0.47656,-2.4219 1.4375,-3.0781 0.96875,-0.65625 2.4883,-0.98438 4.5625,-0.98438 h 2.25 v -0.29688 c 0,-0.60156 -0.24219,-1.0469 -0.71875,-1.3281 -0.48047,-0.28125 -1.2266,-0.42188 -2.2344,-0.42188 -0.8125,0 -1.5742,0.085937 -2.2812,0.25 -0.71094,0.15625 -1.3672,0.40234 -1.9688,0.73438 v -2.9219 c 0.82031,-0.19531 1.6445,-0.34766 2.4688,-0.45312 0.82031,-0.10156 1.6484,-0.15625 2.4844,-0.15625 2.1562,0 3.7109,0.42969 4.6719,1.2812 0.95703,0.84375 1.4375,2.2266 1.4375,4.1406 z"
|
||||
id="path833" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="c"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 6.0156,-15.359 v 3.3906 H 9.9531 V -9.234 H 6.0156 v 5.0781 c 0,0.55469 0.10938,0.92969 0.32812,1.125 0.21875,0.19922 0.65625,0.29688 1.3125,0.29688 h 1.9688 v 2.7344 h -3.2812 c -1.5117,0 -2.5859,-0.3125 -3.2188,-0.9375 -0.625,-0.63281 -0.9375,-1.707 -0.9375,-3.2188 v -5.0781 h -1.9062 v -2.7344 h 1.9062 v -3.3906 z"
|
||||
id="path836" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="g"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 9.9688,-10.219 v -6.4062 h 3.8594 V -2e-4 H 9.9688 V -1.7346 C 9.44536,-1.02366 8.8672,-0.5041 8.2344,-0.1721 7.59768,0.14821 6.8633,0.31228 6.0313,0.31228 c -1.4688,0 -2.6797,-0.58203 -3.625,-1.75 -0.94922,-1.1758 -1.4219,-2.6875 -1.4219,-4.5312 0,-1.8437 0.47266,-3.3477 1.4219,-4.5156 0.94531,-1.1758 2.1562,-1.7656 3.625,-1.7656 0.83203,0 1.5664,0.16797 2.2031,0.5 0.63281,0.32422 1.2109,0.83594 1.7344,1.5312 z m -2.5156,7.75 c 0.82031,0 1.4453,-0.29688 1.875,-0.89062 0.42578,-0.60156 0.64062,-1.4727 0.64062,-2.6094 0,-1.1445 -0.21484,-2.0156 -0.64062,-2.6094 -0.42969,-0.59375 -1.0547,-0.89062 -1.875,-0.89062 -0.8125,0 -1.4336,0.29688 -1.8594,0.89062 -0.42969,0.59375 -0.64062,1.4648 -0.64062,2.6094 0,1.1367 0.21094,2.0078 0.64062,2.6094 0.42578,0.59375 1.0469,0.89062 1.8594,0.89062 z"
|
||||
id="path839" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="k"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 8.2031,-2.4688 c 0.82031,0 1.4453,-0.29688 1.875,-0.89062 0.42578,-0.60156 0.64062,-1.4727 0.64062,-2.6094 0,-1.1445 -0.21484,-2.0156 -0.64062,-2.6094 -0.42969,-0.59375 -1.0547,-0.89062 -1.875,-0.89062 -0.82422,0 -1.4531,0.30469 -1.8906,0.90625 -0.4375,0.59375 -0.65625,1.4609 -0.65625,2.5938 0,1.1367 0.21875,2.0078 0.65625,2.6094 0.4375,0.59375 1.0664,0.89062 1.8906,0.89062 z m -2.5469,-7.75 c 0.53125,-0.69531 1.1133,-1.207 1.75,-1.5312 0.64453,-0.33203 1.3828,-0.5 2.2188,-0.5 1.4688,0 2.6758,0.58984 3.625,1.7656 0.94531,1.168 1.4219,2.6719 1.4219,4.5156 0,1.8437 -0.47656,3.3555 -1.4219,4.5312 -0.94922,1.168 -2.1562,1.75 -3.625,1.75 -0.83594,0 -1.5742,-0.16797 -2.2188,-0.5 -0.63672,-0.33203 -1.2188,-0.84766 -1.75,-1.5469 V -1e-4 H 1.8437 v -16.625 h 3.8125 z"
|
||||
id="path842" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="j"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 0.26562,-11.969 h 3.8281 l 3.2188,8.125 2.7344,-8.125 h 3.8125 L 8.82822,1.125 c -0.5,1.332 -1.0898,2.2656 -1.7656,2.7969 -0.66797,0.53125 -1.5547,0.79688 -2.6562,0.79688 h -2.2188 v -2.5 h 1.2031 c 0.64453,0 1.1133,-0.10547 1.4062,-0.3125 C 5.0977,1.69534 5.32817,1.32816 5.48442,0.79688 L 5.5938,0.45313 Z"
|
||||
id="path845" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="i"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="M 2.0156,-15.953 H 6.125 V 0 H 2.0156 Z"
|
||||
id="path848" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="f"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="M 13.859,-7.2812 V 0 h -3.8438 v -5.5781 c 0,-1.0312 -0.027344,-1.7383 -0.078125,-2.125 -0.042969,-0.39453 -0.12109,-0.6875 -0.23438,-0.875 -0.14844,-0.25 -0.35156,-0.44141 -0.60938,-0.57812 -0.25,-0.14453 -0.54297,-0.21875 -0.875,-0.21875 -0.79297,0 -1.418,0.3125 -1.875,0.9375 -0.46094,0.61719 -0.6875,1.4648 -0.6875,2.5469 V 3e-5 h -3.8125 v -11.969 h 3.8125 v 1.75 c 0.58203,-0.69531 1.1953,-1.207 1.8438,-1.5312 0.64453,-0.33203 1.3594,-0.5 2.1406,-0.5 1.3828,0 2.4297,0.42969 3.1406,1.2812 0.71875,0.84375 1.0781,2.0742 1.0781,3.6875 z"
|
||||
id="path851" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="t"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="M 1.8438,-11.969 H 5.6563 V 0 H 1.8438 Z m 0,-4.6562 h 3.8125 v 3.125 H 1.8438 Z"
|
||||
id="path854" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="h"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 9.7031,-16.625 v 2.5156 H 7.5937 c -0.54297,0 -0.92188,0.10156 -1.1406,0.29688 -0.21094,0.19922 -0.3125,0.53906 -0.3125,1.0156 v 0.82812 h 3.2656 v 2.7344 H 6.1406 V 0 H 2.3125 V -9.2344 H 0.4219 v -2.7344 h 1.8906 v -0.82812 c 0,-1.3008 0.36328,-2.2656 1.0938,-2.8906 0.72656,-0.625 1.8516,-0.9375 3.375,-0.9375 z"
|
||||
id="path857" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="s"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 11.188,-11.594 v 2.9062 c -0.82422,-0.34375 -1.6172,-0.59766 -2.375,-0.76562 -0.76172,-0.16406 -1.4805,-0.25 -2.1562,-0.25 -0.73047,0 -1.2734,0.089844 -1.625,0.26562 -0.35547,0.17969 -0.53125,0.46094 -0.53125,0.84375 0,0.30469 0.13281,0.53906 0.40625,0.70312 0.26953,0.16797 0.75,0.28906 1.4375,0.35938 l 0.67188,0.09375 c 1.957,0.25 3.2734,0.66406 3.9531,1.2344 0.67578,0.57422 1.0156,1.4648 1.0156,2.6719 0,1.2812 -0.46875,2.2461 -1.4062,2.8906 -0.9375,0.63672 -2.3438,0.95312 -4.2188,0.95312 -0.78125,0 -1.5938,-0.0625 -2.4375,-0.1875 -0.8437,-0.125 -1.7148,-0.3125 -2.6094,-0.5625 v -2.9062 c 0.75781,0.375 1.5391,0.65625 2.3438,0.84375 0.80078,0.17969 1.6133,0.26562 2.4375,0.26562 0.75,0 1.3125,-0.10156 1.6875,-0.3125 0.38281,-0.20703 0.57812,-0.50781 0.57812,-0.90625 0,-0.34375 -0.13281,-0.59766 -0.39062,-0.76562 C 7.70756,-4.38304 7.18803,-4.51586 6.40678,-4.6096 L 5.7349,-4.70335 C 4.0357,-4.91038 2.8443,-5.30101 2.1568,-5.87525 1.4693,-6.45728 1.1256,-7.33615 1.1256,-8.51585 c 0,-1.2695 0.42969,-2.207 1.2969,-2.8125 0.875,-0.61328 2.2109,-0.92188 4.0156,-0.92188 0.69531,0 1.4297,0.05469 2.2031,0.15625 0.78125,0.10547 1.6289,0.27344 2.5469,0.5 z"
|
||||
id="path860" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="e"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 7.5312,-9.5156 c -0.84375,0 -1.4922,0.30859 -1.9375,0.92188 -0.44922,0.60547 -0.67188,1.4805 -0.67188,2.625 0,1.1484 0.22266,2.0273 0.67188,2.6406 0.44531,0.60547 1.0938,0.90625 1.9375,0.90625 0.83203,0 1.4688,-0.30078 1.9062,-0.90625 0.44531,-0.61328 0.67188,-1.4922 0.67188,-2.6406 0,-1.1445 -0.22656,-2.0195 -0.67188,-2.625 C 8.9999,-9.207 8.3632,-9.5156 7.5312,-9.5156 Z m 0,-2.7344 c 2.0508,0 3.6562,0.55859 4.8125,1.6719 1.1641,1.1055 1.75,2.6406 1.75,4.6094 0,1.9688 -0.58594,3.5117 -1.75,4.625 -1.1562,1.1055 -2.7617,1.6562 -4.8125,1.6562 -2.0625,0 -3.6797,-0.55078 -4.8438,-1.6562 -1.168,-1.1133 -1.75,-2.6562 -1.75,-4.625 0,-1.9688 0.58203,-3.5039 1.75,-4.6094 1.1641,-1.1133 2.7812,-1.6719 4.8438,-1.6719 z"
|
||||
id="path863" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="r"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 12.922,-9.9688 c 0.48828,-0.75 1.0625,-1.3164 1.7188,-1.7031 0.66406,-0.38281 1.3984,-0.57812 2.2031,-0.57812 1.375,0 2.4219,0.42969 3.1406,1.2812 0.71875,0.84375 1.0781,2.0742 1.0781,3.6875 v 7.2812 h -3.8438 v -6.2344 c 0.0078,-0.09375 0.01563,-0.1875 0.01563,-0.28125 v -0.4375 c 0,-0.84375 -0.125,-1.457 -0.375,-1.8438 -0.25,-0.38281 -0.65234,-0.57812 -1.2031,-0.57812 -0.73047,0 -1.293,0.30469 -1.6875,0.90625 -0.38672,0.59375 -0.58984,1.4609 -0.60938,2.5938 v 5.875 h -3.8438 v -6.2344 c 0,-1.3203 -0.11719,-2.1758 -0.34375,-2.5625 -0.23047,-0.38281 -0.63672,-0.57812 -1.2188,-0.57812 -0.73047,0 -1.2969,0.30469 -1.7031,0.90625 -0.39844,0.60547 -0.59375,1.4648 -0.59375,2.5781 v 5.8906 h -3.8438 v -11.969 h 3.8438 v 1.75 c 0.46875,-0.66406 1.0039,-1.1719 1.6094,-1.5156 0.61328,-0.34375 1.2891,-0.51562 2.0312,-0.51562 0.82031,0 1.5508,0.19922 2.1875,0.59375 0.63281,0.39844 1.1133,0.96094 1.4375,1.6875 z"
|
||||
id="path866" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="q"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="M 13.859,-7.2812 V 0 h -3.8438 v -5.5469 c 0,-1.0508 -0.027344,-1.7695 -0.078125,-2.1562 -0.042969,-0.39453 -0.12109,-0.6875 -0.23438,-0.875 -0.14844,-0.25 -0.35156,-0.44141 -0.60938,-0.57812 -0.25,-0.14453 -0.54297,-0.21875 -0.875,-0.21875 -0.79297,0 -1.418,0.3125 -1.875,0.9375 -0.46094,0.61719 -0.6875,1.4648 -0.6875,2.5469 V 3e-5 h -3.8125 v -16.625 h 3.8125 v 6.4062 c 0.58203,-0.69531 1.1953,-1.207 1.8438,-1.5312 0.64453,-0.33203 1.3594,-0.5 2.1406,-0.5 1.3828,0 2.4297,0.42969 3.1406,1.2812 0.71875,0.84375 1.0781,2.0742 1.0781,3.6875 z"
|
||||
id="path869" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="p"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 2.0156,-15.953 h 4.5781 l 5.8125,10.938 v -10.938 h 3.8906 V 0 H 11.703 L 5.9061,-10.938 V 0 H 2.0155 Z"
|
||||
id="path872" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="o"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 1.7031,-4.6562 v -7.3125 h 3.8438 v 1.2031 c 0,0.64844 -0.00781,1.4609 -0.015625,2.4375 v 1.9688 c 0,0.96094 0.023438,1.6523 0.078125,2.0781 0.050781,0.41797 0.13281,0.72656 0.25,0.92188 0.15625,0.25 0.35938,0.44531 0.60938,0.57812 0.25781,0.13672 0.55078,0.20312 0.875,0.20312 0.80078,0 1.4258,-0.30469 1.875,-0.92188 0.45703,-0.61328 0.6875,-1.4688 0.6875,-2.5625 v -5.9062 h 3.8281 v 11.969 h -3.8281 v -1.7344 c -0.57422,0.69922 -1.1836,1.2148 -1.8281,1.5469 -0.64844,0.33203 -1.3555,0.5 -2.125,0.5 -1.3867,0 -2.4453,-0.42188 -3.1719,-1.2656 -0.71875,-0.85156 -1.0781,-2.0859 -1.0781,-3.7031 z"
|
||||
id="path875" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="n"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 2.0156,-15.953 h 6.8125 c 2.0312,0 3.5859,0.45312 4.6719,1.3594 1.0938,0.89844 1.6406,2.1797 1.6406,3.8438 0,1.6797 -0.54688,2.9688 -1.6406,3.875 -1.0859,0.89844 -2.6406,1.3438 -4.6719,1.3438 H 6.125 V 2e-4 H 2.0156 Z m 4.1094,2.9844 v 4.4531 h 2.2656 c 0.80078,0 1.4141,-0.19141 1.8438,-0.57812 0.4375,-0.38281 0.65625,-0.9375 0.65625,-1.6562 0,-0.70703 -0.21875,-1.2539 -0.65625,-1.6406 -0.42969,-0.38281 -1.043,-0.57812 -1.8438,-0.57812 z"
|
||||
id="path878" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="m"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 1.8438,-11.969 h 3.8125 v 11.75 c 0,1.6016 -0.38672,2.8281 -1.1562,3.6719 C 3.73838,4.29665 2.629,4.7185 1.172,4.7185 h -1.8906 v -2.5 h 0.65625 c 0.72656,0 1.2266,-0.16797 1.5,-0.5 C 1.70718,1.39428 1.8439,0.74975 1.8439,-0.219 Z m 0,-4.6562 h 3.8125 v 3.125 H 1.8438 Z"
|
||||
id="path881" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="l"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 11.5,-11.594 v 3.125 C 10.97656,-8.82056 10.457,-9.08228 9.9375,-9.25025 9.41406,-9.42603 8.875,-9.51587 8.3125,-9.51587 c -1.0742,0 -1.9062,0.3125 -2.5,0.9375 -0.5938,0.625 -0.89062,1.4961 -0.89062,2.6094 0,1.1172 0.29688,1.9844 0.89062,2.6094 0.59374,0.625 1.4258,0.9375 2.5,0.9375 0.59375,0 1.1562,-0.085937 1.6875,-0.26562 0.53906,-0.17578 1.0391,-0.44141 1.5,-0.79688 v 3.125 c -0.59375,0.23047 -1.1992,0.39453 -1.8125,0.5 -0.61719,0.11328 -1.2344,0.17188 -1.8594,0.17188 -2.1562,0 -3.8438,-0.55078 -5.0625,-1.6562 -1.2188,-1.1133 -1.8281,-2.6562 -1.8281,-4.625 0,-1.9688 0.60938,-3.5039 1.8281,-4.6094 1.2188,-1.1133 2.9062,-1.6719 5.0625,-1.6719 0.625,0 1.2383,0.05859 1.8438,0.17188 0.61328,0.10547 1.2227,0.26562 1.8281,0.48438 z"
|
||||
id="path884" />
|
||||
</symbol>
|
||||
</defs>
|
||||
<g
|
||||
inkscape:label="Layer 1"
|
||||
inkscape:groupmode="layer"
|
||||
id="layer1">
|
||||
<path
|
||||
d="m 8.8845302,5.3494472 c 0,0.4477953 -0.1778441,0.8772048 -0.4944813,1.1938387 -0.3166348,0.316634 -0.7460153,0.4944822 -1.1938396,0.4944822 -0.4477109,0 -0.8772047,-0.1778449 -1.1938395,-0.4944822 C 5.6858484,6.226652 5.5078885,5.7972707 5.5078885,5.3494472 c 0,-0.4477116 0.1779542,-0.8772055 0.4944813,-1.1938394 0.3166348,-0.316634 0.7461286,-0.4944813 1.1938395,-0.4944813 0.4477953,0 0.8772048,0.177954 1.1938396,0.4944813 0.3166339,0.3166339 0.4944813,0.7461278 0.4944813,1.1938394 z M 11.9797,2.6818787 v 4.9535711 c 0,0.2025579 -0.08042,0.396732 -0.223629,0.5399248 -0.143202,0.1431936 -0.337478,0.22363 -0.539925,0.22363 H 1.7693668 c -0.2024472,0 -0.396732,-0.08043 -0.539925,-0.22363 C 1.0862489,8.0321727 1.0058124,7.8380094 1.0058124,7.6354498 V 2.6818787 c 0,-0.2024471 0.080428,-0.396732 0.2236294,-0.5399247 C 1.3726433,1.9987612 1.5669455,1.921557 1.7693668,1.9183247 H 4.422559 L 5.0067408,1.1926164 v 1.117e-4 C 5.073603,1.0757847 5.1700203,0.97869889 5.2865236,0.91106734 5.4029169,0.84355161 5.5351968,0.80802499 5.6697839,0.80802499 h 3.33439 c 0.1347055,0 0.266875,0.0355242 0.38326,0.10315238 0.1165025,0.0675157 0.2130381,0.16471403 0.279782,0.28155073 L 10.251399,1.918324 h 0.9649 c 0.202447,0 0.396732,0.08043 0.539923,0.2236291 0.143193,0.1432011 0.22363,0.3374778 0.22363,0.5399248 z M 3.0026051,3.1406051 c 0,-0.1492709 -0.059243,-0.2923735 -0.1648241,-0.3979465 C 2.7321996,2.6371873 2.5891078,2.5778337 2.4398344,2.5778337 2.2905607,2.5778337 2.147461,2.6371917 2.041888,2.7426586 1.9363066,2.84824 1.8770635,2.9913309 1.8770635,3.1406051 c 0,0.1492742 0.059246,0.2923726 0.1648245,0.3979465 0.1055814,0.1055813 0.2486727,0.1648241 0.3979464,0.1648241 0.1492734,0 0.2923736,-0.059243 0.3979466,-0.1648241 C 2.9433623,3.4330794 3.0026051,3.2898793 3.0026051,3.1406051 Z m 2.9205146,-0.00883 C 5.5155708,3.337535 5.1846171,3.6685109 4.9787244,4.0761732 3.8026494,6.4140588 6.1313852,8.742793 8.4692981,7.5667478 8.8768479,7.3608798 9.2078012,7.0299014 9.413694,6.6223516 10.589543,4.2844667 8.260921,1.9557319 5.9231197,3.1317788 Z"
|
||||
id="path889"
|
||||
style="stroke-width:0.0282432"
|
||||
sodipodi:nodetypes="ssscscscscsssssssssccccsscccssccscscscscsccccc" />
|
||||
<g
|
||||
aria-label="4K"
|
||||
transform="scale(1.1808986,0.84681275)"
|
||||
id="text2715"
|
||||
style="font-size:5.51344px;line-height:1.25;stroke-width:0.137836">
|
||||
<path
|
||||
d="m 3.2861357,11.349594 -1.1360702,1.682568 h 1.1360702 z m -0.172295,-0.853399 h 1.1522228 v 2.535967 h 0.5734194 v 0.751099 H 4.2660635 v 0.732253 H 3.2861357 V 13.783261 H 1.5039593 v -0.888397 z"
|
||||
style="font-weight:bold;-inkscape-font-specification:'sans-serif Bold'"
|
||||
id="path7376" />
|
||||
<path
|
||||
d="m 5.5986578,10.496195 h 1.0364621 v 1.4672 l 1.4941208,-1.4672 h 1.2033729 l -1.9356267,1.903321 2.1348428,2.115998 H 8.2342329 l -1.599113,-1.58296 v 1.58296 H 5.5986578 Z"
|
||||
style="font-weight:bold;-inkscape-font-specification:'sans-serif Bold'"
|
||||
id="path7378" />
|
||||
</g>
|
||||
</g>
|
||||
<metadata
|
||||
id="metadata7498">
|
||||
<rdf:RDF>
|
||||
<cc:Work
|
||||
rdf:about="">
|
||||
<dc:title>snap-pro-a</dc:title>
|
||||
</cc:Work>
|
||||
</rdf:RDF>
|
||||
</metadata>
|
||||
</svg>
|
After Width: | Height: | Size: 18 KiB |
226
applications/tabletCam/appIcons/snap-pro-i.svg
Normal file
226
applications/tabletCam/appIcons/snap-pro-i.svg
Normal file
|
@ -0,0 +1,226 @@
|
|||
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||
<!-- Created with Inkscape (http://www.inkscape.org/) -->
|
||||
|
||||
<svg
|
||||
width="50"
|
||||
height="50"
|
||||
viewBox="0 0 13.229167 13.229167"
|
||||
version="1.1"
|
||||
id="svg5"
|
||||
inkscape:version="1.1.1 (3bf5ae0d25, 2021-09-20)"
|
||||
sodipodi:docname="snap-pro-i.svg"
|
||||
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
xmlns:svg="http://www.w3.org/2000/svg"
|
||||
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||
xmlns:cc="http://creativecommons.org/ns#"
|
||||
xmlns:dc="http://purl.org/dc/elements/1.1/">
|
||||
<title
|
||||
id="title7500">snap-pro-i</title>
|
||||
<sodipodi:namedview
|
||||
id="namedview7"
|
||||
pagecolor="#ffffff"
|
||||
bordercolor="#666666"
|
||||
borderopacity="1.0"
|
||||
inkscape:pageshadow="2"
|
||||
inkscape:pageopacity="0.0"
|
||||
inkscape:pagecheckerboard="0"
|
||||
inkscape:document-units="mm"
|
||||
showgrid="false"
|
||||
showguides="false"
|
||||
units="px"
|
||||
width="50px"
|
||||
inkscape:zoom="6.0007856"
|
||||
inkscape:cx="65.408102"
|
||||
inkscape:cy="39.828118"
|
||||
inkscape:window-width="1628"
|
||||
inkscape:window-height="932"
|
||||
inkscape:window-x="1690"
|
||||
inkscape:window-y="22"
|
||||
inkscape:window-maximized="0"
|
||||
inkscape:current-layer="layer1" />
|
||||
<defs
|
||||
id="defs2">
|
||||
<symbol
|
||||
id="u"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 14.656,-0.875 c -0.76172,0.39844 -1.5547,0.69531 -2.375,0.89062 -0.8125,0.19531 -1.6641,0.29688 -2.5469,0.29688 -2.6562,0 -4.7617,-0.73828 -6.3125,-2.2188 -1.5547,-1.4883 -2.3281,-3.5039 -2.3281,-6.0469 0,-2.5508 0.77344,-4.5664 2.3281,-6.0469 1.5508,-1.4883 3.6562,-2.2344 6.3125,-2.2344 0.88281,0 1.7344,0.10156 2.5469,0.29688 0.82031,0.19922 1.6133,0.49609 2.375,0.89062 v 3.2969 c -0.76172,-0.51953 -1.5117,-0.89844 -2.25,-1.1406 -0.74219,-0.23828 -1.5234,-0.35938 -2.3438,-0.35938 -1.4688,0 -2.625,0.46875 -3.4688,1.4062 -0.83594,0.9375 -1.25,2.2344 -1.25,3.8906 0,1.6484 0.41406,2.9375 1.25,3.875 0.84375,0.9375 2,1.4062 3.4688,1.4062 0.82031,0 1.6016,-0.11719 2.3438,-0.35938 0.73828,-0.23828 1.4883,-0.61719 2.25,-1.1406 z"
|
||||
id="path824" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="b"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 10.719,-8.7031 c -0.33594,-0.15625 -0.66797,-0.26953 -1,-0.34375 -0.32422,-0.082031 -0.65625,-0.125 -1,-0.125 -0.98047,0 -1.7344,0.32031 -2.2656,0.95312 -0.53125,0.625 -0.79688,1.5273 -0.79688,2.7031 V -3e-5 h -3.8125 v -11.969 h 3.8125 v 1.9688 c 0.48828,-0.78125 1.0508,-1.3477 1.6875,-1.7031 0.64453,-0.36328 1.4102,-0.54688 2.2969,-0.54688 0.13281,0 0.27344,0.0078 0.42188,0.01563 0.14453,0.01172 0.36328,0.03125 0.65625,0.0625 z"
|
||||
id="path827" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="a"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 13.781,-6.0156 v 1.0938 H 4.8435 c 0.09375,0.89844 0.41406,1.5703 0.96875,2.0156 0.55078,0.44922 1.3281,0.67188 2.3281,0.67188 0.80078,0 1.625,-0.11719 2.4688,-0.35938 0.84375,-0.23828 1.7109,-0.59766 2.6094,-1.0781 v 2.9531 c -0.90625,0.33594 -1.8125,0.58984 -2.7188,0.76562 -0.9063,0.17578 -1.8125,0.26562 -2.7188,0.26562 -2.1562,0 -3.8398,-0.54688 -5.0469,-1.6406 -1.1992,-1.1016 -1.7969,-2.6484 -1.7969,-4.6406 0,-1.9453 0.58594,-3.4766 1.7656,-4.5938 1.1758,-1.125 2.8008,-1.6875 4.875,-1.6875 1.875,0 3.375,0.57031 4.5,1.7031 1.1328,1.125 1.7031,2.6367 1.7031,4.5312 z M 9.8435,-7.2812 c 0,-0.72656 -0.21484,-1.3125 -0.64062,-1.75 -0.41797,-0.44531 -0.96875,-0.67188 -1.6562,-0.67188 -0.74219,0 -1.3438,0.21094 -1.8125,0.625 -0.46094,0.41797 -0.74609,1.0156 -0.85938,1.7969 z"
|
||||
id="path830" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="d"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 7.2031,-5.3906 c -0.80469,0 -1.4062,0.13672 -1.8125,0.40625 -0.39844,0.27344 -0.59375,0.67188 -0.59375,1.2031 0,0.48047 0.16016,0.85938 0.48438,1.1406 0.32031,0.27344 0.77344,0.40625 1.3594,0.40625 0.71875,0 1.3203,-0.25391 1.8125,-0.76562 0.48828,-0.51953 0.73438,-1.1719 0.73438,-1.9531 v -0.4375 z m 5.8438,-1.4375 V 0 H 9.1875 v -1.7656 c -0.51172,0.71875 -1.0898,1.2461 -1.7344,1.5781 -0.63672,0.33203 -1.418,0.5 -2.3438,0.5 -1.2422,0 -2.2461,-0.35938 -3.0156,-1.0781 -0.77344,-0.72656 -1.1562,-1.6719 -1.1562,-2.8281 0,-1.3945 0.47656,-2.4219 1.4375,-3.0781 0.96875,-0.65625 2.4883,-0.98438 4.5625,-0.98438 h 2.25 v -0.29688 c 0,-0.60156 -0.24219,-1.0469 -0.71875,-1.3281 -0.48047,-0.28125 -1.2266,-0.42188 -2.2344,-0.42188 -0.8125,0 -1.5742,0.085937 -2.2812,0.25 -0.71094,0.15625 -1.3672,0.40234 -1.9688,0.73438 v -2.9219 c 0.82031,-0.19531 1.6445,-0.34766 2.4688,-0.45312 0.82031,-0.10156 1.6484,-0.15625 2.4844,-0.15625 2.1562,0 3.7109,0.42969 4.6719,1.2812 0.95703,0.84375 1.4375,2.2266 1.4375,4.1406 z"
|
||||
id="path833" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="c"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 6.0156,-15.359 v 3.3906 H 9.9531 V -9.234 H 6.0156 v 5.0781 c 0,0.55469 0.10938,0.92969 0.32812,1.125 0.21875,0.19922 0.65625,0.29688 1.3125,0.29688 h 1.9688 v 2.7344 h -3.2812 c -1.5117,0 -2.5859,-0.3125 -3.2188,-0.9375 -0.625,-0.63281 -0.9375,-1.707 -0.9375,-3.2188 v -5.0781 h -1.9062 v -2.7344 h 1.9062 v -3.3906 z"
|
||||
id="path836" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="g"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 9.9688,-10.219 v -6.4062 h 3.8594 V -2e-4 H 9.9688 V -1.7346 C 9.44536,-1.02366 8.8672,-0.5041 8.2344,-0.1721 7.59768,0.14821 6.8633,0.31228 6.0313,0.31228 c -1.4688,0 -2.6797,-0.58203 -3.625,-1.75 -0.94922,-1.1758 -1.4219,-2.6875 -1.4219,-4.5312 0,-1.8437 0.47266,-3.3477 1.4219,-4.5156 0.94531,-1.1758 2.1562,-1.7656 3.625,-1.7656 0.83203,0 1.5664,0.16797 2.2031,0.5 0.63281,0.32422 1.2109,0.83594 1.7344,1.5312 z m -2.5156,7.75 c 0.82031,0 1.4453,-0.29688 1.875,-0.89062 0.42578,-0.60156 0.64062,-1.4727 0.64062,-2.6094 0,-1.1445 -0.21484,-2.0156 -0.64062,-2.6094 -0.42969,-0.59375 -1.0547,-0.89062 -1.875,-0.89062 -0.8125,0 -1.4336,0.29688 -1.8594,0.89062 -0.42969,0.59375 -0.64062,1.4648 -0.64062,2.6094 0,1.1367 0.21094,2.0078 0.64062,2.6094 0.42578,0.59375 1.0469,0.89062 1.8594,0.89062 z"
|
||||
id="path839" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="k"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 8.2031,-2.4688 c 0.82031,0 1.4453,-0.29688 1.875,-0.89062 0.42578,-0.60156 0.64062,-1.4727 0.64062,-2.6094 0,-1.1445 -0.21484,-2.0156 -0.64062,-2.6094 -0.42969,-0.59375 -1.0547,-0.89062 -1.875,-0.89062 -0.82422,0 -1.4531,0.30469 -1.8906,0.90625 -0.4375,0.59375 -0.65625,1.4609 -0.65625,2.5938 0,1.1367 0.21875,2.0078 0.65625,2.6094 0.4375,0.59375 1.0664,0.89062 1.8906,0.89062 z m -2.5469,-7.75 c 0.53125,-0.69531 1.1133,-1.207 1.75,-1.5312 0.64453,-0.33203 1.3828,-0.5 2.2188,-0.5 1.4688,0 2.6758,0.58984 3.625,1.7656 0.94531,1.168 1.4219,2.6719 1.4219,4.5156 0,1.8437 -0.47656,3.3555 -1.4219,4.5312 -0.94922,1.168 -2.1562,1.75 -3.625,1.75 -0.83594,0 -1.5742,-0.16797 -2.2188,-0.5 -0.63672,-0.33203 -1.2188,-0.84766 -1.75,-1.5469 V -1e-4 H 1.8437 v -16.625 h 3.8125 z"
|
||||
id="path842" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="j"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 0.26562,-11.969 h 3.8281 l 3.2188,8.125 2.7344,-8.125 h 3.8125 L 8.82822,1.125 c -0.5,1.332 -1.0898,2.2656 -1.7656,2.7969 -0.66797,0.53125 -1.5547,0.79688 -2.6562,0.79688 h -2.2188 v -2.5 h 1.2031 c 0.64453,0 1.1133,-0.10547 1.4062,-0.3125 C 5.0977,1.69534 5.32817,1.32816 5.48442,0.79688 L 5.5938,0.45313 Z"
|
||||
id="path845" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="i"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="M 2.0156,-15.953 H 6.125 V 0 H 2.0156 Z"
|
||||
id="path848" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="f"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="M 13.859,-7.2812 V 0 h -3.8438 v -5.5781 c 0,-1.0312 -0.027344,-1.7383 -0.078125,-2.125 -0.042969,-0.39453 -0.12109,-0.6875 -0.23438,-0.875 -0.14844,-0.25 -0.35156,-0.44141 -0.60938,-0.57812 -0.25,-0.14453 -0.54297,-0.21875 -0.875,-0.21875 -0.79297,0 -1.418,0.3125 -1.875,0.9375 -0.46094,0.61719 -0.6875,1.4648 -0.6875,2.5469 V 3e-5 h -3.8125 v -11.969 h 3.8125 v 1.75 c 0.58203,-0.69531 1.1953,-1.207 1.8438,-1.5312 0.64453,-0.33203 1.3594,-0.5 2.1406,-0.5 1.3828,0 2.4297,0.42969 3.1406,1.2812 0.71875,0.84375 1.0781,2.0742 1.0781,3.6875 z"
|
||||
id="path851" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="t"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="M 1.8438,-11.969 H 5.6563 V 0 H 1.8438 Z m 0,-4.6562 h 3.8125 v 3.125 H 1.8438 Z"
|
||||
id="path854" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="h"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 9.7031,-16.625 v 2.5156 H 7.5937 c -0.54297,0 -0.92188,0.10156 -1.1406,0.29688 -0.21094,0.19922 -0.3125,0.53906 -0.3125,1.0156 v 0.82812 h 3.2656 v 2.7344 H 6.1406 V 0 H 2.3125 V -9.2344 H 0.4219 v -2.7344 h 1.8906 v -0.82812 c 0,-1.3008 0.36328,-2.2656 1.0938,-2.8906 0.72656,-0.625 1.8516,-0.9375 3.375,-0.9375 z"
|
||||
id="path857" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="s"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 11.188,-11.594 v 2.9062 c -0.82422,-0.34375 -1.6172,-0.59766 -2.375,-0.76562 -0.76172,-0.16406 -1.4805,-0.25 -2.1562,-0.25 -0.73047,0 -1.2734,0.089844 -1.625,0.26562 -0.35547,0.17969 -0.53125,0.46094 -0.53125,0.84375 0,0.30469 0.13281,0.53906 0.40625,0.70312 0.26953,0.16797 0.75,0.28906 1.4375,0.35938 l 0.67188,0.09375 c 1.957,0.25 3.2734,0.66406 3.9531,1.2344 0.67578,0.57422 1.0156,1.4648 1.0156,2.6719 0,1.2812 -0.46875,2.2461 -1.4062,2.8906 -0.9375,0.63672 -2.3438,0.95312 -4.2188,0.95312 -0.78125,0 -1.5938,-0.0625 -2.4375,-0.1875 -0.8437,-0.125 -1.7148,-0.3125 -2.6094,-0.5625 v -2.9062 c 0.75781,0.375 1.5391,0.65625 2.3438,0.84375 0.80078,0.17969 1.6133,0.26562 2.4375,0.26562 0.75,0 1.3125,-0.10156 1.6875,-0.3125 0.38281,-0.20703 0.57812,-0.50781 0.57812,-0.90625 0,-0.34375 -0.13281,-0.59766 -0.39062,-0.76562 C 7.70756,-4.38304 7.18803,-4.51586 6.40678,-4.6096 L 5.7349,-4.70335 C 4.0357,-4.91038 2.8443,-5.30101 2.1568,-5.87525 1.4693,-6.45728 1.1256,-7.33615 1.1256,-8.51585 c 0,-1.2695 0.42969,-2.207 1.2969,-2.8125 0.875,-0.61328 2.2109,-0.92188 4.0156,-0.92188 0.69531,0 1.4297,0.05469 2.2031,0.15625 0.78125,0.10547 1.6289,0.27344 2.5469,0.5 z"
|
||||
id="path860" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="e"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 7.5312,-9.5156 c -0.84375,0 -1.4922,0.30859 -1.9375,0.92188 -0.44922,0.60547 -0.67188,1.4805 -0.67188,2.625 0,1.1484 0.22266,2.0273 0.67188,2.6406 0.44531,0.60547 1.0938,0.90625 1.9375,0.90625 0.83203,0 1.4688,-0.30078 1.9062,-0.90625 0.44531,-0.61328 0.67188,-1.4922 0.67188,-2.6406 0,-1.1445 -0.22656,-2.0195 -0.67188,-2.625 C 8.9999,-9.207 8.3632,-9.5156 7.5312,-9.5156 Z m 0,-2.7344 c 2.0508,0 3.6562,0.55859 4.8125,1.6719 1.1641,1.1055 1.75,2.6406 1.75,4.6094 0,1.9688 -0.58594,3.5117 -1.75,4.625 -1.1562,1.1055 -2.7617,1.6562 -4.8125,1.6562 -2.0625,0 -3.6797,-0.55078 -4.8438,-1.6562 -1.168,-1.1133 -1.75,-2.6562 -1.75,-4.625 0,-1.9688 0.58203,-3.5039 1.75,-4.6094 1.1641,-1.1133 2.7812,-1.6719 4.8438,-1.6719 z"
|
||||
id="path863" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="r"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 12.922,-9.9688 c 0.48828,-0.75 1.0625,-1.3164 1.7188,-1.7031 0.66406,-0.38281 1.3984,-0.57812 2.2031,-0.57812 1.375,0 2.4219,0.42969 3.1406,1.2812 0.71875,0.84375 1.0781,2.0742 1.0781,3.6875 v 7.2812 h -3.8438 v -6.2344 c 0.0078,-0.09375 0.01563,-0.1875 0.01563,-0.28125 v -0.4375 c 0,-0.84375 -0.125,-1.457 -0.375,-1.8438 -0.25,-0.38281 -0.65234,-0.57812 -1.2031,-0.57812 -0.73047,0 -1.293,0.30469 -1.6875,0.90625 -0.38672,0.59375 -0.58984,1.4609 -0.60938,2.5938 v 5.875 h -3.8438 v -6.2344 c 0,-1.3203 -0.11719,-2.1758 -0.34375,-2.5625 -0.23047,-0.38281 -0.63672,-0.57812 -1.2188,-0.57812 -0.73047,0 -1.2969,0.30469 -1.7031,0.90625 -0.39844,0.60547 -0.59375,1.4648 -0.59375,2.5781 v 5.8906 h -3.8438 v -11.969 h 3.8438 v 1.75 c 0.46875,-0.66406 1.0039,-1.1719 1.6094,-1.5156 0.61328,-0.34375 1.2891,-0.51562 2.0312,-0.51562 0.82031,0 1.5508,0.19922 2.1875,0.59375 0.63281,0.39844 1.1133,0.96094 1.4375,1.6875 z"
|
||||
id="path866" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="q"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="M 13.859,-7.2812 V 0 h -3.8438 v -5.5469 c 0,-1.0508 -0.027344,-1.7695 -0.078125,-2.1562 -0.042969,-0.39453 -0.12109,-0.6875 -0.23438,-0.875 -0.14844,-0.25 -0.35156,-0.44141 -0.60938,-0.57812 -0.25,-0.14453 -0.54297,-0.21875 -0.875,-0.21875 -0.79297,0 -1.418,0.3125 -1.875,0.9375 -0.46094,0.61719 -0.6875,1.4648 -0.6875,2.5469 V 3e-5 h -3.8125 v -16.625 h 3.8125 v 6.4062 c 0.58203,-0.69531 1.1953,-1.207 1.8438,-1.5312 0.64453,-0.33203 1.3594,-0.5 2.1406,-0.5 1.3828,0 2.4297,0.42969 3.1406,1.2812 0.71875,0.84375 1.0781,2.0742 1.0781,3.6875 z"
|
||||
id="path869" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="p"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 2.0156,-15.953 h 4.5781 l 5.8125,10.938 v -10.938 h 3.8906 V 0 H 11.703 L 5.9061,-10.938 V 0 H 2.0155 Z"
|
||||
id="path872" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="o"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 1.7031,-4.6562 v -7.3125 h 3.8438 v 1.2031 c 0,0.64844 -0.00781,1.4609 -0.015625,2.4375 v 1.9688 c 0,0.96094 0.023438,1.6523 0.078125,2.0781 0.050781,0.41797 0.13281,0.72656 0.25,0.92188 0.15625,0.25 0.35938,0.44531 0.60938,0.57812 0.25781,0.13672 0.55078,0.20312 0.875,0.20312 0.80078,0 1.4258,-0.30469 1.875,-0.92188 0.45703,-0.61328 0.6875,-1.4688 0.6875,-2.5625 v -5.9062 h 3.8281 v 11.969 h -3.8281 v -1.7344 c -0.57422,0.69922 -1.1836,1.2148 -1.8281,1.5469 -0.64844,0.33203 -1.3555,0.5 -2.125,0.5 -1.3867,0 -2.4453,-0.42188 -3.1719,-1.2656 -0.71875,-0.85156 -1.0781,-2.0859 -1.0781,-3.7031 z"
|
||||
id="path875" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="n"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 2.0156,-15.953 h 6.8125 c 2.0312,0 3.5859,0.45312 4.6719,1.3594 1.0938,0.89844 1.6406,2.1797 1.6406,3.8438 0,1.6797 -0.54688,2.9688 -1.6406,3.875 -1.0859,0.89844 -2.6406,1.3438 -4.6719,1.3438 H 6.125 V 2e-4 H 2.0156 Z m 4.1094,2.9844 v 4.4531 h 2.2656 c 0.80078,0 1.4141,-0.19141 1.8438,-0.57812 0.4375,-0.38281 0.65625,-0.9375 0.65625,-1.6562 0,-0.70703 -0.21875,-1.2539 -0.65625,-1.6406 -0.42969,-0.38281 -1.043,-0.57812 -1.8438,-0.57812 z"
|
||||
id="path878" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="m"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 1.8438,-11.969 h 3.8125 v 11.75 c 0,1.6016 -0.38672,2.8281 -1.1562,3.6719 C 3.73838,4.29665 2.629,4.7185 1.172,4.7185 h -1.8906 v -2.5 h 0.65625 c 0.72656,0 1.2266,-0.16797 1.5,-0.5 C 1.70718,1.39428 1.8439,0.74975 1.8439,-0.219 Z m 0,-4.6562 h 3.8125 v 3.125 H 1.8438 Z"
|
||||
id="path881" />
|
||||
</symbol>
|
||||
<symbol
|
||||
id="l"
|
||||
overflow="visible">
|
||||
<path
|
||||
d="m 11.5,-11.594 v 3.125 C 10.97656,-8.82056 10.457,-9.08228 9.9375,-9.25025 9.41406,-9.42603 8.875,-9.51587 8.3125,-9.51587 c -1.0742,0 -1.9062,0.3125 -2.5,0.9375 -0.5938,0.625 -0.89062,1.4961 -0.89062,2.6094 0,1.1172 0.29688,1.9844 0.89062,2.6094 0.59374,0.625 1.4258,0.9375 2.5,0.9375 0.59375,0 1.1562,-0.085937 1.6875,-0.26562 0.53906,-0.17578 1.0391,-0.44141 1.5,-0.79688 v 3.125 c -0.59375,0.23047 -1.1992,0.39453 -1.8125,0.5 -0.61719,0.11328 -1.2344,0.17188 -1.8594,0.17188 -2.1562,0 -3.8438,-0.55078 -5.0625,-1.6562 -1.2188,-1.1133 -1.8281,-2.6562 -1.8281,-4.625 0,-1.9688 0.60938,-3.5039 1.8281,-4.6094 1.2188,-1.1133 2.9062,-1.6719 5.0625,-1.6719 0.625,0 1.2383,0.05859 1.8438,0.17188 0.61328,0.10547 1.2227,0.26562 1.8281,0.48438 z"
|
||||
id="path884" />
|
||||
</symbol>
|
||||
</defs>
|
||||
<g
|
||||
inkscape:label="Layer 1"
|
||||
inkscape:groupmode="layer"
|
||||
id="layer1">
|
||||
<path
|
||||
d="m 8.8845302,5.3494472 c 0,0.4477953 -0.1778441,0.8772048 -0.4944813,1.1938387 -0.3166348,0.316634 -0.7460153,0.4944822 -1.1938396,0.4944822 -0.4477109,0 -0.8772047,-0.1778449 -1.1938395,-0.4944822 C 5.6858484,6.226652 5.5078885,5.7972707 5.5078885,5.3494472 c 0,-0.4477116 0.1779542,-0.8772055 0.4944813,-1.1938394 0.3166348,-0.316634 0.7461286,-0.4944813 1.1938395,-0.4944813 0.4477953,0 0.8772048,0.177954 1.1938396,0.4944813 0.3166339,0.3166339 0.4944813,0.7461278 0.4944813,1.1938394 z M 11.9797,2.6818787 v 4.9535711 c 0,0.2025579 -0.08042,0.396732 -0.223629,0.5399248 -0.143202,0.1431936 -0.337478,0.22363 -0.539925,0.22363 H 1.7693668 c -0.2024472,0 -0.396732,-0.08043 -0.539925,-0.22363 C 1.0862489,8.0321727 1.0058124,7.8380094 1.0058124,7.6354498 V 2.6818787 c 0,-0.2024471 0.080428,-0.396732 0.2236294,-0.5399247 C 1.3726433,1.9987612 1.5669455,1.921557 1.7693668,1.9183247 H 4.422559 L 5.0067408,1.1926164 v 1.117e-4 C 5.073603,1.0757847 5.1700203,0.97869889 5.2865236,0.91106734 5.4029169,0.84355161 5.5351968,0.80802499 5.6697839,0.80802499 h 3.33439 c 0.1347055,0 0.266875,0.0355242 0.38326,0.10315238 0.1165025,0.0675157 0.2130381,0.16471403 0.279782,0.28155073 L 10.251399,1.918324 h 0.9649 c 0.202447,0 0.396732,0.08043 0.539923,0.2236291 0.143193,0.1432011 0.22363,0.3374778 0.22363,0.5399248 z M 3.0026051,3.1406051 c 0,-0.1492709 -0.059243,-0.2923735 -0.1648241,-0.3979465 C 2.7321996,2.6371873 2.5891078,2.5778337 2.4398344,2.5778337 2.2905607,2.5778337 2.147461,2.6371917 2.041888,2.7426586 1.9363066,2.84824 1.8770635,2.9913309 1.8770635,3.1406051 c 0,0.1492742 0.059246,0.2923726 0.1648245,0.3979465 0.1055814,0.1055813 0.2486727,0.1648241 0.3979464,0.1648241 0.1492734,0 0.2923736,-0.059243 0.3979466,-0.1648241 C 2.9433623,3.4330794 3.0026051,3.2898793 3.0026051,3.1406051 Z m 2.9205146,-0.00883 C 5.5155708,3.337535 5.1846171,3.6685109 4.9787244,4.0761732 3.8026494,6.4140588 6.1313852,8.742793 8.4692981,7.5667478 8.8768479,7.3608798 9.2078012,7.0299014 9.413694,6.6223516 10.589543,4.2844667 8.260921,1.9557319 5.9231197,3.1317788 Z"
|
||||
id="path889"
|
||||
style="stroke-width:0.0282432;fill:#ffffff"
|
||||
sodipodi:nodetypes="ssscscscscsssssssssccccsscccssccscscscscsccccc" />
|
||||
<g
|
||||
aria-label="4K"
|
||||
transform="scale(1.1808986,0.84681275)"
|
||||
id="text2715"
|
||||
style="font-size:5.51344px;line-height:1.25;stroke-width:0.137836;fill:#ffffff">
|
||||
<path
|
||||
d="m 3.2861357,11.349594 -1.1360702,1.682568 h 1.1360702 z m -0.172295,-0.853399 h 1.1522228 v 2.535967 h 0.5734194 v 0.751099 H 4.2660635 v 0.732253 H 3.2861357 V 13.783261 H 1.5039593 v -0.888397 z"
|
||||
style="font-weight:bold;-inkscape-font-specification:'sans-serif Bold';fill:#ffffff"
|
||||
id="path7376" />
|
||||
<path
|
||||
d="m 5.5986578,10.496195 h 1.0364621 v 1.4672 l 1.4941208,-1.4672 h 1.2033729 l -1.9356267,1.903321 2.1348428,2.115998 H 8.2342329 l -1.599113,-1.58296 v 1.58296 H 5.5986578 Z"
|
||||
style="font-weight:bold;-inkscape-font-specification:'sans-serif Bold';fill:#ffffff"
|
||||
id="path7378" />
|
||||
</g>
|
||||
</g>
|
||||
<metadata
|
||||
id="metadata7498">
|
||||
<rdf:RDF>
|
||||
<cc:Work
|
||||
rdf:about="">
|
||||
<dc:title>snap-pro-i</dc:title>
|
||||
</cc:Work>
|
||||
</rdf:RDF>
|
||||
</metadata>
|
||||
</svg>
|
After Width: | Height: | Size: 18 KiB |
BIN
applications/tabletCam/models/camera.fbx
Normal file
BIN
applications/tabletCam/models/camera.fbx
Normal file
Binary file not shown.
388
applications/tabletCam/modules/appUi.js
Normal file
388
applications/tabletCam/modules/appUi.js
Normal file
|
@ -0,0 +1,388 @@
|
|||
"use strict";
|
||||
/* global Tablet, Script */
|
||||
//
|
||||
// libraries/appUi.js
|
||||
//
|
||||
// Created by Howard Stearns on 3/20/18.
|
||||
// Modified by Zach Fox on 2019-04-13
|
||||
// Copyright 2018 High Fidelity, Inc.
|
||||
//
|
||||
// Distributed under the Apache License, Version 2.0.
|
||||
// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html
|
||||
//
|
||||
|
||||
function AppUi(properties) {
|
||||
var request = Script.require('request').request;
|
||||
/* Example development order:
|
||||
1. var AppUi = Script.require('appUi');
|
||||
2. Put appname-i.svg, appname-a.svg in graphicsDirectory (where non-default graphicsDirectory can be added in #3).
|
||||
3. ui = new AppUi({buttonName: "APPNAME", home: "qml-or-html-path"});
|
||||
(And if converting an existing app,
|
||||
define var tablet = ui.tablet, button = ui.button; as needed.
|
||||
remove button.clicked.[dis]connect and tablet.remove(button).)
|
||||
4. Define onOpened and onClosed behavior in #3, if any.
|
||||
(And if converting an existing app, remove screenChanged.[dis]connect.)
|
||||
5. Define onMessage and sendMessage in #3, if any. onMessage is wired/unwired on open/close. If you
|
||||
want a handler to be "always on", connect it yourself at script startup.
|
||||
(And if converting an existing app, remove code that [un]wires that message handling such as
|
||||
fromQml/sendToQml or webEventReceived/emitScriptEvent.)
|
||||
6. (If converting an existing app, cleanup stuff that is no longer necessary, like references to button, tablet,
|
||||
and use isOpen, open(), and close() as needed.)
|
||||
7. lint!
|
||||
*/
|
||||
var that = this;
|
||||
function defaultButton(name, suffix) {
|
||||
var base = that[name] || (that.buttonPrefix + suffix);
|
||||
that[name] = (base.indexOf('/') >= 0) ? base : (that.graphicsDirectory + base); // poor man's merge
|
||||
}
|
||||
|
||||
// Defaults:
|
||||
that.tabletName = "com.highfidelity.interface.tablet.system";
|
||||
that.inject = "";
|
||||
that.graphicsDirectory = "icons/tablet-icons/"; // Where to look for button svgs. See below.
|
||||
that.additionalAppScreens = [];
|
||||
that.checkIsOpen = function checkIsOpen(type, tabletUrl) { // Are we active? Value used to set isOpen.
|
||||
// Actual url may have prefix or suffix.
|
||||
return that.currentVisibleUrl &&
|
||||
((that.home.indexOf(that.currentVisibleUrl) > -1) ||
|
||||
(that.additionalAppScreens.indexOf(that.currentVisibleUrl) > -1));
|
||||
};
|
||||
that.setCurrentVisibleScreenMetadata = function setCurrentVisibleScreenMetadata(type, url) {
|
||||
that.currentVisibleScreenType = type;
|
||||
that.currentVisibleUrl = url;
|
||||
};
|
||||
that.open = function open(optionalUrl, optionalInject) { // How to open the app.
|
||||
var url = optionalUrl || that.home;
|
||||
var inject = optionalInject || that.inject;
|
||||
|
||||
if (that.isQMLUrl(url)) {
|
||||
that.tablet.loadQMLSource(url);
|
||||
} else {
|
||||
that.tablet.gotoWebScreen(url, inject);
|
||||
}
|
||||
};
|
||||
// Opens some app on top of the current app (on desktop, opens new window)
|
||||
that.openNewAppOnTop = function openNewAppOnTop(url, optionalInject) {
|
||||
var inject = optionalInject || "";
|
||||
if (that.isQMLUrl(url)) {
|
||||
that.tablet.loadQMLOnTop(url);
|
||||
} else {
|
||||
that.tablet.loadWebScreenOnTop(url, inject);
|
||||
}
|
||||
};
|
||||
that.close = function close() { // How to close the app.
|
||||
that.currentVisibleUrl = "";
|
||||
// for toolbar-mode: go back to home screen, this will close the window.
|
||||
that.tablet.gotoHomeScreen();
|
||||
};
|
||||
that.buttonActive = function buttonActive(isActive) { // How to make the button active (white).
|
||||
that.button.editProperties({isActive: isActive});
|
||||
};
|
||||
that.isQMLUrl = function isQMLUrl(url) {
|
||||
var type = /.qml$/.test(url) ? 'QML' : 'Web';
|
||||
return type === 'QML';
|
||||
};
|
||||
that.isCurrentlyOnQMLScreen = function isCurrentlyOnQMLScreen() {
|
||||
return that.currentVisibleScreenType === 'QML';
|
||||
};
|
||||
|
||||
//
|
||||
// START Notification Handling Defaults
|
||||
//
|
||||
that.messagesWaiting = function messagesWaiting(isWaiting) { // How to indicate a message light on button.
|
||||
// Note that waitingButton doesn't have to exist unless someone explicitly calls this with isWaiting true.
|
||||
that.button.editProperties({
|
||||
icon: isWaiting ? that.normalMessagesButton : that.normalButton,
|
||||
activeIcon: isWaiting ? that.activeMessagesButton : that.activeButton
|
||||
});
|
||||
};
|
||||
that.notificationPollTimeout = [false];
|
||||
that.notificationPollTimeoutMs = [60000];
|
||||
that.notificationPollEndpoint = [false];
|
||||
that.notificationPollStopPaginatingConditionMet = [false];
|
||||
that.notificationDataProcessPage = function (data) {
|
||||
return data;
|
||||
};
|
||||
that.notificationPollCallback = [that.ignore];
|
||||
that.notificationPollCaresAboutSince = [false];
|
||||
that.notificationInitialCallbackMade = [false];
|
||||
that.notificationDisplayBanner = function (message) {
|
||||
if (!that.isOpen) {
|
||||
Window.displayAnnouncement(message);
|
||||
}
|
||||
};
|
||||
//
|
||||
// END Notification Handling Defaults
|
||||
//
|
||||
|
||||
// Handlers
|
||||
that.onScreenChanged = function onScreenChanged(type, url) {
|
||||
// Set isOpen, wireEventBridge, set buttonActive as appropriate,
|
||||
// and finally call onOpened() or onClosed() IFF defined.
|
||||
that.setCurrentVisibleScreenMetadata(type, url);
|
||||
|
||||
if (that.checkIsOpen(type, url)) {
|
||||
that.wireEventBridge(true);
|
||||
if (!that.isOpen) {
|
||||
if (that.onOpened) {
|
||||
that.onOpened();
|
||||
}
|
||||
that.buttonActive(true);
|
||||
that.isOpen = true;
|
||||
}
|
||||
} else {
|
||||
// A different screen is now visible, or the tablet has been closed.
|
||||
// Tablet visibility is controlled separately by `tabletShownChanged()`
|
||||
that.wireEventBridge(false);
|
||||
if (that.isOpen) {
|
||||
if (that.onClosed) {
|
||||
that.onClosed();
|
||||
}
|
||||
that.buttonActive(false);
|
||||
that.isOpen = false;
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
// Overwrite with the given properties:
|
||||
Object.keys(properties).forEach(function (key) {
|
||||
that[key] = properties[key];
|
||||
});
|
||||
|
||||
//
|
||||
// START Notification Handling
|
||||
//
|
||||
|
||||
var currentDataPageToRetrieve = [];
|
||||
var concatenatedServerResponse = [];
|
||||
for (var i = 0; i < that.notificationPollEndpoint.length; i++) {
|
||||
currentDataPageToRetrieve[i] = 1;
|
||||
concatenatedServerResponse[i] = new Array();
|
||||
}
|
||||
|
||||
var MAX_LOG_LENGTH_CHARACTERS = 300;
|
||||
function requestCallback(error, response, optionalParams) {
|
||||
var indexOfRequest = optionalParams.indexOfRequest;
|
||||
var urlOfRequest = optionalParams.urlOfRequest;
|
||||
|
||||
if (error || (response.status !== 'success')) {
|
||||
print("Error: unable to complete request from URL. Error:", error || response.status);
|
||||
startNotificationTimer(indexOfRequest);
|
||||
return;
|
||||
}
|
||||
|
||||
if (!that.notificationPollStopPaginatingConditionMet[indexOfRequest] ||
|
||||
that.notificationPollStopPaginatingConditionMet[indexOfRequest](response)) {
|
||||
startNotificationTimer(indexOfRequest);
|
||||
|
||||
var notificationData;
|
||||
if (concatenatedServerResponse[indexOfRequest].length) {
|
||||
notificationData = concatenatedServerResponse[indexOfRequest];
|
||||
} else {
|
||||
notificationData = that.notificationDataProcessPage[indexOfRequest](response);
|
||||
}
|
||||
console.debug(that.buttonName,
|
||||
'truncated notification data for processing:',
|
||||
JSON.stringify(notificationData).substring(0, MAX_LOG_LENGTH_CHARACTERS));
|
||||
that.notificationPollCallback[indexOfRequest](notificationData);
|
||||
that.notificationInitialCallbackMade[indexOfRequest] = true;
|
||||
currentDataPageToRetrieve[indexOfRequest] = 1;
|
||||
concatenatedServerResponse[indexOfRequest] = new Array();
|
||||
} else {
|
||||
concatenatedServerResponse[indexOfRequest] =
|
||||
concatenatedServerResponse[indexOfRequest].concat(that.notificationDataProcessPage[indexOfRequest](response));
|
||||
currentDataPageToRetrieve[indexOfRequest]++;
|
||||
request({
|
||||
json: true,
|
||||
uri: (urlOfRequest + "&page=" + currentDataPageToRetrieve[indexOfRequest])
|
||||
}, requestCallback, optionalParams);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
var METAVERSE_BASE = Account.metaverseServerURL;
|
||||
var MS_IN_SEC = 1000;
|
||||
that.notificationPoll = function (i) {
|
||||
if (!that.notificationPollEndpoint[i]) {
|
||||
return;
|
||||
}
|
||||
|
||||
// User is "appearing offline" or is not logged in
|
||||
if (GlobalServices.findableBy === "none" || Account.username === "Unknown user") {
|
||||
// The notification polling will restart when the user changes their availability
|
||||
// or when they log in, so it's not necessary to restart a timer here.
|
||||
console.debug(that.buttonName + " Notifications: User is appearing offline or not logged in. " +
|
||||
that.buttonName + " will poll for notifications when user logs in and has their availability " +
|
||||
"set to not appear offline.");
|
||||
return;
|
||||
}
|
||||
|
||||
var url = METAVERSE_BASE + that.notificationPollEndpoint[i];
|
||||
|
||||
var settingsKey = "notifications/" + that.notificationPollEndpoint[i] + "/lastPoll";
|
||||
var currentTimestamp = new Date().getTime();
|
||||
var lastPollTimestamp = Settings.getValue(settingsKey, currentTimestamp);
|
||||
if (that.notificationPollCaresAboutSince[i]) {
|
||||
url = url + "&since=" + lastPollTimestamp / MS_IN_SEC;
|
||||
}
|
||||
Settings.setValue(settingsKey, currentTimestamp);
|
||||
|
||||
request({
|
||||
json: true,
|
||||
uri: url
|
||||
},
|
||||
requestCallback,
|
||||
{
|
||||
indexOfRequest: i,
|
||||
urlOfRequest: url
|
||||
});
|
||||
};
|
||||
|
||||
// This won't do anything if there isn't a notification endpoint set
|
||||
for (i = 0; i < that.notificationPollEndpoint.length; i++) {
|
||||
that.notificationPoll(i);
|
||||
}
|
||||
|
||||
function startNotificationTimer(indexOfRequest) {
|
||||
that.notificationPollTimeout[indexOfRequest] = Script.setTimeout(function () {
|
||||
that.notificationPoll(indexOfRequest);
|
||||
}, that.notificationPollTimeoutMs[indexOfRequest]);
|
||||
}
|
||||
|
||||
function restartNotificationPoll() {
|
||||
for (var j = 0; j < that.notificationPollEndpoint.length; j++) {
|
||||
that.notificationInitialCallbackMade[j] = false;
|
||||
if (that.notificationPollTimeout[j]) {
|
||||
Script.clearTimeout(that.notificationPollTimeout[j]);
|
||||
that.notificationPollTimeout[j] = false;
|
||||
}
|
||||
that.notificationPoll(j);
|
||||
}
|
||||
}
|
||||
//
|
||||
// END Notification Handling
|
||||
//
|
||||
|
||||
// Properties:
|
||||
that.tablet = Tablet.getTablet(that.tabletName);
|
||||
// Must be after we gather properties.
|
||||
that.buttonPrefix = that.buttonPrefix || that.buttonName.toLowerCase() + "-";
|
||||
defaultButton('normalButton', 'i.svg');
|
||||
defaultButton('activeButton', 'a.svg');
|
||||
defaultButton('normalMessagesButton', 'i-msg.svg');
|
||||
defaultButton('activeMessagesButton', 'a-msg.svg');
|
||||
var buttonOptions = {
|
||||
icon: that.normalButton,
|
||||
activeIcon: that.activeButton,
|
||||
text: that.buttonName
|
||||
};
|
||||
// `TabletScriptingInterface` looks for the presence of a `sortOrder` key.
|
||||
// What it SHOULD do is look to see if the value inside that key is defined.
|
||||
// To get around the current code, we do this instead.
|
||||
if (that.sortOrder) {
|
||||
buttonOptions.sortOrder = that.sortOrder;
|
||||
}
|
||||
that.button = that.tablet.addButton(buttonOptions);
|
||||
that.ignore = function ignore() { };
|
||||
that.hasOutboundEventBridge = false;
|
||||
that.hasInboundQmlEventBridge = false;
|
||||
that.hasInboundHtmlEventBridge = false;
|
||||
// HTML event bridge uses strings, not objects. Here we abstract over that.
|
||||
// (Although injected javascript still has to use JSON.stringify/JSON.parse.)
|
||||
that.sendToHtml = function (messageObject) {
|
||||
that.tablet.emitScriptEvent(JSON.stringify(messageObject));
|
||||
};
|
||||
that.fromHtml = function (messageString) {
|
||||
var parsedMessage = JSON.parse(messageString);
|
||||
parsedMessage.messageSrc = "HTML";
|
||||
that.onMessage(parsedMessage);
|
||||
};
|
||||
that.sendMessage = that.ignore;
|
||||
that.wireEventBridge = function wireEventBridge(on) {
|
||||
// Uniquivocally sets that.sendMessage(messageObject) to do the right thing.
|
||||
// Sets has*EventBridge and wires onMessage to the proper event bridge as appropriate, IFF onMessage defined.
|
||||
var isCurrentlyOnQMLScreen = that.isCurrentlyOnQMLScreen();
|
||||
// Outbound (always, regardless of whether there is an inbound handler).
|
||||
if (on) {
|
||||
that.sendMessage = isCurrentlyOnQMLScreen ? that.tablet.sendToQml : that.sendToHtml;
|
||||
that.hasOutboundEventBridge = true;
|
||||
} else {
|
||||
that.sendMessage = that.ignore;
|
||||
that.hasOutboundEventBridge = false;
|
||||
}
|
||||
|
||||
if (!that.onMessage) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Inbound
|
||||
if (on) {
|
||||
if (isCurrentlyOnQMLScreen && !that.hasInboundQmlEventBridge) {
|
||||
console.debug(that.buttonName, 'connecting', that.tablet.fromQml);
|
||||
that.tablet.fromQml.connect(that.onMessage);
|
||||
that.hasInboundQmlEventBridge = true;
|
||||
} else if (!isCurrentlyOnQMLScreen && !that.hasInboundHtmlEventBridge) {
|
||||
console.debug(that.buttonName, 'connecting', that.tablet.webEventReceived);
|
||||
that.tablet.webEventReceived.connect(that.fromHtml);
|
||||
that.hasInboundHtmlEventBridge = true;
|
||||
}
|
||||
} else {
|
||||
if (that.hasInboundQmlEventBridge) {
|
||||
console.debug(that.buttonName, 'disconnecting', that.tablet.fromQml);
|
||||
that.tablet.fromQml.disconnect(that.onMessage);
|
||||
that.hasInboundQmlEventBridge = false;
|
||||
}
|
||||
if (that.hasInboundHtmlEventBridge) {
|
||||
console.debug(that.buttonName, 'disconnecting', that.tablet.webEventReceived);
|
||||
that.tablet.webEventReceived.disconnect(that.fromHtml);
|
||||
that.hasInboundHtmlEventBridge = false;
|
||||
}
|
||||
}
|
||||
};
|
||||
that.isOpen = false;
|
||||
// To facilitate incremental development, only wire onClicked to do something when "home" is defined in properties.
|
||||
that.onClicked = that.home
|
||||
? function onClicked() {
|
||||
// Call open() or close(), and reset type based on current home property.
|
||||
if (that.isOpen) {
|
||||
that.close();
|
||||
} else {
|
||||
that.open();
|
||||
}
|
||||
} : that.ignore;
|
||||
that.onScriptEnding = function onScriptEnding() {
|
||||
// Close if necessary, clean up any remaining handlers, and remove the button.
|
||||
GlobalServices.myUsernameChanged.disconnect(restartNotificationPoll);
|
||||
GlobalServices.findableByChanged.disconnect(restartNotificationPoll);
|
||||
that.tablet.screenChanged.disconnect(that.onScreenChanged);
|
||||
if (that.isOpen) {
|
||||
that.close();
|
||||
that.onScreenChanged("", "");
|
||||
}
|
||||
if (that.button) {
|
||||
if (that.onClicked) {
|
||||
that.button.clicked.disconnect(that.onClicked);
|
||||
}
|
||||
that.tablet.removeButton(that.button);
|
||||
}
|
||||
for (var i = 0; i < that.notificationPollTimeout.length; i++) {
|
||||
if (that.notificationPollTimeout[i]) {
|
||||
Script.clearInterval(that.notificationPollTimeout[i]);
|
||||
that.notificationPollTimeout[i] = false;
|
||||
}
|
||||
}
|
||||
};
|
||||
// Set up the handlers.
|
||||
that.tablet.screenChanged.connect(that.onScreenChanged);
|
||||
that.button.clicked.connect(that.onClicked);
|
||||
Script.scriptEnding.connect(that.onScriptEnding);
|
||||
GlobalServices.findableByChanged.connect(restartNotificationPoll);
|
||||
GlobalServices.myUsernameChanged.connect(restartNotificationPoll);
|
||||
if (that.buttonName === Settings.getValue("startUpApp")) {
|
||||
Settings.setValue("startUpApp", "");
|
||||
Script.setTimeout(function () {
|
||||
that.open();
|
||||
}, 1000);
|
||||
}
|
||||
}
|
||||
module.exports = AppUi;
|
BIN
applications/tabletCam/sounds/flashOff.wav
Normal file
BIN
applications/tabletCam/sounds/flashOff.wav
Normal file
Binary file not shown.
BIN
applications/tabletCam/sounds/flashOn.wav
Normal file
BIN
applications/tabletCam/sounds/flashOn.wav
Normal file
Binary file not shown.
BIN
applications/tabletCam/sounds/snap.wav
Normal file
BIN
applications/tabletCam/sounds/snap.wav
Normal file
Binary file not shown.
646
applications/tabletCam/tabletCam_app.js
Normal file
646
applications/tabletCam/tabletCam_app.js
Normal file
|
@ -0,0 +1,646 @@
|
|||
"use strict";
|
||||
/*jslint vars:true, plusplus:true, forin:true*/
|
||||
/*global Tablet, Script, */
|
||||
/* eslint indent: ["error", 4, { "outerIIFEBody": 1 }] */
|
||||
//
|
||||
// tabletCam_app.js
|
||||
//
|
||||
// Created by Zach Fox on 2019-04-14
|
||||
// Copyright 2022 Overte e.V.
|
||||
//
|
||||
// Camera with more advanced features than the SNAP application, with an higher resolution capability.
|
||||
//
|
||||
// Distributed under the Apache License, Version 2.0
|
||||
// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html
|
||||
//
|
||||
|
||||
(function () { // BEGIN LOCAL_SCOPE
|
||||
var AppUi = Script.require('./modules/appUi.js');
|
||||
|
||||
var secondaryCameraConfig = Render.getConfig("SecondaryCamera");
|
||||
var tabletCamAvatarEntity = false;
|
||||
var previousNearClipDistance = false;
|
||||
var previousFarClipDistance = false;
|
||||
var previousvFoV = false;
|
||||
var NEAR_CLIP_DISTANCE = 0.001;
|
||||
var FAR_CLIP_DISTANCE = 16384;
|
||||
var vFoV = Settings.getValue("tabletCam/vFoV", 60);
|
||||
var secondaryCameraResolutionWidth = 1000;
|
||||
var secondaryCameraResolutionHeight = secondaryCameraResolutionWidth / aspectRatio;
|
||||
|
||||
var PREVIEW_SHORT_SIDE_RESOLUTION = 400;
|
||||
var secondaryCameraResolutionPreviewWidth = PREVIEW_SHORT_SIDE_RESOLUTION;
|
||||
var secondaryCameraResolutionPreviewHeight = PREVIEW_SHORT_SIDE_RESOLUTION / aspectRatio;
|
||||
|
||||
var CAMERA_ENTITY_NAME = "CAMERA SNAP-PRO OV-22";
|
||||
var APPLICATION_CAPTION = "SNAP-PRO";
|
||||
|
||||
var tabletCamRunning = false;
|
||||
|
||||
var TABLET_CAM_ENTITY_PROPERTIES = {
|
||||
"type": "Model",
|
||||
"modelURL": Script.resolvePath("models/camera.fbx"),
|
||||
"shapeType": "simple-hull",
|
||||
"dimensions": {"x":0.1600, "y":0.1021, "z":0.1137},
|
||||
"damping": 0,
|
||||
"angularDamping": 0,
|
||||
"shape": "Cube",
|
||||
"isVisibleInSecondaryCamera": false,
|
||||
"name": CAMERA_ENTITY_NAME,
|
||||
"grab": {
|
||||
"grabbable": true
|
||||
},
|
||||
"registrationPoint": {
|
||||
"x": 0.42,
|
||||
"y": 0.4,
|
||||
"z": 0
|
||||
}
|
||||
};
|
||||
|
||||
function enableTabletCam() {
|
||||
if (!tabletCamRunning) {
|
||||
wireSignals(true);
|
||||
|
||||
setTakePhotoControllerMappingStatus(true);
|
||||
|
||||
secondaryCameraConfig.enableSecondaryCameraRenderConfigs(true);
|
||||
setSnapshotQuality(snapshotQuality);
|
||||
var props = TABLET_CAM_ENTITY_PROPERTIES;
|
||||
var dynamicProps = getDynamicTabletCamAvatarEntityProperties();
|
||||
for (var key in dynamicProps) {
|
||||
props[key] = dynamicProps[key];
|
||||
}
|
||||
tabletCamAvatarEntity = Entities.addEntity(props, "avatar");
|
||||
previousFarClipDistance = secondaryCameraConfig.farClipPlaneDistance;
|
||||
previousNearClipDistance = secondaryCameraConfig.nearClipPlaneDistance;
|
||||
previousvFoV = secondaryCameraConfig.vFoV;
|
||||
secondaryCameraConfig.nearClipPlaneDistance = NEAR_CLIP_DISTANCE;
|
||||
secondaryCameraConfig.farClipPlaneDistance = FAR_CLIP_DISTANCE;
|
||||
secondaryCameraConfig.vFoV = vFoV;
|
||||
|
||||
secondaryCameraConfig.attachedEntityId = tabletCamAvatarEntity;
|
||||
tabletCamRunning = true;
|
||||
}
|
||||
|
||||
updateTabletCamLocalEntity();
|
||||
|
||||
// Remove the existing tabletCamAvatarEntity model from the domain if one exists.
|
||||
// It's easy for this to happen if the user crashes while the Tablet Cam is on.
|
||||
// We do this down here (after the new one is rezzed) so that we don't accidentally delete
|
||||
// the newly-rezzed model.
|
||||
var entityIDs = Entities.findEntitiesByName(CAMERA_ENTITY_NAME, MyAvatar.position, 100, false);
|
||||
entityIDs.forEach(function (currentEntityID) {
|
||||
var currentEntityOwner = Entities.getEntityProperties(currentEntityID, ['owningAvatarID']).owningAvatarID;
|
||||
if (currentEntityOwner === MyAvatar.sessionUUID && currentEntityID !== tabletCamAvatarEntity) {
|
||||
Entities.deleteEntity(currentEntityID);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
var frontCamInUse = Settings.getValue("tabletCam/frontCamInUse", true);
|
||||
function switchCams(forceFrontCamValue) {
|
||||
if (!tabletCamAvatarEntity || (!!HMD.tabletID && !tabletCamLocalEntity)) {
|
||||
console.log("User tried to switch cams, but TabletCam wasn't ready!");
|
||||
return;
|
||||
}
|
||||
|
||||
frontCamInUse = forceFrontCamValue || !frontCamInUse;
|
||||
Settings.setValue("tabletCam/frontCamInUse", frontCamInUse);
|
||||
|
||||
var newTabletCamAvatarEntityProps = getDynamicTabletCamAvatarEntityProperties();
|
||||
Entities.editEntity(tabletCamAvatarEntity, newTabletCamAvatarEntityProps);
|
||||
|
||||
updateTabletCamLocalEntity();
|
||||
}
|
||||
|
||||
function disableTabletCam() {
|
||||
function deleteTabletCamAvatarEntity() {
|
||||
if (flash) {
|
||||
Entities.deleteEntity(flash);
|
||||
flash = false;
|
||||
}
|
||||
|
||||
if (tabletCamAvatarEntity) {
|
||||
Entities.deleteEntity(tabletCamAvatarEntity);
|
||||
tabletCamAvatarEntity = false;
|
||||
detached = false; // TO BE CONFIRMED
|
||||
Settings.setValue("tabletCam/detached", detached); // TO BE CONFIRMED
|
||||
}
|
||||
}
|
||||
|
||||
wireSignals(false);
|
||||
|
||||
setTakePhotoControllerMappingStatus(false);
|
||||
|
||||
if (tabletCamRunning) {
|
||||
secondaryCameraConfig.farClipPlaneDistance = previousFarClipDistance;
|
||||
secondaryCameraConfig.nearClipPlaneDistance = previousNearClipDistance;
|
||||
secondaryCameraConfig.vFoV = previousvFoV;
|
||||
secondaryCameraConfig.attachedEntityId = false;
|
||||
secondaryCameraConfig.enableSecondaryCameraRenderConfigs(false);
|
||||
}
|
||||
|
||||
deleteTabletCamAvatarEntity();
|
||||
|
||||
if (tabletCamLocalEntity) {
|
||||
Entities.deleteEntity(tabletCamLocalEntity);
|
||||
tabletCamLocalEntity = false;
|
||||
detached = false; // TO BE CONFIRMED
|
||||
Settings.setValue("tabletCam/detached", detached); // TO BE CONFIRMED
|
||||
}
|
||||
|
||||
tabletCamRunning = false;
|
||||
}
|
||||
|
||||
var tabletCamLocalEntityWidth = 0.282;
|
||||
var tabletCamLocalEntityHeight = 0.282;
|
||||
var tabletCamLocalEntityDim = { x: tabletCamLocalEntityWidth, y: tabletCamLocalEntityHeight };
|
||||
var tabletCamLocalEntity = false;
|
||||
var LOCAL_ENTITY_STATIC_PROPERTIES = {
|
||||
type: "Image",
|
||||
imageURL: "resource://spectatorCameraFrame",
|
||||
emissive: true,
|
||||
grab: {
|
||||
"grabbable": false
|
||||
},
|
||||
alpha: 1,
|
||||
triggerable: false
|
||||
};
|
||||
function updateTabletCamLocalEntity() {
|
||||
if (!HMD.tabletID) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (tabletCamLocalEntity) {
|
||||
Entities.deleteEntity(tabletCamLocalEntity);
|
||||
tabletCamLocalEntity = false;
|
||||
}
|
||||
var props = LOCAL_ENTITY_STATIC_PROPERTIES;
|
||||
props.dimensions = tabletCamLocalEntityDim;
|
||||
if (!!HMD.tabletID) {
|
||||
props.parentID = HMD.tabletID;
|
||||
props.localPosition = [0, 0.0225, -0.008];
|
||||
if (frontCamInUse) {
|
||||
props.localRotation = Quat.fromVec3Degrees([0, 180, 180]);
|
||||
} else {
|
||||
props.localRotation = Quat.fromVec3Degrees([0, 0, 180]);
|
||||
}
|
||||
} else {
|
||||
props.parentID = Uuid.NULL;
|
||||
props.localPosition = inFrontOf(0.5);
|
||||
props.localRotation = MyAvatar.orientation;
|
||||
}
|
||||
|
||||
tabletCamLocalEntity = Entities.addEntity(props, "local");
|
||||
}
|
||||
|
||||
function onDomainChanged() {
|
||||
if (tabletCamRunning) {
|
||||
disableTabletCam();
|
||||
}
|
||||
}
|
||||
|
||||
function tabletVisibilityChanged() {
|
||||
if (!ui.tablet.tabletShown && ui.isOpen) {
|
||||
ui.close();
|
||||
}
|
||||
}
|
||||
|
||||
var flash = Settings.getValue("tabletCam/flashEnabled", false);;
|
||||
function setFlashStatus(enabled) {
|
||||
if (!tabletCamAvatarEntity) {
|
||||
return;
|
||||
}
|
||||
|
||||
Settings.setValue("tabletCam/flashEnabled", enabled);
|
||||
|
||||
var cameraPosition = Entities.getEntityProperties(tabletCamAvatarEntity, ["positon"]).position;
|
||||
if (enabled) {
|
||||
Audio.playSound(SOUND_FLASH_ON, {
|
||||
position: cameraPosition,
|
||||
localOnly: true,
|
||||
volume: 0.8
|
||||
});
|
||||
flash = Entities.addEntity({
|
||||
"collisionless": true,
|
||||
"collidesWith": "",
|
||||
"collisionMask": 0,
|
||||
"color": {
|
||||
"blue": 173,
|
||||
"green": 252,
|
||||
"red": 255
|
||||
},
|
||||
"cutoff": 90,
|
||||
"dimensions": {
|
||||
"x": 4,
|
||||
"y": 4,
|
||||
"z": 4
|
||||
},
|
||||
"dynamic": false,
|
||||
"falloffRadius": 0.20000000298023224,
|
||||
"intensity": 27,
|
||||
"isSpotlight": true,
|
||||
"localRotation": { w: 1, x: 0, y: 0, z: 0 },
|
||||
"localPosition": { x: 0, y: 0, z: -0.005 },
|
||||
"name": "Tablet Camera Flash",
|
||||
"type": "Light",
|
||||
"parentID": tabletCamAvatarEntity,
|
||||
}, "avatar");
|
||||
} else {
|
||||
if (flash) {
|
||||
Audio.playSound(SOUND_FLASH_OFF, {
|
||||
position: cameraPosition,
|
||||
localOnly: true,
|
||||
volume: 0.8
|
||||
});
|
||||
Entities.deleteEntity(flash);
|
||||
flash = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function takePhoto() {
|
||||
var tabletCamAvatarEntityPosition = Entities.getEntityProperties(tabletCamAvatarEntity, ["position"]).position;
|
||||
Audio.playSound(SOUND_SNAPSHOT, {
|
||||
position: { x: tabletCamAvatarEntityPosition.x, y: tabletCamAvatarEntityPosition.y, z: tabletCamAvatarEntityPosition.z },
|
||||
localOnly: true,
|
||||
volume: 0.2
|
||||
});
|
||||
Window.takeSecondaryCameraSnapshot();
|
||||
}
|
||||
|
||||
function maybeTakePhoto() {
|
||||
if (tabletCamAvatarEntity) {
|
||||
secondaryCameraConfig.resetSizeSpectatorCamera(secondaryCameraResolutionWidth, secondaryCameraResolutionHeight);
|
||||
// Wait a moment before taking the photo for the resolution to update
|
||||
Script.setTimeout(function () {
|
||||
takePhoto();
|
||||
}, 250);
|
||||
}
|
||||
}
|
||||
|
||||
var snapshotQuality = Settings.getValue("tabletCam/quality", "normal");
|
||||
function setSnapshotQuality(quality) {
|
||||
snapshotQuality = quality;
|
||||
Settings.setValue("tabletCam/quality", snapshotQuality);
|
||||
|
||||
var shortSideTargetResolution = 1000;
|
||||
if (snapshotQuality === "low") {
|
||||
shortSideTargetResolution = 500;
|
||||
} else if (snapshotQuality === "normal") {
|
||||
shortSideTargetResolution = 1000;
|
||||
} else if (snapshotQuality === "high") {
|
||||
shortSideTargetResolution = 2160;
|
||||
} else if (snapshotQuality === "extreme") {
|
||||
shortSideTargetResolution = 4320;
|
||||
}
|
||||
|
||||
if (tallOrientation && !HMD.active) {
|
||||
secondaryCameraResolutionWidth = shortSideTargetResolution;
|
||||
secondaryCameraResolutionHeight = secondaryCameraResolutionWidth / aspectRatio;
|
||||
|
||||
secondaryCameraResolutionPreviewWidth = PREVIEW_SHORT_SIDE_RESOLUTION;
|
||||
secondaryCameraResolutionPreviewHeight = secondaryCameraResolutionPreviewWidth / aspectRatio;
|
||||
} else {
|
||||
secondaryCameraResolutionHeight = shortSideTargetResolution;
|
||||
secondaryCameraResolutionWidth = secondaryCameraResolutionHeight / aspectRatio;
|
||||
|
||||
secondaryCameraResolutionPreviewHeight = PREVIEW_SHORT_SIDE_RESOLUTION;
|
||||
secondaryCameraResolutionPreviewWidth = secondaryCameraResolutionPreviewHeight / aspectRatio;
|
||||
}
|
||||
|
||||
secondaryCameraConfig.resetSizeSpectatorCamera(secondaryCameraResolutionPreviewWidth, secondaryCameraResolutionPreviewHeight);
|
||||
}
|
||||
|
||||
var aspectRatio = parseFloat(Settings.getValue("tabletCam/aspectRatio", "0.8"));
|
||||
function setAspectRatio(ratio) {
|
||||
aspectRatio = ratio;
|
||||
Settings.setValue("tabletCam/aspectRatio", aspectRatio);
|
||||
|
||||
setSnapshotQuality(snapshotQuality);
|
||||
}
|
||||
|
||||
var tallOrientation = Settings.getValue("tabletCam/tallOrientation", true);
|
||||
function setOrientation(orientation) {
|
||||
tallOrientation = orientation;
|
||||
Settings.setValue("tabletCam/tallOrientation", tallOrientation);
|
||||
|
||||
setSnapshotQuality(snapshotQuality);
|
||||
}
|
||||
|
||||
function photoDirChanged(snapshotPath) {
|
||||
Window.browseDirChanged.disconnect(photoDirChanged);
|
||||
if (snapshotPath !== "") { // not cancelled
|
||||
Snapshot.setSnapshotsLocation(snapshotPath);
|
||||
ui.sendMessage({
|
||||
method: "photoDirectoryChanged",
|
||||
photoDirectory: snapshotPath
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
function fromQml(message) {
|
||||
switch (message.method) {
|
||||
case 'switchCams':
|
||||
switchCams(message.frontCamInUse);
|
||||
break;
|
||||
case 'switchOrientation':
|
||||
setOrientation(!tallOrientation);
|
||||
break;
|
||||
case 'setFlashStatus':
|
||||
setFlashStatus(message.enabled);
|
||||
break;
|
||||
case 'takePhoto':
|
||||
maybeTakePhoto();
|
||||
break;
|
||||
case 'updateCameravFoV':
|
||||
vFoV = message.vFoV;
|
||||
secondaryCameraConfig.vFoV = vFoV;
|
||||
Settings.setValue("tabletCam/vFoV", vFoV);
|
||||
break;
|
||||
case 'setSnapshotQuality':
|
||||
setSnapshotQuality(message.quality);
|
||||
break;
|
||||
case 'setAspectRatio':
|
||||
setAspectRatio(message.aspectRatio);
|
||||
break;
|
||||
case 'activeViewChanged':
|
||||
if (message.activeView === "settingsView" || message.activeView === "reviewView") {
|
||||
//disableTabletCam();
|
||||
} else {
|
||||
enableTabletCam();
|
||||
}
|
||||
break;
|
||||
case 'setPhotoDirectory':
|
||||
Window.browseDirChanged.connect(photoDirChanged);
|
||||
Window.browseDirAsync("Choose Photo Directory", "", "");
|
||||
break;
|
||||
case 'setDetached':
|
||||
detached = message.detached;
|
||||
Settings.setValue("tabletCam/detached", detached);
|
||||
var newTabletCamAvatarEntityProps = getDynamicTabletCamAvatarEntityProperties();
|
||||
Entities.editEntity(tabletCamAvatarEntity, newTabletCamAvatarEntityProps);
|
||||
break;
|
||||
default:
|
||||
print('Unrecognized message from TabletCam.qml.');
|
||||
}
|
||||
}
|
||||
|
||||
function setTakePhotoControllerMappingStatus(status) {
|
||||
if (!takePhotoControllerMapping) {
|
||||
return;
|
||||
}
|
||||
if (status) {
|
||||
takePhotoControllerMapping.enable();
|
||||
} else {
|
||||
takePhotoControllerMapping.disable();
|
||||
}
|
||||
}
|
||||
|
||||
var takePhotoControllerMapping;
|
||||
var takePhotoControllerMappingName = 'Hifi-TabletCam-Mapping-TakePhoto';
|
||||
function registerTakePhotoControllerMapping() {
|
||||
takePhotoControllerMapping = Controller.newMapping(takePhotoControllerMappingName);
|
||||
if (controllerType === "OculusTouch") {
|
||||
takePhotoControllerMapping.from(Controller.Standard.RS).to(function (value) {
|
||||
if (value === 1.0) {
|
||||
maybeTakePhoto();
|
||||
}
|
||||
return;
|
||||
});
|
||||
} else if (controllerType === "Vive") {
|
||||
takePhotoControllerMapping.from(Controller.Standard.RightPrimaryThumb).to(function (value) {
|
||||
if (value === 1.0) {
|
||||
maybeTakePhoto();
|
||||
}
|
||||
return;
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
var controllerType = "Other";
|
||||
function registerButtonMappings() {
|
||||
var VRDevices = Controller.getDeviceNames().toString();
|
||||
if (VRDevices) {
|
||||
if (VRDevices.indexOf("Vive") !== -1) {
|
||||
controllerType = "Vive";
|
||||
} else if (VRDevices.indexOf("OculusTouch") !== -1) {
|
||||
controllerType = "OculusTouch";
|
||||
} else {
|
||||
return; // Neither Vive nor Touch detected
|
||||
}
|
||||
}
|
||||
|
||||
if (!takePhotoControllerMapping) {
|
||||
registerTakePhotoControllerMapping();
|
||||
}
|
||||
}
|
||||
|
||||
function onHMDChanged(isHMDMode) {
|
||||
registerButtonMappings();
|
||||
disableTabletCam();
|
||||
}
|
||||
|
||||
var cameraRollPaths = JSON.parse(Settings.getValue("tabletCam/cameraRollPaths", '{"paths": []}'));
|
||||
function onStillSnapshotTaken(path) {
|
||||
var tempObject = {};
|
||||
tempObject.imagePath = "file:///" + path;
|
||||
|
||||
cameraRollPaths.paths.unshift(tempObject);
|
||||
if (cameraRollPaths.paths.length > 15) {
|
||||
cameraRollPaths.paths.pop();
|
||||
}
|
||||
Settings.setValue("tabletCam/cameraRollPaths", JSON.stringify(cameraRollPaths));
|
||||
|
||||
secondaryCameraConfig.resetSizeSpectatorCamera(secondaryCameraResolutionPreviewWidth, secondaryCameraResolutionPreviewHeight);
|
||||
ui.sendMessage({
|
||||
method: 'stillSnapshotTaken',
|
||||
lastStillSnapshotPath: tempObject.imagePath
|
||||
});
|
||||
}
|
||||
|
||||
var signalsWired = false;
|
||||
function wireSignals(shouldWire) {
|
||||
if (signalsWired === shouldWire) {
|
||||
return;
|
||||
}
|
||||
|
||||
signalsWired = shouldWire;
|
||||
|
||||
if (shouldWire) {
|
||||
Window.stillSnapshotTaken.connect(onStillSnapshotTaken);
|
||||
} else {
|
||||
Window.stillSnapshotTaken.disconnect(onStillSnapshotTaken);
|
||||
}
|
||||
}
|
||||
|
||||
function inFrontOf(distance, position, orientation) {
|
||||
return Vec3.sum(position || MyAvatar.position,
|
||||
Vec3.multiply(distance, Quat.getForward(orientation || MyAvatar.orientation)));
|
||||
}
|
||||
|
||||
var detached = false;
|
||||
Settings.setValue("tabletCam/detached", detached);
|
||||
function getDynamicTabletCamAvatarEntityProperties() {
|
||||
var dynamicProps = {
|
||||
dimensions: {"x":0.1600, "y":0.1021, "z":0.1137}
|
||||
};
|
||||
|
||||
if (detached) {
|
||||
//print("DETACHED MODE");
|
||||
dynamicProps.collisionless = false;
|
||||
dynamicProps.ignoreForCollisions = false;
|
||||
dynamicProps.grab = {
|
||||
"grabbable": true,
|
||||
"equippableLeftRotation": {
|
||||
"x": -0.0000152587890625,
|
||||
"y": -0.0000152587890625,
|
||||
"z": -0.0000152587890625,
|
||||
"w": 1
|
||||
},
|
||||
"equippableRightRotation": {
|
||||
"x": -0.0000152587890625,
|
||||
"y": -0.0000152587890625,
|
||||
"z": -0.0000152587890625,
|
||||
"w": 1
|
||||
}
|
||||
};
|
||||
dynamicProps.visible = true;
|
||||
dynamicProps.parentID = Uuid.NULL;
|
||||
dynamicProps.parentJointIndex = 65535;
|
||||
dynamicProps.triggerable = true;
|
||||
if (tabletCamAvatarEntity) {
|
||||
var currentProps = Entities.getEntityProperties(tabletCamAvatarEntity, ["position", "rotation"]);
|
||||
if (!!HMD.tabletID) {
|
||||
dynamicProps.position = inFrontOf(0.2, currentProps.position, currentProps.rotation);
|
||||
} else {
|
||||
dynamicProps.position = currentProps.position;
|
||||
}
|
||||
dynamicProps.rotation = currentProps.rotation;
|
||||
} else {
|
||||
dynamicProps.position = inFrontOf(0.5);
|
||||
dynamicProps.rotation = MyAvatar.orientation;
|
||||
}
|
||||
dynamicProps.velocity = [0, 0, 0];
|
||||
dynamicProps.angularVelocity = [0, 0, 0];
|
||||
} else {
|
||||
dynamicProps.triggerable = false;
|
||||
dynamicProps.collisionless = true;
|
||||
dynamicProps.ignoreForCollisions = true;
|
||||
dynamicProps.grab = {
|
||||
"grabbable": false
|
||||
};
|
||||
dynamicProps.visible = false;
|
||||
|
||||
if (!!HMD.tabletID) {
|
||||
//print("TABLET MODE");
|
||||
dynamicProps.parentID = HMD.tabletID;
|
||||
dynamicProps.parentJointIndex = 65535;
|
||||
dynamicProps.dimensions = [0.01, 0.01, 0.01];
|
||||
} else {
|
||||
//print("DESKTOP USER CAMERA MODE");
|
||||
var cameraMode = Camera.mode;
|
||||
// If:
|
||||
// - User is in third person mode
|
||||
// - User is using the rear-facing camera
|
||||
if (cameraMode !== "first person" && !frontCamInUse) {
|
||||
dynamicProps.parentID = MyAvatar.sessionUUID;
|
||||
dynamicProps.parentJointIndex = MyAvatar.getJointIndex("_CAMERA_MATRIX");
|
||||
} else {
|
||||
dynamicProps.parentID = MyAvatar.sessionUUID;
|
||||
var jointIndex = MyAvatar.getJointIndex("HeadTop_End");
|
||||
if (jointIndex === -1) {
|
||||
jointIndex = MyAvatar.getJointIndex("Head");
|
||||
}
|
||||
dynamicProps.parentJointIndex = jointIndex;
|
||||
}
|
||||
}
|
||||
|
||||
dynamicProps.localPosition = {
|
||||
"x": 0,
|
||||
"y": !!HMD.tabletID ? 0.215 : (frontCamInUse ? -0.03 : (Camera.mode !== "first person" ? 0 : -0.02)),
|
||||
"z": !!HMD.tabletID ? (frontCamInUse ? -0.02 : 0.1) : (frontCamInUse ? 1 : (Camera.mode !== "first person" ? 0 : 0.05))
|
||||
};
|
||||
|
||||
if (!!HMD.tabletID) {
|
||||
dynamicProps.localRotation = {
|
||||
"x": 0,
|
||||
"y": frontCamInUse ? 0 : 1,
|
||||
"z": 0,
|
||||
"w": frontCamInUse ? 1 : 0
|
||||
};
|
||||
} else {
|
||||
dynamicProps.localRotation = {
|
||||
"x": 0,
|
||||
"y": frontCamInUse || (!frontCamInUse && Camera.mode !== "first person") ? 0 : 1,
|
||||
"z": 0,
|
||||
"w": frontCamInUse || (!frontCamInUse && Camera.mode !== "first person") ? 1 : 0
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
return dynamicProps;
|
||||
}
|
||||
|
||||
function onModeUpdated(newMode) {
|
||||
if (tabletCamAvatarEntity) {
|
||||
var newTabletCamAvatarEntityProps = getDynamicTabletCamAvatarEntityProperties();
|
||||
Entities.editEntity(tabletCamAvatarEntity, newTabletCamAvatarEntityProps);
|
||||
}
|
||||
}
|
||||
|
||||
function onClosed() {
|
||||
if (!detached) {
|
||||
disableTabletCam();
|
||||
}
|
||||
|
||||
if (tabletCamLocalEntity) {
|
||||
Entities.deleteEntity(tabletCamLocalEntity);
|
||||
tabletCamLocalEntity = false;
|
||||
}
|
||||
}
|
||||
|
||||
function buttonActive(isActive) {
|
||||
ui.button.editProperties({isActive: isActive || tabletCamRunning});
|
||||
}
|
||||
|
||||
var ui;
|
||||
function startup() {
|
||||
ui = new AppUi({
|
||||
buttonName: APPLICATION_CAPTION,
|
||||
home: Script.resolvePath("./ui/TabletCam.qml"),
|
||||
// Selfie by Path Lord from the Noun Project
|
||||
graphicsDirectory: Script.resolvePath("appIcons/"),
|
||||
onOpened: enableTabletCam,
|
||||
onClosed: onClosed,
|
||||
onMessage: fromQml,
|
||||
buttonActive: buttonActive
|
||||
});
|
||||
|
||||
Window.domainChanged.connect(onDomainChanged);
|
||||
ui.tablet.tabletShownChanged.connect(tabletVisibilityChanged);
|
||||
HMD.displayModeChanged.connect(onHMDChanged);
|
||||
Camera.modeUpdated.connect(onModeUpdated);
|
||||
|
||||
registerButtonMappings();
|
||||
}
|
||||
startup();
|
||||
|
||||
function shutdown() {
|
||||
disableTabletCam();
|
||||
Window.domainChanged.disconnect(onDomainChanged);
|
||||
ui.tablet.tabletShownChanged.disconnect(tabletVisibilityChanged);
|
||||
HMD.displayModeChanged.disconnect(onHMDChanged);
|
||||
Camera.modeUpdated.disconnect(onModeUpdated);
|
||||
if (takePhotoControllerMapping) {
|
||||
takePhotoControllerMapping.disable();
|
||||
}
|
||||
wireSignals(false);
|
||||
}
|
||||
Script.scriptEnding.connect(shutdown);
|
||||
|
||||
// "Camera Shutter, Fast, A.wav" by InspectorJ (www.jshaw.co.uk) of Freesound.org
|
||||
var SOUND_SNAPSHOT = SoundCache.getSound(Script.resolvePath("sounds/snap.wav"));
|
||||
var SOUND_FLASH_ON = SoundCache.getSound(Script.resolvePath("sounds/flashOn.wav"));
|
||||
var SOUND_FLASH_OFF = SoundCache.getSound(Script.resolvePath("sounds/flashOff.wav"));
|
||||
}()); // END LOCAL_SCOPE
|
907
applications/tabletCam/ui/TabletCam.qml
Normal file
907
applications/tabletCam/ui/TabletCam.qml
Normal file
|
@ -0,0 +1,907 @@
|
|||
//
|
||||
// TabletCam.qml
|
||||
// qml/hifi
|
||||
//
|
||||
// Tablet Cam v2.2
|
||||
//
|
||||
// Created by Zach Fox on 2019-04-14
|
||||
// Copyright 2022 Overte e.V.
|
||||
//
|
||||
// Distributed under the Apache License, Version 2.0.
|
||||
// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html
|
||||
//
|
||||
|
||||
import Hifi 1.0 as Hifi
|
||||
import QtQuick 2.7
|
||||
import QtQuick.Controls 2.3
|
||||
import stylesUit 1.0 as HifiStylesUit
|
||||
import controlsUit 1.0 as HifiControlsUit
|
||||
|
||||
Rectangle {
|
||||
id: root;
|
||||
property bool flashEnabled: Settings.getValue("tabletCam/flashEnabled", false);
|
||||
property string snapshotQuality: Settings.getValue("tabletCam/quality", "normal");
|
||||
property real aspectRatio: Settings.getValue("tabletCam/aspectRatio", (8 / 10));
|
||||
property bool detached: Settings.getValue("tabletCam/detached", false);
|
||||
property bool frontCamInUse: Settings.getValue("tabletCam/frontCamInUse", true);
|
||||
property string activeView: "mainView";
|
||||
|
||||
HifiStylesUit.HifiConstants { id: hifi; }
|
||||
color: hifi.colors.black;
|
||||
|
||||
onFlashEnabledChanged: {
|
||||
sendToScript({method: 'setFlashStatus', enabled: root.flashEnabled});
|
||||
}
|
||||
|
||||
onDetachedChanged: {
|
||||
sendToScript({method: 'setDetached', detached: root.detached});
|
||||
}
|
||||
|
||||
onFrontCamInUseChanged: {
|
||||
sendToScript({method: 'switchCams', frontCamInUse: root.frontCamInUse});
|
||||
}
|
||||
|
||||
onActiveViewChanged: {
|
||||
root.flashEnabled = false;
|
||||
sendToScript({method: 'activeViewChanged', activeView: root.activeView});
|
||||
|
||||
if (root.activeView === "settingsView") {
|
||||
photoDirectoryTextField.text = Settings.getValue("snapshotsLocation", "<Not Set>");
|
||||
}
|
||||
}
|
||||
|
||||
Item {
|
||||
id: mainView;
|
||||
visible: root.activeView === "mainView";
|
||||
anchors.fill: parent;
|
||||
|
||||
Rectangle {
|
||||
id: helpTextContainer;
|
||||
visible: !!Settings.getValue('tabletCam/firstRun', true) && HMD.active;
|
||||
width: parent.width;
|
||||
height: topBarContainer_main.height;
|
||||
anchors.left: parent.left;
|
||||
anchors.top: parent.top;
|
||||
color: "#121212";
|
||||
|
||||
HifiStylesUit.RalewaySemiBold {
|
||||
text: "Try clicking right thumbstick for photos!";
|
||||
// Anchors
|
||||
anchors.left: parent.left;
|
||||
anchors.leftMargin: 8;
|
||||
anchors.verticalCenter: parent.verticalCenter;
|
||||
size: 22;
|
||||
// Style
|
||||
color: hifi.colors.white;
|
||||
// Alignment
|
||||
horizontalAlignment: Text.AlignLeft;
|
||||
verticalAlignment: Text.AlignVCenter;
|
||||
wrapMode: Text.Wrap;
|
||||
}
|
||||
|
||||
HifiControlsUit.Button {
|
||||
text: "OK";
|
||||
colorScheme: hifi.colorSchemes.dark;
|
||||
color: hifi.buttons.blue;
|
||||
anchors.verticalCenter: parent.verticalCenter;
|
||||
anchors.right: parent.right;
|
||||
anchors.rightMargin: 8;
|
||||
width: 50;
|
||||
height: 35;
|
||||
onClicked: {
|
||||
helpTextContainer.visible = false;
|
||||
Settings.setValue('tabletCam/firstRun', false);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
id: topBarContainer_main;
|
||||
visible: !helpTextContainer.visible;
|
||||
width: parent.width;
|
||||
height: 42;
|
||||
anchors.left: parent.left;
|
||||
anchors.top: parent.top;
|
||||
color: "#121212";
|
||||
|
||||
HifiControlsUit.CheckBox {
|
||||
id: detachCheckbox;
|
||||
text: "Detach"
|
||||
checked: root.detached;
|
||||
boxSize: 24;
|
||||
height: 32;
|
||||
anchors.verticalCenter: parent.verticalCenter;
|
||||
anchors.left: parent.left;
|
||||
anchors.leftMargin: 8;
|
||||
onClicked: {
|
||||
root.detached = checked;
|
||||
}
|
||||
}
|
||||
|
||||
HifiControlsUit.GlyphButton {
|
||||
id: flashButton;
|
||||
height: 26;
|
||||
width: height;
|
||||
anchors.verticalCenter: parent.verticalCenter;
|
||||
anchors.right: fakeFlash.left;
|
||||
anchors.rightMargin: 8;
|
||||
glyph: hifi.glyphs.lightning;
|
||||
color: root.flashEnabled ? hifi.buttons.blue : hifi.buttons.none;
|
||||
onClicked: {
|
||||
root.flashEnabled = !root.flashEnabled;
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
id: fakeCamera;
|
||||
width: 34;
|
||||
height: width;
|
||||
radius: width;
|
||||
anchors.centerIn: parent;
|
||||
color: hifi.colors.black;
|
||||
|
||||
Rectangle {
|
||||
visible: root.frontCamInUse && !root.detached;
|
||||
width: parent.width - 12;
|
||||
height: width;
|
||||
radius: width;
|
||||
anchors.centerIn: parent;
|
||||
color: "#230000";
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
id: fakeFlash;
|
||||
width: 12;
|
||||
height: width;
|
||||
radius: width;
|
||||
anchors.verticalCenter: fakeCamera.verticalCenter;
|
||||
anchors.right: fakeCamera.left;
|
||||
anchors.rightMargin: 4;
|
||||
color: root.flashEnabled && root.frontCamInUse ? "#fffcad" : "#000000";
|
||||
}
|
||||
|
||||
Image {
|
||||
id: switchCams;
|
||||
height: 26;
|
||||
width: height;
|
||||
anchors.verticalCenter: parent.verticalCenter;
|
||||
anchors.left: fakeCamera.right;
|
||||
anchors.leftMargin: 8;
|
||||
source: "./images/switchCams.svg"; // rotate camera by Diego Naive from the Noun Project
|
||||
mipmap: true;
|
||||
MouseArea {
|
||||
anchors.fill: parent;
|
||||
enabled: !root.detached;
|
||||
|
||||
onClicked: {
|
||||
root.frontCamInUse = !root.frontCamInUse;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
HifiControlsUit.GlyphButton {
|
||||
id: settingsButton;
|
||||
height: 26;
|
||||
width: height;
|
||||
anchors.verticalCenter: parent.verticalCenter;
|
||||
anchors.right: parent.right;
|
||||
anchors.rightMargin: 8;
|
||||
glyph: hifi.glyphs.settings;
|
||||
color: hifi.buttons.none;
|
||||
onClicked: {
|
||||
root.activeView = "settingsView";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
visible: !secondaryCameraPreview.visible && HMD.tabletID !== "{00000000-0000-0000-0000-000000000000}";
|
||||
anchors.fill: secondaryCameraPreview;
|
||||
color: hifi.colors.white;
|
||||
}
|
||||
|
||||
// Secondary Camera Preview
|
||||
Hifi.ResourceImageItem {
|
||||
id: secondaryCameraPreview;
|
||||
visible: HMD.tabletID !== "{00000000-0000-0000-0000-000000000000}";
|
||||
url: "resource://spectatorCameraFrame";
|
||||
ready: visible;
|
||||
mirrorVertically: true;
|
||||
anchors.top: topBarContainer_main.bottom;
|
||||
anchors.bottom: bottomBarContainer_main.top;
|
||||
anchors.left: parent.left;
|
||||
anchors.right: parent.right;
|
||||
onVisibleChanged: {
|
||||
update();
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
id: bottomBarContainer_main;
|
||||
height: 88;
|
||||
anchors.left: parent.left;
|
||||
anchors.bottom: parent.bottom;
|
||||
anchors.right: parent.right;
|
||||
color: "#121212";
|
||||
|
||||
Item {
|
||||
id: fieldOfView;
|
||||
anchors.left: parent.left;
|
||||
anchors.leftMargin: 12;
|
||||
anchors.verticalCenter: parent.verticalCenter;
|
||||
anchors.right: takeSnapshotButton.left;
|
||||
anchors.rightMargin: 12;
|
||||
height: 35;
|
||||
|
||||
HifiControlsUit.GlyphButton {
|
||||
id: resetvFoV;
|
||||
anchors.verticalCenter: parent.verticalCenter;
|
||||
anchors.left: parent.left;
|
||||
height: parent.height - 8;
|
||||
width: height;
|
||||
glyph: hifi.glyphs.reload;
|
||||
onClicked: {
|
||||
fieldOfViewSlider.value = 60.0;
|
||||
}
|
||||
}
|
||||
|
||||
HifiControlsUit.Slider {
|
||||
id: fieldOfViewSlider;
|
||||
anchors.top: parent.top;
|
||||
anchors.bottom: parent.bottom;
|
||||
anchors.right: parent.right;
|
||||
anchors.left: resetvFoV.right;
|
||||
anchors.leftMargin: 8;
|
||||
colorScheme: hifi.colorSchemes.dark;
|
||||
from: 8.0;
|
||||
to: 120.0;
|
||||
value: (to - Settings.getValue("tabletCam/vFoV", 60.0) + from);
|
||||
stepSize: 1;
|
||||
|
||||
onValueChanged: {
|
||||
sendToScript({method: 'updateCameravFoV', vFoV: to - value + from});
|
||||
}
|
||||
onPressedChanged: {
|
||||
if (!pressed) {
|
||||
sendToScript({method: 'updateCameravFoV', vFoV: to - value + from});
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
id: takeSnapshotButton;
|
||||
color: "#EA4C5F";
|
||||
anchors.horizontalCenter: parent.horizontalCenter;
|
||||
anchors.verticalCenter: parent.verticalCenter;
|
||||
height: 72;
|
||||
width: height;
|
||||
radius: height;
|
||||
border.width: 3;
|
||||
border.color: hifi.colors.white;
|
||||
|
||||
MouseArea {
|
||||
anchors.fill: parent;
|
||||
hoverEnabled: true;
|
||||
onEntered: {
|
||||
parent.color = "#C62147";
|
||||
}
|
||||
onExited: {
|
||||
parent.color = "#EA4C5F";
|
||||
}
|
||||
onClicked: {
|
||||
if (HMD.tabletID !== "{00000000-0000-0000-0000-000000000000}") {
|
||||
secondaryCameraPreview.visible = false;
|
||||
}
|
||||
sendToScript({method: 'takePhoto'});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Image {
|
||||
visible: !HMD.active;
|
||||
source: "./images/orientation.svg"; // orientation by Atif Arshad from the Noun Project
|
||||
height: 24;
|
||||
width: height;
|
||||
anchors.left: takeSnapshotButton.right;
|
||||
anchors.leftMargin: 24;
|
||||
anchors.verticalCenter: parent.verticalCenter;
|
||||
|
||||
MouseArea {
|
||||
anchors.fill: parent;
|
||||
onClicked: {
|
||||
sendToScript({method: 'switchOrientation'});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
id: galleryButton;
|
||||
anchors.right: parent.right;
|
||||
anchors.rightMargin: 12;
|
||||
anchors.verticalCenter: parent.verticalCenter;
|
||||
height: 72;
|
||||
width: height;
|
||||
color: hifi.colors.black;
|
||||
|
||||
Image {
|
||||
id: galleryButtonImage;
|
||||
source: JSON.parse(Settings.getValue("tabletCam/cameraRollPaths", '{"paths": ["imagePath": ""]}')).paths[0].imagePath;
|
||||
fillMode: Image.PreserveAspectCrop;
|
||||
anchors.fill: parent;
|
||||
mipmap: true;
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
enabled: galleryButtonImage.source !== "";
|
||||
anchors.fill: parent;
|
||||
onClicked: {
|
||||
cameraRollSwipeView.setCurrentIndex(0);
|
||||
cameraRollModel.clear();
|
||||
|
||||
var settingsString = Settings.getValue("tabletCam/cameraRollPaths", '{"paths": []}');
|
||||
cameraRollModel.append(JSON.parse(settingsString).paths);
|
||||
|
||||
root.activeView = "reviewView";
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Item {
|
||||
id: reviewView;
|
||||
visible: root.activeView === "reviewView";
|
||||
anchors.fill: parent;
|
||||
|
||||
Rectangle {
|
||||
id: topBarContainer_review;
|
||||
width: parent.width;
|
||||
height: 42;
|
||||
anchors.left: parent.left;
|
||||
anchors.top: parent.top;
|
||||
color: "#121212";
|
||||
|
||||
HifiControlsUit.Button {
|
||||
text: "BACK";
|
||||
colorScheme: hifi.colorSchemes.dark;
|
||||
color: hifi.buttons.noneBorderlessWhite;
|
||||
anchors.verticalCenter: parent.verticalCenter;
|
||||
anchors.left: parent.left;
|
||||
anchors.leftMargin: 8;
|
||||
width: 50;
|
||||
height: 30;
|
||||
onClicked: {
|
||||
root.activeView = "mainView";
|
||||
}
|
||||
}
|
||||
|
||||
HifiStylesUit.RalewaySemiBold {
|
||||
text: "CAMERA ROLL";
|
||||
// Anchors
|
||||
anchors.horizontalCenter: parent.horizontalCenter;
|
||||
anchors.verticalCenter: parent.verticalCenter;
|
||||
size: 22;
|
||||
// Style
|
||||
color: hifi.colors.white;
|
||||
// Alignment
|
||||
horizontalAlignment: Text.AlignHCenter;
|
||||
verticalAlignment: Text.AlignVCenter;
|
||||
wrapMode: Text.Wrap;
|
||||
}
|
||||
}
|
||||
|
||||
ListModel {
|
||||
id: cameraRollModel;
|
||||
}
|
||||
|
||||
SwipeView {
|
||||
id: cameraRollSwipeView;
|
||||
|
||||
anchors.top: topBarContainer_review.bottom;
|
||||
anchors.left: parent.left;
|
||||
anchors.right: parent.right;
|
||||
anchors.bottom: bottomBarContainer_review.top;
|
||||
|
||||
Repeater {
|
||||
model: cameraRollModel;
|
||||
|
||||
Image {
|
||||
source: imagePath;
|
||||
fillMode: Image.PreserveAspectFit;
|
||||
mipmap: true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
PageIndicator {
|
||||
id: indicator;
|
||||
interactive: true;
|
||||
count: cameraRollSwipeView.count;
|
||||
currentIndex: cameraRollSwipeView.currentIndex
|
||||
|
||||
anchors.bottom: cameraRollSwipeView.bottom;
|
||||
anchors.horizontalCenter: cameraRollSwipeView.horizontalCenter;
|
||||
|
||||
delegate: Rectangle {
|
||||
implicitWidth: 15;
|
||||
implicitHeight: 15;
|
||||
radius: width;
|
||||
color: "#00b4ef";
|
||||
opacity: index === cameraRollSwipeView.currentIndex ? 0.95 : 0.45;
|
||||
|
||||
border.color: "#FFFFFF";
|
||||
border.width: index === cameraRollSwipeView.currentIndex ? 2 : 0;
|
||||
|
||||
Behavior on opacity {
|
||||
OpacityAnimator {
|
||||
duration: 100;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
id: bottomBarContainer_review;
|
||||
height: 88;
|
||||
anchors.left: parent.left;
|
||||
anchors.bottom: parent.bottom;
|
||||
anchors.right: parent.right;
|
||||
color: "#121212";
|
||||
|
||||
HifiControlsUit.Button {
|
||||
text: "SHOW IN DESKTOP FILE BROWSER";
|
||||
colorScheme: hifi.colorSchemes.dark;
|
||||
color: hifi.buttons.blue;
|
||||
anchors.verticalCenter: parent.verticalCenter;
|
||||
anchors.horizontalCenter: parent.horizontalCenter;
|
||||
width: 240;
|
||||
height: 30;
|
||||
onClicked: {
|
||||
var currentImagePath = cameraRollModel.get(cameraRollSwipeView.index).imagePath;
|
||||
Qt.openUrlExternally(currentImagePath.substring(0, currentImagePath.lastIndexOf('/')));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
id: settingsView;
|
||||
visible: root.activeView === "settingsView";
|
||||
anchors.fill: parent;
|
||||
color: hifi.colors.black;
|
||||
|
||||
Rectangle {
|
||||
id: topBarContainer_settings;
|
||||
width: parent.width;
|
||||
height: 42;
|
||||
anchors.left: parent.left;
|
||||
anchors.top: parent.top;
|
||||
color: "#121212";
|
||||
|
||||
HifiControlsUit.Button {
|
||||
text: "BACK";
|
||||
colorScheme: hifi.colorSchemes.dark;
|
||||
color: hifi.buttons.noneBorderlessWhite;
|
||||
anchors.verticalCenter: parent.verticalCenter;
|
||||
anchors.left: parent.left;
|
||||
anchors.leftMargin: 8;
|
||||
width: 50;
|
||||
height: 30;
|
||||
onClicked: {
|
||||
root.activeView = "mainView";
|
||||
}
|
||||
}
|
||||
|
||||
HifiStylesUit.RalewaySemiBold {
|
||||
text: "SETTINGS";
|
||||
// Anchors
|
||||
anchors.horizontalCenter: parent.horizontalCenter;
|
||||
anchors.verticalCenter: parent.verticalCenter;
|
||||
size: 22;
|
||||
// Style
|
||||
color: hifi.colors.white;
|
||||
// Alignment
|
||||
horizontalAlignment: Text.AlignHCenter;
|
||||
verticalAlignment: Text.AlignVCenter;
|
||||
wrapMode: Text.Wrap;
|
||||
}
|
||||
}
|
||||
|
||||
Item {
|
||||
id: settingsContainer;
|
||||
anchors.top: topBarContainer_settings.bottom;
|
||||
anchors.topMargin: 16;
|
||||
anchors.left: parent.left;
|
||||
anchors.leftMargin: 16;
|
||||
anchors.right: parent.right;
|
||||
anchors.rightMargin: 16;
|
||||
anchors.bottom: parent.bottom;
|
||||
anchors.bottomMargin: 8;
|
||||
|
||||
Item {
|
||||
id: qualityContainer;
|
||||
anchors.top: parent.top;
|
||||
anchors.left: parent.left;
|
||||
anchors.right: parent.right;
|
||||
height: childrenRect.height;
|
||||
|
||||
HifiStylesUit.RalewaySemiBold {
|
||||
id: qualityHeaderText;
|
||||
text: "Photo Quality";
|
||||
// Anchors
|
||||
anchors.left: parent.left;
|
||||
anchors.top: parent.top;
|
||||
height: 22;
|
||||
size: 18;
|
||||
// Style
|
||||
color: hifi.colors.white;
|
||||
// Alignment
|
||||
horizontalAlignment: Text.AlignLeft;
|
||||
verticalAlignment: Text.AlignTop;
|
||||
}
|
||||
|
||||
HifiControlsUit.RadioButton {
|
||||
id: lowRadioButton;
|
||||
checked: root.snapshotQuality === "low";
|
||||
text: "Low";
|
||||
width: 70;
|
||||
height: 35;
|
||||
anchors.left: parent.left;
|
||||
anchors.top: qualityHeaderText.bottom;
|
||||
colorScheme: hifi.colorSchemes.dark;
|
||||
onClicked: {
|
||||
if (!lowRadioButton.checked) {
|
||||
lowRadioButton.checked = true;
|
||||
}
|
||||
if (normalRadioButton.checked) {
|
||||
normalRadioButton.checked = false;
|
||||
}
|
||||
if (highRadioButton.checked) {
|
||||
highRadioButton.checked = false;
|
||||
}
|
||||
if (extremeRadioButton.checked) {
|
||||
extremeRadioButton.checked = false;
|
||||
}
|
||||
}
|
||||
onCheckedChanged: {
|
||||
if (checked) {
|
||||
sendToScript({method: 'setSnapshotQuality', quality: "low"});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
HifiControlsUit.RadioButton {
|
||||
id: normalRadioButton;
|
||||
checked: root.snapshotQuality === "normal";
|
||||
text: "Normal";
|
||||
width: 100;
|
||||
height: 35;
|
||||
anchors.left: lowRadioButton.right;
|
||||
anchors.leftMargin: 16;
|
||||
anchors.top: qualityHeaderText.bottom;
|
||||
colorScheme: hifi.colorSchemes.dark;
|
||||
onClicked: {
|
||||
if (lowRadioButton.checked) {
|
||||
lowRadioButton.checked = false;
|
||||
}
|
||||
if (!normalRadioButton.checked) {
|
||||
normalRadioButton.checked = true;
|
||||
}
|
||||
if (highRadioButton.checked) {
|
||||
highRadioButton.checked = false;
|
||||
}
|
||||
if (extremeRadioButton.checked) {
|
||||
extremeRadioButton.checked = false;
|
||||
}
|
||||
}
|
||||
onCheckedChanged: {
|
||||
if (checked) {
|
||||
sendToScript({method: 'setSnapshotQuality', quality: "normal"});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
HifiControlsUit.RadioButton {
|
||||
id: highRadioButton;
|
||||
checked: root.snapshotQuality === "high";
|
||||
text: "4k";
|
||||
width: 75;
|
||||
height: 35;
|
||||
anchors.left: normalRadioButton.right;
|
||||
anchors.leftMargin: 16;
|
||||
anchors.top: qualityHeaderText.bottom;
|
||||
colorScheme: hifi.colorSchemes.dark;
|
||||
onClicked: {
|
||||
if (lowRadioButton.checked) {
|
||||
lowRadioButton.checked = false;
|
||||
}
|
||||
if (normalRadioButton.checked) {
|
||||
normalRadioButton.checked = false;
|
||||
}
|
||||
if (!highRadioButton.checked) {
|
||||
highRadioButton.checked = true;
|
||||
}
|
||||
if (extremeRadioButton.checked) {
|
||||
extremeRadioButton.checked = false;
|
||||
}
|
||||
}
|
||||
onCheckedChanged: {
|
||||
if (checked) {
|
||||
sendToScript({method: 'setSnapshotQuality', quality: "high"});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
HifiControlsUit.RadioButton {
|
||||
id: extremeRadioButton;
|
||||
checked: root.snapshotQuality === "extreme";
|
||||
text: "EXTREME";
|
||||
width: 120;
|
||||
height: 35;
|
||||
anchors.left: highRadioButton.right;
|
||||
anchors.leftMargin: 16;
|
||||
anchors.top: qualityHeaderText.bottom;
|
||||
colorScheme: hifi.colorSchemes.dark;
|
||||
onClicked: {
|
||||
if (lowRadioButton.checked) {
|
||||
lowRadioButton.checked = false;
|
||||
}
|
||||
if (normalRadioButton.checked) {
|
||||
normalRadioButton.checked = false;
|
||||
}
|
||||
if (highRadioButton.checked) {
|
||||
highRadioButton.checked = false;
|
||||
}
|
||||
if (!extremeRadioButton.checked) {
|
||||
extremeRadioButton.checked = true;
|
||||
}
|
||||
}
|
||||
onCheckedChanged: {
|
||||
if (checked) {
|
||||
sendToScript({method: 'setSnapshotQuality', quality: "extreme"});
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Item {
|
||||
id: aspectRatioContainer;
|
||||
anchors.top: qualityContainer.bottom;
|
||||
anchors.topMargin: 16;
|
||||
anchors.left: parent.left;
|
||||
anchors.right: parent.right;
|
||||
height: childrenRect.height;
|
||||
|
||||
HifiStylesUit.RalewaySemiBold {
|
||||
id: aspectRatioHeaderText;
|
||||
text: "Aspect Ratio";
|
||||
// Anchors
|
||||
anchors.left: parent.left;
|
||||
anchors.top: parent.top;
|
||||
height: 22;
|
||||
size: 18;
|
||||
// Style
|
||||
color: hifi.colors.white;
|
||||
// Alignment
|
||||
horizontalAlignment: Text.AlignLeft;
|
||||
verticalAlignment: Text.AlignTop;
|
||||
}
|
||||
|
||||
HifiControlsUit.RadioButton {
|
||||
id: eightByTenRadioButton;
|
||||
checked: parseFloat(root.aspectRatio) === (8 / 10);
|
||||
text: "8x10";
|
||||
width: 70;
|
||||
height: 35;
|
||||
anchors.left: parent.left;
|
||||
anchors.top: aspectRatioHeaderText.bottom;
|
||||
colorScheme: hifi.colorSchemes.dark;
|
||||
onClicked: {
|
||||
if (!eightByTenRadioButton.checked) {
|
||||
eightByTenRadioButton.checked = true;
|
||||
}
|
||||
if (twoByThreeRadioButton.checked) {
|
||||
twoByThreeRadioButton.checked = false;
|
||||
}
|
||||
if (nineBySixteenRadioButton.checked) {
|
||||
nineBySixteenRadioButton.checked = false;
|
||||
}
|
||||
if (oneByOneRadioButton.checked) {
|
||||
oneByOneRadioButton.checked = false;
|
||||
}
|
||||
}
|
||||
onCheckedChanged: {
|
||||
if (checked) {
|
||||
sendToScript({method: 'setAspectRatio', aspectRatio: (8 / 10)});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
HifiControlsUit.RadioButton {
|
||||
id: twoByThreeRadioButton;
|
||||
checked: parseFloat(root.aspectRatio) === (2 / 3);
|
||||
text: "2x3";
|
||||
width: 100;
|
||||
height: 35;
|
||||
anchors.left: eightByTenRadioButton.right;
|
||||
anchors.leftMargin: 16;
|
||||
anchors.top: aspectRatioHeaderText.bottom;
|
||||
colorScheme: hifi.colorSchemes.dark;
|
||||
onClicked: {
|
||||
if (eightByTenRadioButton.checked) {
|
||||
eightByTenRadioButton.checked = false;
|
||||
}
|
||||
if (!twoByThreeRadioButton.checked) {
|
||||
twoByThreeRadioButton.checked = true;
|
||||
}
|
||||
if (nineBySixteenRadioButton.checked) {
|
||||
nineBySixteenRadioButton.checked = false;
|
||||
}
|
||||
if (oneByOneRadioButton.checked) {
|
||||
oneByOneRadioButton.checked = false;
|
||||
}
|
||||
}
|
||||
onCheckedChanged: {
|
||||
if (checked) {
|
||||
sendToScript({method: 'setAspectRatio', aspectRatio: (2 / 3)});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
HifiControlsUit.RadioButton {
|
||||
id: nineBySixteenRadioButton;
|
||||
checked: parseFloat(root.aspectRatio) === 9 / 16;
|
||||
text: "9x16";
|
||||
width: 75;
|
||||
height: 35;
|
||||
anchors.left: twoByThreeRadioButton.right;
|
||||
anchors.leftMargin: 16;
|
||||
anchors.top: aspectRatioHeaderText.bottom;
|
||||
colorScheme: hifi.colorSchemes.dark;
|
||||
onClicked: {
|
||||
if (eightByTenRadioButton.checked) {
|
||||
eightByTenRadioButton.checked = false;
|
||||
}
|
||||
if (twoByThreeRadioButton.checked) {
|
||||
twoByThreeRadioButton.checked = false;
|
||||
}
|
||||
if (!nineBySixteenRadioButton.checked) {
|
||||
nineBySixteenRadioButton.checked = true;
|
||||
}
|
||||
if (oneByOneRadioButton.checked) {
|
||||
oneByOneRadioButton.checked = false;
|
||||
}
|
||||
}
|
||||
onCheckedChanged: {
|
||||
if (checked) {
|
||||
sendToScript({method: 'setAspectRatio', aspectRatio: (9 / 16)});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
HifiControlsUit.RadioButton {
|
||||
id: oneByOneRadioButton;
|
||||
checked: parseFloat(root.aspectRatio) === 1 / 1;
|
||||
text: "Square";
|
||||
width: 83;
|
||||
height: 35;
|
||||
anchors.left: nineBySixteenRadioButton.right;
|
||||
anchors.leftMargin: 16;
|
||||
anchors.top: aspectRatioHeaderText.bottom;
|
||||
colorScheme: hifi.colorSchemes.dark;
|
||||
onClicked: {
|
||||
if (eightByTenRadioButton.checked) {
|
||||
eightByTenRadioButton.checked = false;
|
||||
}
|
||||
if (twoByThreeRadioButton.checked) {
|
||||
twoByThreeRadioButton.checked = false;
|
||||
}
|
||||
if (nineBySixteenRadioButton.checked) {
|
||||
nineBySixteenRadioButton.checked = false;
|
||||
}
|
||||
if (!oneByOneRadioButton.checked) {
|
||||
oneByOneRadioButton.checked = true;
|
||||
}
|
||||
}
|
||||
onCheckedChanged: {
|
||||
if (checked) {
|
||||
sendToScript({method: 'setAspectRatio', aspectRatio: 1});
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Item {
|
||||
id: photoDirectoryContainer;
|
||||
anchors.top: aspectRatioContainer.bottom;
|
||||
anchors.topMargin: 16;
|
||||
anchors.left: parent.left;
|
||||
anchors.right: parent.right;
|
||||
height: childrenRect.height;
|
||||
|
||||
HifiStylesUit.RalewaySemiBold {
|
||||
id: photoDirectoryHeaderText;
|
||||
text: "Photo Directory";
|
||||
// Anchors
|
||||
anchors.left: parent.left;
|
||||
anchors.top: parent.top;
|
||||
height: 22;
|
||||
size: 18;
|
||||
// Style
|
||||
color: hifi.colors.white;
|
||||
// Alignment
|
||||
horizontalAlignment: Text.AlignLeft;
|
||||
verticalAlignment: Text.AlignTop;
|
||||
}
|
||||
|
||||
HifiControlsUit.TextField {
|
||||
id: photoDirectoryTextField;
|
||||
readOnly: true;
|
||||
text: Settings.getValue("snapshotsDirectory", "<Not Set>");
|
||||
colorScheme: hifi.colorSchemes.dark;
|
||||
// Anchors
|
||||
anchors.top: photoDirectoryHeaderText.bottom;
|
||||
anchors.topMargin: 8;
|
||||
anchors.left: parent.left;
|
||||
anchors.right: parent.right;
|
||||
height: 50;
|
||||
|
||||
MouseArea {
|
||||
anchors.fill: parent;
|
||||
|
||||
onClicked: {
|
||||
sendToScript({method: 'setPhotoDirectory'});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
HifiControlsUit.Button {
|
||||
text: "CHANGE";
|
||||
colorScheme: hifi.colorSchemes.dark;
|
||||
color: hifi.buttons.blue;
|
||||
anchors.top: photoDirectoryTextField.bottom;
|
||||
anchors.topMargin: 4;
|
||||
anchors.right: parent.right;
|
||||
width: 100;
|
||||
height: 35;
|
||||
onClicked: {
|
||||
sendToScript({method: 'setPhotoDirectory'});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
HifiStylesUit.FiraSansRegular {
|
||||
text: "Hint:\nIn HMD, using the detached camera, you can press on the\nthumbsticks of your right controller to take a photo.\n\n\nv2.4";
|
||||
// Anchors
|
||||
anchors.bottom: parent.bottom;
|
||||
anchors.left: parent.left;
|
||||
size: 16;
|
||||
// Style
|
||||
color: hifi.colors.lightGrayText;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function fromScript(message) {
|
||||
switch (message.method) {
|
||||
case 'stillSnapshotTaken':
|
||||
Settings.setValue('tabletCam/firstRun', false);
|
||||
helpTextContainer.visible = false;
|
||||
galleryButtonImage.source = message.lastStillSnapshotPath;
|
||||
if (HMD.tabletID !== "{00000000-0000-0000-0000-000000000000}") {
|
||||
secondaryCameraPreview.visible = true;
|
||||
}
|
||||
break;
|
||||
case 'photoDirectoryChanged':
|
||||
photoDirectoryTextField.text = message.photoDirectory;
|
||||
break;
|
||||
case 'inspectionCertificate_resetCert':
|
||||
break;
|
||||
default:
|
||||
console.log('Unrecognized message from TabletCam.js.');
|
||||
}
|
||||
}
|
||||
signal sendToScript(var message);
|
||||
}
|
3
applications/tabletCam/ui/images/orientation.svg
Normal file
3
applications/tabletCam/ui/images/orientation.svg
Normal file
|
@ -0,0 +1,3 @@
|
|||
<svg enable-background="new 0 0 24 24" version="1.1" viewBox="0 0 23.732 22.154" xml:space="preserve" xmlns="http://www.w3.org/2000/svg"><g transform="translate(-.134 -.764)" fill="#fff"><path d="m9.544 19.319h-7.167c-1.237 0-2.243-1.007-2.243-2.243v-14.069c0-1.237 1.006-2.243 2.243-2.243h7.167c1.237 0 2.243 1.006 2.243 2.243v14.069c0 1.237-1.006 2.243-2.243 2.243zm-7.167-17.255c-0.52 0-0.943 0.423-0.943 0.943v14.069c0 0.52 0.423 0.942 0.943 0.942h7.167c0.52 0 0.943-0.423 0.943-0.942v-14.069c0-0.52-0.423-0.943-0.943-0.943z"/><path d="m11.137 5.515h-10.353c-0.359 0-0.65-0.291-0.65-0.65s0.291-0.65 0.65-0.65h10.353c0.359 0 0.65 0.291 0.65 0.65s-0.291 0.65-0.65 0.65z"/><path d="m11.137 15.735h-10.353c-0.359 0-0.65-0.291-0.65-0.65s0.291-0.65 0.65-0.65h10.353c0.359 0 0.65 0.291 0.65 0.65s-0.291 0.65-0.65 0.65z"/><path d="m21.623 22.918h-14.069c-1.237 0-2.243-1.007-2.243-2.243v-2.006c0-0.359 0.291-0.65 0.65-0.65s0.65 0.291 0.65 0.65v2.006c0 0.52 0.423 0.942 0.943 0.942h14.069c0.52 0 0.942-0.423 0.942-0.942v-7.167c0-0.52-0.423-0.942-0.942-0.942h-10.485c-0.359 0-0.65-0.292-0.65-0.65s0.291-0.65 0.65-0.65h10.485c1.236 0 2.243 1.006 2.243 2.243v7.167c0 1.235-1.007 2.242-2.243 2.242z"/><path d="m19.765 22.918c-0.359 0-0.65-0.291-0.65-0.65v-10.353c0-0.359 0.291-0.65 0.65-0.65s0.65 0.291 0.65 0.65v10.353c0 0.359-0.291 0.65-0.65 0.65z"/><path d="m9.545 22.54c-0.359 0-0.65-0.291-0.65-0.65v-3.221c0-0.359 0.291-0.65 0.65-0.65s0.65 0.291 0.65 0.65v3.221c0 0.359-0.291 0.65-0.65 0.65z"/></g><text x="-0.134" y="38.236" fill="#000000" font-family="'Helvetica Neue', Helvetica, Arial-Unicode, Arial, Sans-serif" font-size="5px" font-weight="bold">Created by Atif Arshad</text>
|
||||
<text x="-0.134" y="43.236" fill="#000000" font-family="'Helvetica Neue', Helvetica, Arial-Unicode, Arial, Sans-serif" font-size="5px" font-weight="bold">from the Noun Project</text>
|
||||
</svg>
|
After Width: | Height: | Size: 1.8 KiB |
9
applications/tabletCam/ui/images/switchCams.svg
Normal file
9
applications/tabletCam/ui/images/switchCams.svg
Normal file
|
@ -0,0 +1,9 @@
|
|||
<svg version="1.1" viewBox="0 0 73.497 73.571" xmlns="http://www.w3.org/2000/svg">
|
||||
<title>rotate-cam-3</title>
|
||||
<desc>Created with Sketch.</desc>
|
||||
<g transform="translate(-13,-13)" fill="#fff" fill-rule="evenodd">
|
||||
<path d="m54.548 48.979c0-2.654-2.158-4.813-4.812-4.813s-4.814 2.159-4.814 4.813c0 2.653 2.16 4.812 4.814 4.812s4.812-2.159 4.812-4.812zm4 0c0 4.859-3.953 8.813-8.812 8.813-4.86 0-8.814-3.954-8.814-8.813s3.954-8.813 8.814-8.813c4.859 0 8.812 3.954 8.812 8.813zm6.762-5.951c0-1.639-1.333-2.972-2.971-2.972h-2.418c-1.733 0-3.262-0.853-4.142-2.283l-1.101-1.78h-9.885l-1.105 1.785c-0.876 1.425-2.405 2.278-4.085 2.278h-2.47c-1.639 0-2.972 1.333-2.972 2.972v13.779c0 1.639 1.333 2.972 2.972 2.972h25.206c1.638 0 2.971-1.333 2.971-2.972zm4 0v13.779c0 3.844-3.127 6.972-6.971 6.972h-25.206c-3.844 0-6.972-3.128-6.972-6.972v-13.779c0-3.844 3.128-6.972 6.972-6.972h2.417c0.333 0 0.588-0.141 0.733-0.379l1.696-2.737c0.364-0.589 1.007-0.947 1.7-0.947h12.113c0.693 0 1.336 0.358 1.7 0.947l1.692 2.732c0.149 0.243 0.404 0.384 0.684 0.384h2.471c3.844 0 6.971 3.128 6.971 6.972zm9.049-16.349c-7.008-8.694-17.433-13.679-28.605-13.679h-0.018c-3.411 0-6.802 0.475-10.081 1.411-1.062 0.302-1.677 1.409-1.374 2.471 0.302 1.062 1.407 1.679 2.472 1.374 2.921-0.833 5.943-1.256 8.984-1.256h0.016c9.956 0 19.247 4.443 25.492 12.189 5.487 6.806 7.994 15.341 7.061 24.034-0.774 7.207-3.841 13.802-8.743 18.975l1e-3 -5.235c0-1.104-0.896-2-2-2-1.105 0-2 0.896-2 2l-2e-3 9.805c0 0.028 7e-3 0.055 7e-3 0.082 3e-3 0.07 0.012 0.139 0.022 0.208 9e-3 0.064 0.02 0.126 0.034 0.187 0.015 0.061 0.035 0.121 0.056 0.181 0.023 0.066 0.047 0.13 0.077 0.193 0.024 0.051 0.053 0.101 0.082 0.151 0.038 0.066 0.079 0.13 0.124 0.19 0.016 0.021 0.025 0.043 0.041 0.063 0.018 0.021 0.039 0.036 0.057 0.057 0.063 0.072 0.132 0.138 0.205 0.201 0.038 0.033 0.076 0.066 0.116 0.096 0.076 0.056 0.157 0.103 0.241 0.148 0.04 0.021 0.078 0.046 0.119 0.064 0.099 0.045 0.202 0.077 0.309 0.106 0.029 8e-3 0.058 0.02 0.088 0.027 0.136 0.028 0.276 0.046 0.421 0.046l9.799 3e-3h1e-3c1.105 0 2-0.896 2-1.999 0-1.105-0.894-2.001-1.999-2.001l-4.724-1e-3c5.406-5.778 8.786-13.113 9.645-21.12 1.047-9.756-1.767-19.334-7.924-26.971zm-17.167 55.995c0.303 1.063-0.312 2.169-1.373 2.473-3.354 0.959-6.763 1.424-10.133 1.424-10.93 0-21.476-4.888-28.572-13.693-11.6-14.39-10.532-34.945 1.733-48.089l-4.738-1e-3c-1.105 0-1.999-0.897-1.999-2.001s0.895-1.999 2-1.999l9.805 3e-3c0.033 0 0.067 7e-3 0.1 9e-3 0.069 4e-3 0.137 0.01 0.206 0.021 0.06 0.01 0.119 0.021 0.179 0.037 0.066 0.016 0.13 0.035 0.195 0.059 0.057 0.021 0.112 0.043 0.168 0.07 0.061 0.029 0.121 0.06 0.181 0.096 0.053 0.033 0.105 0.068 0.156 0.105 0.052 0.039 0.103 0.081 0.153 0.126 0.024 0.022 0.053 0.039 0.076 0.062 0.027 0.027 0.046 0.059 0.071 0.086 0.023 0.026 0.049 0.046 0.071 0.073 0.018 0.023 0.03 0.049 0.048 0.073 0.042 0.057 0.079 0.115 0.114 0.176 0.033 0.055 0.063 0.112 0.091 0.17 0.027 0.058 0.049 0.117 0.07 0.177 0.023 0.064 0.043 0.128 0.059 0.194 0.014 0.059 0.024 0.12 0.033 0.18 0.01 0.069 0.017 0.135 0.019 0.203 2e-3 0.028 9e-3 0.055 9e-3 0.084l-5e-3 9.804c-1e-3 1.105-0.895 1.999-2 1.999h-1e-3c-1.104-1e-3 -2-0.896-1.999-2.001l3e-3 -5.223c-11.058 11.706-12.063 30.121-1.683 42.998 8.274 10.264 21.813 14.555 34.49 10.932 1.063-0.305 2.17 0.312 2.473 1.373z" fill="#fff"/>
|
||||
</g>
|
||||
<text x="-13" y="102" fill="#000000" font-family="'Helvetica Neue', Helvetica, Arial-Unicode, Arial, Sans-serif" font-size="5px" font-weight="bold">Created by Diego Naive</text>
|
||||
<text x="-13" y="107" fill="#000000" font-family="'Helvetica Neue', Helvetica, Arial-Unicode, Arial, Sans-serif" font-size="5px" font-weight="bold">from the Noun Project</text>
|
||||
</svg>
|
After Width: | Height: | Size: 3.6 KiB |
Loading…
Reference in a new issue