Compare commits
135 Commits
v16-0-0-RC
...
16.0.0-RC4
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
0a4560ea95 | ||
|
|
b44db21714 | ||
|
|
34796ed091 | ||
|
|
a46dfd1c23 | ||
|
|
32eb583036 | ||
|
|
6ee83b8413 | ||
|
|
f034232f36 | ||
|
|
b80e43dfe9 | ||
|
|
40c7c253ea | ||
|
|
d11b312a96 | ||
|
|
2c1e531ed2 | ||
|
|
c352e539bc | ||
|
|
a0333d906f | ||
|
|
ec00e943da | ||
|
|
6175471a00 | ||
|
|
948e76876f | ||
|
|
f4edb206d8 | ||
|
|
a9db769595 | ||
|
|
f0497eb924 | ||
|
|
e53af6de0d | ||
|
|
3b7fe93d02 | ||
|
|
2f1d7e577c | ||
|
|
2a7247abfe | ||
|
|
37ba85717f | ||
|
|
97656114b6 | ||
|
|
6cf1d5ad98 | ||
|
|
fed729bcee | ||
|
|
89c36374b3 | ||
|
|
bb69929247 | ||
|
|
e1ea09c501 | ||
|
|
39a827258d | ||
|
|
1d8c6fa257 | ||
|
|
a9aadbdb06 | ||
|
|
a5927f98d2 | ||
|
|
c708e2374a | ||
|
|
4c3dcd8c29 | ||
|
|
be93567956 | ||
|
|
d4406f47ea | ||
|
|
52efedcfa0 | ||
|
|
28d93253f0 | ||
|
|
c7fdc46df2 | ||
|
|
74491e9bde | ||
|
|
a092142c65 | ||
|
|
f6a3dc5851 | ||
|
|
d027adf006 | ||
|
|
bd5be5c5ec | ||
|
|
3b3a3ebcc9 | ||
|
|
7d62cf67fe | ||
|
|
f6bdd48bca | ||
|
|
5496573369 | ||
|
|
4522ba087f | ||
|
|
d370ba5fe6 | ||
|
|
f39dacc1c5 | ||
|
|
aad1a0e78d | ||
|
|
276efef783 | ||
|
|
79476a8458 | ||
|
|
2b7da5b44e | ||
|
|
ebcec97d1d | ||
|
|
85375b6505 | ||
|
|
085c47b651 | ||
|
|
20a04b888f | ||
|
|
098b1bd025 | ||
|
|
d1c815ce69 | ||
|
|
67c3020d7d | ||
|
|
61bca4ebb8 | ||
|
|
3219202c53 | ||
|
|
cd29690b96 | ||
|
|
3a34564ee2 | ||
|
|
174743ae7f | ||
|
|
e5eca6a53f | ||
|
|
d8e37dce48 | ||
|
|
822753bb4f | ||
|
|
7225792b4b | ||
|
|
b4f6b1a4fb | ||
|
|
21ec58daa0 | ||
|
|
2c69e90fac | ||
|
|
5c57522b71 | ||
|
|
f8eb4db171 | ||
|
|
c9a3df4eec | ||
|
|
acf669900f | ||
|
|
cb3f082218 | ||
|
|
20980b2bcd | ||
|
|
773d21a875 | ||
|
|
3a9c9ac2a4 | ||
|
|
c7e340d3a5 | ||
|
|
0441753a33 | ||
|
|
fb6cb44728 | ||
|
|
ae69942dd9 | ||
|
|
65437727f7 | ||
|
|
ccefe57795 | ||
|
|
e3ff049720 | ||
|
|
39e84baf8b | ||
|
|
eb7d078a1a | ||
|
|
b6c6805a08 | ||
|
|
d567a5d7f2 | ||
|
|
6922970185 | ||
|
|
9a4b51d6de | ||
|
|
2546ab81ff | ||
|
|
7b7544079f | ||
|
|
17fe87b349 | ||
|
|
f99dc8fdfc | ||
|
|
cce992754c | ||
|
|
eefccf6e11 | ||
|
|
64bb4f0ff6 | ||
|
|
f534741205 | ||
|
|
ee38bc7dc6 | ||
|
|
132834c3fd | ||
|
|
d3d9c64f3b | ||
|
|
aa2a4edf7e | ||
|
|
8012b7f43e | ||
|
|
009ab4c896 | ||
|
|
c54ca18e4e | ||
|
|
beb09593eb | ||
|
|
1a76ae121c | ||
|
|
1300242d4a | ||
|
|
79543df23b | ||
|
|
4049d752ba | ||
|
|
dc90972659 | ||
|
|
32282ecfe2 | ||
|
|
ae6a94544b | ||
|
|
70b031eacc | ||
|
|
c3fadf5c2a | ||
|
|
7e5f6bf4a5 | ||
|
|
88b531ae8b | ||
|
|
8481cc4b26 | ||
|
|
ecaed38c1d | ||
|
|
d6a1838d47 | ||
|
|
5194c466be | ||
|
|
043de9265a | ||
|
|
08a350172d | ||
|
|
7e806df64d | ||
|
|
dccfb5e91e | ||
|
|
fbe4609bb9 | ||
|
|
3e85cfb456 | ||
|
|
5dff4ca8cf |
56
.github/workflows/build.yaml
vendored
@@ -53,6 +53,7 @@ jobs:
|
|||||||
./code/.pio/build/esp32cam/partitions.bin
|
./code/.pio/build/esp32cam/partitions.bin
|
||||||
./code/.pio/build/esp32cam/bootloader.bin
|
./code/.pio/build/esp32cam/bootloader.bin
|
||||||
./html/*
|
./html/*
|
||||||
|
./demo/*
|
||||||
key: generated-files-${{ github.run_id }}
|
key: generated-files-${{ github.run_id }}
|
||||||
restore-keys: generated-files # This matches above key as it is only used as a prefix. it the restores the nearest cache, see https://github.com/restore-keys:/blob/main/tips-and-workarounds.md#update-a-cache
|
restore-keys: generated-files # This matches above key as it is only used as a prefix. it the restores the nearest cache, see https://github.com/restore-keys:/blob/main/tips-and-workarounds.md#update-a-cache
|
||||||
|
|
||||||
@@ -87,6 +88,11 @@ jobs:
|
|||||||
echo "Replacing variables..."
|
echo "Replacing variables..."
|
||||||
cd html; find . -type f -exec sed -i 's/$COMMIT_HASH/${{ steps.vars.outputs.sha_short }}/g' {} \;
|
cd html; find . -type f -exec sed -i 's/$COMMIT_HASH/${{ steps.vars.outputs.sha_short }}/g' {} \;
|
||||||
|
|
||||||
|
- name: Prepare Demo mode files
|
||||||
|
run: |
|
||||||
|
rm -rf ./demo
|
||||||
|
mkdir demo
|
||||||
|
cp -r ./sd-card/demo/* ./demo/
|
||||||
|
|
||||||
#########################################################################################
|
#########################################################################################
|
||||||
## Pack for Update
|
## Pack for Update
|
||||||
@@ -97,6 +103,7 @@ jobs:
|
|||||||
# - /firmware.bin
|
# - /firmware.bin
|
||||||
# - (optional) /html/* (inkl. subfolders)
|
# - (optional) /html/* (inkl. subfolders)
|
||||||
# - (optional) /config/*.tfl
|
# - (optional) /config/*.tfl
|
||||||
|
# - (optional) /demo/*
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
needs: build
|
needs: build
|
||||||
|
|
||||||
@@ -111,6 +118,7 @@ jobs:
|
|||||||
./code/.pio/build/esp32cam/partitions.bin
|
./code/.pio/build/esp32cam/partitions.bin
|
||||||
./code/.pio/build/esp32cam/bootloader.bin
|
./code/.pio/build/esp32cam/bootloader.bin
|
||||||
./html/*
|
./html/*
|
||||||
|
./demo/*
|
||||||
key: generated-files-${{ github.run_id }}
|
key: generated-files-${{ github.run_id }}
|
||||||
restore-keys: generated-files # This matches above key as it is only used as a prefix. it the restores the nearest cache, see https://github.com/restore-keys:/blob/main/tips-and-workarounds.md#update-a-cache
|
restore-keys: generated-files # This matches above key as it is only used as a prefix. it the restores the nearest cache, see https://github.com/restore-keys:/blob/main/tips-and-workarounds.md#update-a-cache
|
||||||
|
|
||||||
@@ -135,6 +143,9 @@ jobs:
|
|||||||
|
|
||||||
- name: Add Web UI to update
|
- name: Add Web UI to update
|
||||||
run: cp -r ./html ./update/
|
run: cp -r ./html ./update/
|
||||||
|
|
||||||
|
- name: Add Demo mode files to update
|
||||||
|
run: cp -r ./demo ./update/
|
||||||
|
|
||||||
- name: Add CNN to update
|
- name: Add CNN to update
|
||||||
run: |
|
run: |
|
||||||
@@ -158,6 +169,7 @@ jobs:
|
|||||||
# remote_setup__version.zip file with following content:
|
# remote_setup__version.zip file with following content:
|
||||||
# - /firmware.bin
|
# - /firmware.bin
|
||||||
# - /html/* (inkl. subfolders)
|
# - /html/* (inkl. subfolders)
|
||||||
|
# - /demo/*
|
||||||
# - /config/*
|
# - /config/*
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
needs: build
|
needs: build
|
||||||
@@ -173,6 +185,7 @@ jobs:
|
|||||||
./code/.pio/build/esp32cam/partitions.bin
|
./code/.pio/build/esp32cam/partitions.bin
|
||||||
./code/.pio/build/esp32cam/bootloader.bin
|
./code/.pio/build/esp32cam/bootloader.bin
|
||||||
./html/*
|
./html/*
|
||||||
|
./demo/*
|
||||||
key: generated-files-${{ github.run_id }}
|
key: generated-files-${{ github.run_id }}
|
||||||
restore-keys: generated-files # This matches above key as it is only used as a prefix. it the restores the nearest cache, see https://github.com/restore-keys:/blob/main/tips-and-workarounds.md#update-a-cache
|
restore-keys: generated-files # This matches above key as it is only used as a prefix. it the restores the nearest cache, see https://github.com/restore-keys:/blob/main/tips-and-workarounds.md#update-a-cache
|
||||||
|
|
||||||
@@ -197,6 +210,9 @@ jobs:
|
|||||||
- name: Add Web UI to remote_setup
|
- name: Add Web UI to remote_setup
|
||||||
run: cp -r ./html ./remote_setup/
|
run: cp -r ./html ./remote_setup/
|
||||||
|
|
||||||
|
- name: Add Demo mode files to update
|
||||||
|
run: cp -r ./demo ./update/
|
||||||
|
|
||||||
- name: Add whole config folder to remote_setup
|
- name: Add whole config folder to remote_setup
|
||||||
run: |
|
run: |
|
||||||
rm -rf ./remote_setup/config/
|
rm -rf ./remote_setup/config/
|
||||||
@@ -229,6 +245,7 @@ jobs:
|
|||||||
./code/.pio/build/esp32cam/partitions.bin
|
./code/.pio/build/esp32cam/partitions.bin
|
||||||
./code/.pio/build/esp32cam/bootloader.bin
|
./code/.pio/build/esp32cam/bootloader.bin
|
||||||
./html/*
|
./html/*
|
||||||
|
./demo/*
|
||||||
key: generated-files-${{ github.run_id }}
|
key: generated-files-${{ github.run_id }}
|
||||||
restore-keys: generated-files # This matches above key as it is only used as a prefix. it the restores the nearest cache, see https://github.com/restore-keys:/blob/main/tips-and-workarounds.md#update-a-cache
|
restore-keys: generated-files # This matches above key as it is only used as a prefix. it the restores the nearest cache, see https://github.com/restore-keys:/blob/main/tips-and-workarounds.md#update-a-cache
|
||||||
|
|
||||||
@@ -257,7 +274,9 @@ jobs:
|
|||||||
cp -f "./code/.pio/build/esp32cam/bootloader.bin" "manual_setup/bootloader.bin"
|
cp -f "./code/.pio/build/esp32cam/bootloader.bin" "manual_setup/bootloader.bin"
|
||||||
cp -f "./code/.pio/build/esp32cam/partitions.bin" "manual_setup/partitions.bin"
|
cp -f "./code/.pio/build/esp32cam/partitions.bin" "manual_setup/partitions.bin"
|
||||||
rm -rf ./sd-card/html
|
rm -rf ./sd-card/html
|
||||||
|
rm -rf ./sd-card/demo
|
||||||
cp -r ./html ./sd-card/ # Overwrite the Web UI with the preprocessed files
|
cp -r ./html ./sd-card/ # Overwrite the Web UI with the preprocessed files
|
||||||
|
cp -r ./demo ./sd-card/
|
||||||
cd sd-card; zip -r ../manual_setup/sd-card.zip *; cd ..
|
cd sd-card; zip -r ../manual_setup/sd-card.zip *; cd ..
|
||||||
cd ./manual_setup
|
cd ./manual_setup
|
||||||
|
|
||||||
@@ -271,7 +290,7 @@ jobs:
|
|||||||
#########################################################################################
|
#########################################################################################
|
||||||
## Prepare and create release
|
## Prepare and create release
|
||||||
#########################################################################################
|
#########################################################################################
|
||||||
release:
|
prepare-release:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
needs: [pack-for-update, pack-for-manual_setup, pack-for-remote_setup]
|
needs: [pack-for-update, pack-for-manual_setup, pack-for-remote_setup]
|
||||||
if: startsWith(github.ref, 'refs/tags/')
|
if: startsWith(github.ref, 'refs/tags/')
|
||||||
@@ -331,13 +350,11 @@ jobs:
|
|||||||
|
|
||||||
# extract the version used in next step
|
# extract the version used in next step
|
||||||
- id: get_version
|
- id: get_version
|
||||||
if: startsWith(github.ref, 'refs/tags/')
|
uses: drewg13/get-version-action@98dda2a47a257e202c2e6c2ed2e6072ec23f448e
|
||||||
uses: Simply007/get-version-action@v2
|
|
||||||
|
|
||||||
# # the changelog [unreleased] will now be changed to the release version
|
# # the changelog [unreleased] will now be changed to the release version
|
||||||
# - name: Update changelog
|
# - name: Update changelog
|
||||||
# uses: thomaseizinger/keep-a-changelog-new-release@v1
|
# uses: thomaseizinger/keep-a-changelog-new-release@v1
|
||||||
# if: startsWith(github.ref, 'refs/tags/')
|
|
||||||
# with:
|
# with:
|
||||||
# changelogPath: Changelog.md
|
# changelogPath: Changelog.md
|
||||||
# version: ${{ steps.get_version.outputs.version-without-v }}
|
# version: ${{ steps.get_version.outputs.version-without-v }}
|
||||||
@@ -345,7 +362,6 @@ jobs:
|
|||||||
# # the release notes will be extracted from changelog
|
# # the release notes will be extracted from changelog
|
||||||
# - name: Extract release notes
|
# - name: Extract release notes
|
||||||
# id: extract-release-notes
|
# id: extract-release-notes
|
||||||
# if: startsWith(github.ref, 'refs/tags/')
|
|
||||||
# uses: ffurrer2/extract-release-notes@v1
|
# uses: ffurrer2/extract-release-notes@v1
|
||||||
# with:
|
# with:
|
||||||
# changelog_file: Changelog.md
|
# changelog_file: Changelog.md
|
||||||
@@ -353,12 +369,11 @@ jobs:
|
|||||||
# Releases should only be created on master by tagging the last commit.
|
# Releases should only be created on master by tagging the last commit.
|
||||||
# all artifacts in firmware folder pushed to the release
|
# all artifacts in firmware folder pushed to the release
|
||||||
- name: Release
|
- name: Release
|
||||||
uses: softprops/action-gh-release@v1
|
uses: softprops/action-gh-release@v2.0.8
|
||||||
# Note:
|
# Note:
|
||||||
# If you get the error "Resource not accessible by integration",
|
# If you get the error "Resource not accessible by integration",
|
||||||
# The access rights are not sufficient, see
|
# The access rights are not sufficient, see
|
||||||
# https://github.com/softprops/action-gh-release/issues/232#issuecomment-1131379440
|
# https://github.com/softprops/action-gh-release/issues/232#issuecomment-1131379440
|
||||||
if: startsWith(github.ref, 'refs/tags/')
|
|
||||||
with:
|
with:
|
||||||
name: ${{ steps.get_version.outputs.version-without-v }}
|
name: ${{ steps.get_version.outputs.version-without-v }}
|
||||||
body: ${{ steps.extract-release-notes.outputs.release_notes }}
|
body: ${{ steps.extract-release-notes.outputs.release_notes }}
|
||||||
@@ -367,7 +382,6 @@ jobs:
|
|||||||
|
|
||||||
# # Commit&Push Changelog to master branch. Must be manually merged back to rolling
|
# # Commit&Push Changelog to master branch. Must be manually merged back to rolling
|
||||||
# - name: Commit changes and push changes
|
# - name: Commit changes and push changes
|
||||||
# if: startsWith(github.ref, 'refs/tags/')
|
|
||||||
# run: |
|
# run: |
|
||||||
# git config user.name github-actions
|
# git config user.name github-actions
|
||||||
# git config user.email github-actions@github.com
|
# git config user.email github-actions@github.com
|
||||||
@@ -376,12 +390,34 @@ jobs:
|
|||||||
# git push origin HEAD:master
|
# git push origin HEAD:master
|
||||||
|
|
||||||
|
|
||||||
|
#########################################################################################
|
||||||
|
## Update Contributors List in README.md on a release
|
||||||
|
#########################################################################################
|
||||||
|
contrib-readme-job:
|
||||||
|
if: github.event_name == 'release' && github.event.action == 'published' # Only run on release but not on prerelease
|
||||||
|
needs: [prepare-release]
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
permissions:
|
||||||
|
contents: write
|
||||||
|
pull-requests: write
|
||||||
|
steps:
|
||||||
|
- name: Contribute List
|
||||||
|
uses: akhilmhdh/contributors-readme-action@v2.3.10
|
||||||
|
with:
|
||||||
|
image_size: 50
|
||||||
|
use_username: true
|
||||||
|
columns_per_row: 8
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
|
||||||
|
|
||||||
#########################################################################################
|
#########################################################################################
|
||||||
## Update the Web Installer on a release
|
## Update the Web Installer on a release
|
||||||
#########################################################################################
|
#########################################################################################
|
||||||
# Make sure to also update update-webinstaller.yml!
|
# Make sure to also update update-webinstaller.yml!
|
||||||
update-web-installer:
|
update-web-installer:
|
||||||
needs: [release]
|
if: github.event_name == 'release' && github.event.action == 'published' # Only run on release but not on prerelease
|
||||||
|
needs: [prepare-release]
|
||||||
environment:
|
environment:
|
||||||
name: github-pages
|
name: github-pages
|
||||||
url: ${{ steps.deployment.outputs.page_url }}
|
url: ${{ steps.deployment.outputs.page_url }}
|
||||||
|
|||||||
57
Changelog.md
@@ -1,3 +1,60 @@
|
|||||||
|
## [16.0.0-RC4] - 2024-10-06
|
||||||
|
|
||||||
|
For a full list of changes see [Full list of changes](https://github.com/jomjol/AI-on-the-edge-device/compare/v15.7.0...v16.0.0-RC1)
|
||||||
|
|
||||||
|
#### Known issues
|
||||||
|
Please check the [issues](https://github.com/jomjol/AI-on-the-edge-device/issues) and
|
||||||
|
[discussions](https://github.com/jomjol/AI-on-the-edge-device/discussions) before reporting a new issue.
|
||||||
|
|
||||||
|
#### Core Changes
|
||||||
|
Only changes since RC2 are listed:
|
||||||
|
- Update esp32-camera submodule to `v2.0.13` (#3316)
|
||||||
|
- Added contributor list (#3317)
|
||||||
|
- Added files for demo mode (#3315)
|
||||||
|
|
||||||
|
#### Bug Fixes
|
||||||
|
Only changes since RC2 are listed:
|
||||||
|
- Added delay in InitCam (#3313) to fix `Camera not detected` issues
|
||||||
|
|
||||||
|
|
||||||
|
## [16.0.0-RC3] - 2024-10-05
|
||||||
|
|
||||||
|
For a full list of changes see [Full list of changes](https://github.com/jomjol/AI-on-the-edge-device/compare/v15.7.0...v16.0.0-RC1)
|
||||||
|
|
||||||
|
#### Known issues
|
||||||
|
Please check the [issues](https://github.com/jomjol/AI-on-the-edge-device/issues) and
|
||||||
|
[discussions](https://github.com/jomjol/AI-on-the-edge-device/discussions) before reporting a new issue.
|
||||||
|
|
||||||
|
#### Core Changes
|
||||||
|
Only changes since RC2 are listed:
|
||||||
|
- Renamed MQTT topic from `rate_per_digitalization_round` to `rate_per_digitization_round` (change happened already in RC1)
|
||||||
|
|
||||||
|
#### Bug Fixes
|
||||||
|
Only changes since RC2 are listed:
|
||||||
|
- Re-did revertion of TFlite submodule update as certain modules crash with it (#3269) (change was lost)
|
||||||
|
|
||||||
|
|
||||||
|
## [16.0.0-RC2] - 2024-10-04
|
||||||
|
|
||||||
|
For a full list of changes see [Full list of changes](https://github.com/jomjol/AI-on-the-edge-device/compare/v15.7.0...v16.0.0-RC1)
|
||||||
|
|
||||||
|
#### Known issues
|
||||||
|
Please check the [issues](https://github.com/jomjol/AI-on-the-edge-device/issues) and
|
||||||
|
[discussions](https://github.com/jomjol/AI-on-the-edge-device/discussions) before reporting a new issue.
|
||||||
|
|
||||||
|
#### Core Changes
|
||||||
|
Only changes since RC1 are listed:
|
||||||
|
- Updated parameter documentation pages
|
||||||
|
- Rename/remove unused parameters (#3291)
|
||||||
|
- Migrate-cam-parameters (#3288)
|
||||||
|
|
||||||
|
#### Bug Fixes
|
||||||
|
Only changes since RC1 are listed:
|
||||||
|
- Reverted TFlite submodule update as certain modules crash with it (#3269)
|
||||||
|
- Changed the webhook UploadImg to false (#3279)
|
||||||
|
- Changed default value from boolean to numeric value in parameter camDenoise documentation
|
||||||
|
- Updated config page
|
||||||
|
|
||||||
## [16.0.0-RC1] - 2024-09-24
|
## [16.0.0-RC1] - 2024-09-24
|
||||||
|
|
||||||
For a full list of changes see [Full list of changes](https://github.com/jomjol/AI-on-the-edge-device/compare/v15.7.0...v16.0.0-RC1)
|
For a full list of changes see [Full list of changes](https://github.com/jomjol/AI-on-the-edge-device/compare/v15.7.0...v16.0.0-RC1)
|
||||||
|
|||||||
21
README.md
@@ -2,11 +2,11 @@
|
|||||||
<img src="images/icon/watermeter.svg" width="100px">
|
<img src="images/icon/watermeter.svg" width="100px">
|
||||||
|
|
||||||
Artificial intelligence based systems have become established in our everyday lives. Just think of speech or image recognition. Most of the systems rely on either powerful processors or a direct connection to the cloud for doing the calculations there. With the increasing power of modern processors, the AI systems are coming closer to the end user – which is usually called **edge computing**.
|
Artificial intelligence based systems have become established in our everyday lives. Just think of speech or image recognition. Most of the systems rely on either powerful processors or a direct connection to the cloud for doing the calculations there. With the increasing power of modern processors, the AI systems are coming closer to the end user – which is usually called **edge computing**.
|
||||||
Here, this edge computing is put into a practically oriented example, where an AI network is implemented on an ESP32 device so: **AI on the edge**.
|
In this project, edge computing is demonstrated through a practical example, where an AI network is implemented on an ESP32 device, hence: **AI on the edge**.
|
||||||
|
|
||||||
This project allows you to digitize your **analog** water, gas, power and other meters using cheap and easily available hardware.
|
This project allows you to digitize your **analog** water, gas, power and other meters using cheap and easily available hardware.
|
||||||
|
|
||||||
All you need is an [ESP32 board with a supported camera](https://jomjol.github.io/AI-on-the-edge-device-docs/Hardware-Compatibility/) and something of a practical hand.
|
All you need is an [ESP32 board with a supported camera](https://jomjol.github.io/AI-on-the-edge-device-docs/Hardware-Compatibility/) and some practical skills.
|
||||||
|
|
||||||
<img src="images/esp32-cam.png" width="200px">
|
<img src="images/esp32-cam.png" width="200px">
|
||||||
|
|
||||||
@@ -17,13 +17,13 @@ All you need is an [ESP32 board with a supported camera](https://jomjol.github.i
|
|||||||
- Integrated camera and illumination
|
- Integrated camera and illumination
|
||||||
- Web interface for administration and control
|
- Web interface for administration and control
|
||||||
- OTA interface for updating directly via the web interface
|
- OTA interface for updating directly via the web interface
|
||||||
- Full integration into Homeassistant
|
- Full integration with Home Assistant
|
||||||
- Support for Influx DB 1 and 2
|
- Support for Influx DB 1 and 2
|
||||||
- MQTT
|
- MQTT
|
||||||
- REST API
|
- REST API
|
||||||
|
|
||||||
## Workflow
|
## Workflow
|
||||||
The device takes a photo of your meter at a defined interval. It then extracts the Regions of Interest (ROIs) from the image and runs them through artificial intelligence. As a result, you get the digitized value of your meter.
|
The device captures a photo of your meter at set intervals. It then extracts the Regions of Interest (ROIs) from the image and runs them through artificial intelligence. As a result, you get the digitized value of your meter.
|
||||||
|
|
||||||
There are several options for what to do with that value. Either send it to an MQTT broker, write it to an InfluxDb or simply provide access to it via a REST API.
|
There are several options for what to do with that value. Either send it to an MQTT broker, write it to an InfluxDb or simply provide access to it via a REST API.
|
||||||
|
|
||||||
@@ -65,7 +65,7 @@ The latest available version can be found on the [Releases page](https://github.
|
|||||||
Initially you will have to flash the ESP32 via a USB connection. Later updates are possible directly over the air (OTA using WIFI).
|
Initially you will have to flash the ESP32 via a USB connection. Later updates are possible directly over the air (OTA using WIFI).
|
||||||
|
|
||||||
There are different ways to flash your ESP32:
|
There are different ways to flash your ESP32:
|
||||||
- The prefered way is the [Web Installer and Console](https://jomjol.github.io/AI-on-the-edge-device/index.html) which is a browser-based tool to flash the ESP32 and extract the log over USB:
|
- The preferred way is the [Web Installer and Console](https://jomjol.github.io/AI-on-the-edge-device/index.html) which is a browser-based tool to flash the ESP32 and extract the log over USB:
|
||||||

|

|
||||||
- Flash Tool from Espressif
|
- Flash Tool from Espressif
|
||||||
- ESPtool (command-line tool)
|
- ESPtool (command-line tool)
|
||||||
@@ -74,7 +74,7 @@ See the [documentation](https://jomjol.github.io/AI-on-the-edge-device-docs/Inst
|
|||||||
|
|
||||||
### Flashing the SD Card
|
### Flashing the SD Card
|
||||||
The SD card can be setup automatically after the firmware got installed. See the [documentation](https://jomjol.github.io/AI-on-the-edge-device-docs/Installation/#remote-setup-using-the-built-in-access-point) for details. For this to work, the SD card must be FAT formated (which is the default on a new SD card).
|
The SD card can be setup automatically after the firmware got installed. See the [documentation](https://jomjol.github.io/AI-on-the-edge-device-docs/Installation/#remote-setup-using-the-built-in-access-point) for details. For this to work, the SD card must be FAT formated (which is the default on a new SD card).
|
||||||
Alternatively the SD card still can be setup manually, see the [documentation](https://jomjol.github.io/AI-on-the-edge-device-docs/Installation/#3-sd-card) for details!
|
Alternatively, the SD card still can be set up manually, see the [documentation](https://jomjol.github.io/AI-on-the-edge-device-docs/Installation/#3-sd-card) for details!
|
||||||
|
|
||||||
## Casing
|
## Casing
|
||||||
Various 3D-printable housing can be found here:
|
Various 3D-printable housing can be found here:
|
||||||
@@ -89,7 +89,7 @@ If you would like to support the developer with a cup of coffee, you can do that
|
|||||||
<a href="https://www.paypal.com/donate?hosted_button_id=8TRSVYNYKDSWL"><img border="0" src="images/paypal.png" width="200px" target="_blank"></a>
|
<a href="https://www.paypal.com/donate?hosted_button_id=8TRSVYNYKDSWL"><img border="0" src="images/paypal.png" width="200px" target="_blank"></a>
|
||||||
|
|
||||||
## Support
|
## Support
|
||||||
If you have any technical problems please search the [discussions](https://github.com/jomjol/AI-on-the-edge-device/discussions). In case you found a ug or have a feature request, please open an [issue](https://github.com/jomjol/AI-on-the-edge-device/issues).
|
If you have any technical problems please search the [discussions](https://github.com/jomjol/AI-on-the-edge-device/discussions). In case you found a bug or have a feature request, please open an [issue](https://github.com/jomjol/AI-on-the-edge-device/issues).
|
||||||
|
|
||||||
In other cases you can contact the developer via email: <img src="https://raw.githubusercontent.com/jomjol/AI-on-the-edge-device/master/images/mail.jpg" height="25">
|
In other cases you can contact the developer via email: <img src="https://raw.githubusercontent.com/jomjol/AI-on-the-edge-device/master/images/mail.jpg" height="25">
|
||||||
|
|
||||||
@@ -106,3 +106,10 @@ See [Build Instructions](code/README.md).
|
|||||||
## Additional Ideas
|
## Additional Ideas
|
||||||
There are some ideas and feature requests which are not currently being pursued – mainly due to capacity reasons on the part of the developers.
|
There are some ideas and feature requests which are not currently being pursued – mainly due to capacity reasons on the part of the developers.
|
||||||
They features are collected in the [issues](https://github.com/jomjol/AI-on-the-edge-device/issues) and in [FeatureRequest.md](FeatureRequest.md).
|
They features are collected in the [issues](https://github.com/jomjol/AI-on-the-edge-device/issues) and in [FeatureRequest.md](FeatureRequest.md).
|
||||||
|
|
||||||
|
## Our Contributors ❤️
|
||||||
|
<!-- Autogenerated table, do not manually update!
|
||||||
|
It gets automatically updated on the next release.
|
||||||
|
See https://github.com/marketplace/actions/contribute-list -->
|
||||||
|
<!-- readme: contributors -start -->
|
||||||
|
<!-- readme: contributors -end -->
|
||||||
|
|||||||
@@ -122,12 +122,18 @@ esp_err_t CCamera::InitCam(void)
|
|||||||
{
|
{
|
||||||
ESP_LOGD(TAG, "Init Camera");
|
ESP_LOGD(TAG, "Init Camera");
|
||||||
|
|
||||||
|
TickType_t cam_xDelay = 100 / portTICK_PERIOD_MS;
|
||||||
|
|
||||||
CCstatus.ImageQuality = camera_config.jpeg_quality;
|
CCstatus.ImageQuality = camera_config.jpeg_quality;
|
||||||
CCstatus.ImageFrameSize = camera_config.frame_size;
|
CCstatus.ImageFrameSize = camera_config.frame_size;
|
||||||
|
|
||||||
|
// De-init in case it was already initialized
|
||||||
|
esp_camera_deinit();
|
||||||
|
vTaskDelay(cam_xDelay);
|
||||||
|
|
||||||
// initialize the camera
|
// initialize the camera
|
||||||
esp_camera_deinit(); // De-init in case it was already initialized
|
|
||||||
esp_err_t err = esp_camera_init(&camera_config);
|
esp_err_t err = esp_camera_init(&camera_config);
|
||||||
|
vTaskDelay(cam_xDelay);
|
||||||
|
|
||||||
if (err != ESP_OK)
|
if (err != ESP_OK)
|
||||||
{
|
{
|
||||||
@@ -280,8 +286,8 @@ esp_err_t CCamera::setSensorDatenFromCCstatus(void)
|
|||||||
|
|
||||||
s->set_dcw(s, CCstatus.ImageDcw); // 0 = disable , 1 = enable
|
s->set_dcw(s, CCstatus.ImageDcw); // 0 = disable , 1 = enable
|
||||||
|
|
||||||
TickType_t xDelay2 = 100 / portTICK_PERIOD_MS;
|
TickType_t cam_xDelay = 100 / portTICK_PERIOD_MS;
|
||||||
vTaskDelay(xDelay2);
|
vTaskDelay(cam_xDelay);
|
||||||
|
|
||||||
return ESP_OK;
|
return ESP_OK;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -286,7 +286,7 @@ bool ClassFlowMQTT::doFlow(string zwtime)
|
|||||||
|
|
||||||
if (resultchangabs.length() > 0) {
|
if (resultchangabs.length() > 0) {
|
||||||
success |= MQTTPublish(namenumber + "changeabsolut", resultchangabs, qos, SetRetainFlag); // Legacy API
|
success |= MQTTPublish(namenumber + "changeabsolut", resultchangabs, qos, SetRetainFlag); // Legacy API
|
||||||
success |= MQTTPublish(namenumber + "rate_per_Digitization_round", resultchangabs, qos, SetRetainFlag);
|
success |= MQTTPublish(namenumber + "rate_per_digitization_round", resultchangabs, qos, SetRetainFlag);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (resultraw.length() > 0)
|
if (resultraw.length() > 0)
|
||||||
|
|||||||
@@ -188,10 +188,10 @@ bool MQTThomeassistantDiscovery(int qos) {
|
|||||||
allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "value", "Value", "gauge", valueUnit, meterType, "total_increasing", "", qos);
|
allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "value", "Value", "gauge", valueUnit, meterType, "total_increasing", "", qos);
|
||||||
allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "raw", "Raw Value", "raw", "", "", "", "diagnostic", qos);
|
allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "raw", "Raw Value", "raw", "", "", "", "diagnostic", qos);
|
||||||
allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "error", "Error", "alert-circle-outline", "", "", "", "diagnostic", qos);
|
allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "error", "Error", "alert-circle-outline", "", "", "", "diagnostic", qos);
|
||||||
/* Not announcing "rate" as it is better to use rate_per_time_unit resp. rate_per_Digitization_round */
|
/* Not announcing "rate" as it is better to use rate_per_time_unit resp. rate_per_digitization_round */
|
||||||
// allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "rate", "Rate (Unit/Minute)", "swap-vertical", "", "", "", ""); // Legacy, always Unit per Minute
|
// allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "rate", "Rate (Unit/Minute)", "swap-vertical", "", "", "", ""); // Legacy, always Unit per Minute
|
||||||
allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "rate_per_time_unit", "Rate (" + rateUnit + ")", "swap-vertical", rateUnit, "", "measurement", "", qos);
|
allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "rate_per_time_unit", "Rate (" + rateUnit + ")", "swap-vertical", rateUnit, "", "measurement", "", qos);
|
||||||
allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "rate_per_Digitization_round", "Change since last Digitization round", "arrow-expand-vertical", valueUnit, "", "measurement", "", qos); // correctly the Unit is Unit/Interval!
|
allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "rate_per_digitization_round", "Change since last Digitization round", "arrow-expand-vertical", valueUnit, "", "measurement", "", qos); // correctly the Unit is Unit/Interval!
|
||||||
allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "timestamp", "Timestamp", "clock-time-eight-outline", "", "timestamp", "", "diagnostic", qos);
|
allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "timestamp", "Timestamp", "clock-time-eight-outline", "", "timestamp", "", "diagnostic", qos);
|
||||||
allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "json", "JSON", "code-json", "", "", "", "diagnostic", qos);
|
allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "json", "JSON", "code-json", "", "", "", "diagnostic", qos);
|
||||||
allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "problem", "Problem", "alert-outline", "", "problem", "", "", qos); // Special binary sensor which is based on error topic
|
allSendsSuccessed |= sendHomeAssistantDiscoveryTopic(group, "problem", "Problem", "alert-outline", "", "problem", "", "", qos); // Special binary sensor which is based on error topic
|
||||||
|
|||||||
@@ -528,30 +528,44 @@ extern "C" void app_main(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// FIXME: needs to be revised or removed!!!
|
|
||||||
void migrateConfiguration(void) {
|
void migrateConfiguration(void) {
|
||||||
|
std::vector<string> splitted;
|
||||||
bool migrated = false;
|
bool migrated = false;
|
||||||
|
|
||||||
|
bool CamZoom_found = false;
|
||||||
|
int CamZoom_lines = 0;
|
||||||
|
bool CamZoom_value = false;
|
||||||
|
int CamZoomSize_lines = 0;
|
||||||
|
int CamZoomSize_value = 0;
|
||||||
|
int CamZoomOffsetX_lines = 0;
|
||||||
|
int CamZoomOffsetX_value = 0;
|
||||||
|
int CamZoomOffsetY_lines = 0;
|
||||||
|
int CamZoomOffsetY_value = 0;
|
||||||
|
|
||||||
if (!FileExists(CONFIG_FILE)) {
|
if (!FileExists(CONFIG_FILE)) {
|
||||||
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Config file seems to be missing!");
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Config file seems to be missing!");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string section = "";
|
std::string section = "";
|
||||||
std::ifstream ifs(CONFIG_FILE);
|
std::ifstream ifs(CONFIG_FILE);
|
||||||
std::string content((std::istreambuf_iterator<char>(ifs)), (std::istreambuf_iterator<char>()));
|
std::string content((std::istreambuf_iterator<char>(ifs)), (std::istreambuf_iterator<char>()));
|
||||||
|
|
||||||
/* Split config file it array of lines */
|
/* Split config file it array of lines */
|
||||||
std::vector<std::string> configLines = splitString(content);
|
std::vector<std::string> configLines = splitString(content);
|
||||||
|
|
||||||
/* Process each line */
|
/* Process each line */
|
||||||
for (int i = 0; i < configLines.size(); i++) {
|
for (int i = 0; i < configLines.size(); i++) {
|
||||||
//ESP_LOGI(TAG, "Line %d: %s", i, configLines[i].c_str());
|
// ESP_LOGI(TAG, "Line %d: %s", i, configLines[i].c_str());
|
||||||
|
|
||||||
if (configLines[i].find("[") != std::string::npos) { // Start of new section
|
if (configLines[i].find("[") != std::string::npos) {
|
||||||
|
// Start of new section
|
||||||
section = configLines[i];
|
section = configLines[i];
|
||||||
replaceString(section, ";", "", false); // Remove possible semicolon (just for the string comparison)
|
replaceString(section, ";", "", false); // Remove possible semicolon (just for the string comparison)
|
||||||
//ESP_LOGI(TAG, "New section: %s", section.c_str());
|
// ESP_LOGI(TAG, "New section: %s", section.c_str());
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
splitted = ZerlegeZeile(configLines[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Migrate parameters as needed
|
/* Migrate parameters as needed
|
||||||
@@ -569,119 +583,154 @@ void migrateConfiguration(void) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (section == "[MakeImage]" || section == "[TakeImage]") {
|
if (section == "[MakeImage]" || section == "[TakeImage]") {
|
||||||
migrated = migrated | replaceString(configLines[i], "LogImageLocation", "RawImagesLocation");
|
if ((isInString(configLines[i], "Brightness")) && (!isInString(configLines[i], "CamBrightness"))) {
|
||||||
migrated = migrated | replaceString(configLines[i], "LogfileRetentionInDays", "RawImagesRetention");
|
migrated = migrated | replaceString(configLines[i], "Brightness", "CamBrightness");
|
||||||
|
}
|
||||||
|
else if ((isInString(configLines[i], "Contrast")) && (!isInString(configLines[i], "CamContrast"))) {
|
||||||
|
migrated = migrated | replaceString(configLines[i], "Contrast", "CamContrast");
|
||||||
|
}
|
||||||
|
else if ((isInString(configLines[i], "Saturation")) && (!isInString(configLines[i], "CamSaturation"))) {
|
||||||
|
migrated = migrated | replaceString(configLines[i], "Saturation", "CamSaturation");
|
||||||
|
}
|
||||||
|
else if ((isInString(configLines[i], "Sharpness")) && (!isInString(configLines[i], "CamSharpness")) && (!isInString(configLines[i], "CamAutoSharpness"))) {
|
||||||
|
migrated = migrated | replaceString(configLines[i], "Sharpness", "CamSharpness");
|
||||||
|
}
|
||||||
|
else if ((isInString(configLines[i], "Aec2")) && (!isInString(configLines[i], "CamAec")) && (!isInString(configLines[i], "CamAec2"))) {
|
||||||
|
migrated = migrated | replaceString(configLines[i], "Aec2", "CamAec2");
|
||||||
|
}
|
||||||
|
else if ((isInString(configLines[i], "Zoom")) && (!isInString(configLines[i], "CamZoom")) && (!isInString(configLines[i], "ZoomMode")) && (!isInString(configLines[i], "ZoomOffsetX")) && (!isInString(configLines[i], "ZoomOffsetY"))) {
|
||||||
|
CamZoom_lines = i;
|
||||||
|
CamZoom_value = alphanumericToBoolean(splitted[1]);
|
||||||
|
CamZoom_found = true;
|
||||||
|
}
|
||||||
|
else if ((isInString(configLines[i], "ZoomMode")) && (!isInString(configLines[i], "CamZoom"))) {
|
||||||
|
CamZoomSize_lines = i;
|
||||||
|
if (isStringNumeric(splitted[1])) {
|
||||||
|
CamZoomSize_value = std::stof(splitted[1]);
|
||||||
|
}
|
||||||
|
CamZoom_found = true;
|
||||||
|
}
|
||||||
|
else if ((isInString(configLines[i], "ZoomOffsetX")) && (!isInString(configLines[i], "CamZoom")) && (!isInString(configLines[i], "ZoomOffsetY"))) {
|
||||||
|
CamZoomOffsetX_lines = i;
|
||||||
|
if (isStringNumeric(splitted[1])) {
|
||||||
|
CamZoomOffsetX_value = std::stof(splitted[1]);
|
||||||
|
}
|
||||||
|
CamZoom_found = true;
|
||||||
|
}
|
||||||
|
else if ((isInString(configLines[i], "ZoomOffsetY")) && (!isInString(configLines[i], "CamZoom")) && (!isInString(configLines[i], "ZoomOffsetX"))) {
|
||||||
|
CamZoomOffsetY_lines = i;
|
||||||
|
if (isStringNumeric(splitted[1])) {
|
||||||
|
CamZoomOffsetY_value = std::stof(splitted[1]);
|
||||||
|
}
|
||||||
|
CamZoom_found = true;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
migrated = migrated | replaceString(configLines[i], "LogImageLocation", "RawImagesLocation");
|
||||||
|
migrated = migrated | replaceString(configLines[i], "LogfileRetentionInDays", "RawImagesRetention");
|
||||||
|
|
||||||
migrated = migrated | replaceString(configLines[i], ";Demo = true", ";Demo = false"); // Set it to its default value
|
migrated = migrated | replaceString(configLines[i], ";Demo = true", ";Demo = false"); // Set it to its default value
|
||||||
migrated = migrated | replaceString(configLines[i], ";Demo", "Demo"); // Enable it
|
migrated = migrated | replaceString(configLines[i], ";Demo", "Demo"); // Enable it
|
||||||
|
|
||||||
// Parameter is no longer used
|
migrated = migrated | replaceString(configLines[i], "ImageQuality", "CamQuality");
|
||||||
// migrated = migrated | replaceString(configLines[i], ";FixedExposure = true", ";FixedExposure = false"); // Set it to its default value
|
migrated = migrated | replaceString(configLines[i], "AutoExposureLevel", "CamAeLevel");
|
||||||
// migrated = migrated | replaceString(configLines[i], ";FixedExposure", "FixedExposure"); // Enable it
|
migrated = migrated | replaceString(configLines[i], "FixedExposure", "CamAec");
|
||||||
|
|
||||||
|
migrated = migrated | replaceString(configLines[i], "ImageSize", ";UNUSED_PARAMETER"); // This parameter is no longer used
|
||||||
|
migrated = migrated | replaceString(configLines[i], "Grayscale", ";UNUSED_PARAMETER"); // This parameter is no longer used
|
||||||
|
migrated = migrated | replaceString(configLines[i], "Negative", ";UNUSED_PARAMETER"); // This parameter is no longer used
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
else if (section == "[Alignment]") {
|
||||||
if (section == "[Alignment]") {
|
migrated = migrated | replaceString(configLines[i], "InitialMirror", ";UNUSED_PARAMETER"); // This parameter is no longer used
|
||||||
// Parameter is no longer used
|
migrated = migrated | replaceString(configLines[i], ";InitialMirror", ";UNUSED_PARAMETER"); // This parameter is no longer used
|
||||||
// migrated = migrated | replaceString(configLines[i], ";InitialMirror = true", ";InitialMirror = false"); // Set it to its default value
|
migrated = migrated | replaceString(configLines[i], "FlipImageSize", ";UNUSED_PARAMETER"); // This parameter is no longer used
|
||||||
// migrated = migrated | replaceString(configLines[i], ";InitialMirror", "InitialMirror"); // Enable it
|
migrated = migrated | replaceString(configLines[i], ";FlipImageSize", ";UNUSED_PARAMETER"); // This parameter is no longer used
|
||||||
|
|
||||||
// Parameter is no longer used
|
|
||||||
// migrated = migrated | replaceString(configLines[i], ";FlipImageSize = true", ";FlipImageSize = false"); // Set it to its default value
|
|
||||||
// migrated = migrated | replaceString(configLines[i], ";FlipImageSize", "FlipImageSize"); // Enable it
|
|
||||||
}
|
}
|
||||||
|
else if (section == "[Digits]") {
|
||||||
if (section == "[Digits]") {
|
|
||||||
migrated = migrated | replaceString(configLines[i], "LogImageLocation", "ROIImagesLocation");
|
migrated = migrated | replaceString(configLines[i], "LogImageLocation", "ROIImagesLocation");
|
||||||
migrated = migrated | replaceString(configLines[i], "LogfileRetentionInDays", "ROIImagesRetention");
|
migrated = migrated | replaceString(configLines[i], "LogfileRetentionInDays", "ROIImagesRetention");
|
||||||
}
|
}
|
||||||
|
else if (section == "[Analog]") {
|
||||||
if (section == "[Analog]") {
|
|
||||||
migrated = migrated | replaceString(configLines[i], "LogImageLocation", "ROIImagesLocation");
|
migrated = migrated | replaceString(configLines[i], "LogImageLocation", "ROIImagesLocation");
|
||||||
migrated = migrated | replaceString(configLines[i], "LogfileRetentionInDays", "ROIImagesRetention");
|
migrated = migrated | replaceString(configLines[i], "LogfileRetentionInDays", "ROIImagesRetention");
|
||||||
migrated = migrated | replaceString(configLines[i], "ExtendedResolution", ";UNUSED_PARAMETER"); // This parameter is no longer used
|
migrated = migrated | replaceString(configLines[i], "ExtendedResolution", ";UNUSED_PARAMETER"); // This parameter is no longer used
|
||||||
}
|
}
|
||||||
|
else if (section == "[PostProcessing]") {
|
||||||
if (section == "[PostProcessing]") {
|
|
||||||
migrated = migrated | replaceString(configLines[i], "AnalogDigitalTransitionStart", "AnalogToDigitTransitionStart"); // Rename it
|
|
||||||
migrated = migrated | replaceString(configLines[i], ";PreValueUse = true", ";PreValueUse = false"); // Set it to its default value
|
|
||||||
migrated = migrated | replaceString(configLines[i], ";PreValueUse", "PreValueUse"); // Enable it
|
|
||||||
|
|
||||||
/* AllowNegativeRates has a <NUMBER> as prefix! */
|
/* AllowNegativeRates has a <NUMBER> as prefix! */
|
||||||
if (isInString(configLines[i], "AllowNegativeRates") && isInString(configLines[i], ";")) { // It is the parameter "AllowNegativeRates" and it is commented out
|
if (isInString(configLines[i], "AllowNegativeRates") && isInString(configLines[i], ";")) {
|
||||||
|
// It is the parameter "AllowNegativeRates" and it is commented out
|
||||||
migrated = migrated | replaceString(configLines[i], "true", "false"); // Set it to its default value
|
migrated = migrated | replaceString(configLines[i], "true", "false"); // Set it to its default value
|
||||||
migrated = migrated | replaceString(configLines[i], ";", ""); // Enable it
|
migrated = migrated | replaceString(configLines[i], ";", ""); // Enable it
|
||||||
}
|
}
|
||||||
|
|
||||||
/* IgnoreLeadingNaN has a <NUMBER> as prefix! */
|
/* IgnoreLeadingNaN has a <NUMBER> as prefix! */
|
||||||
if (isInString(configLines[i], "IgnoreLeadingNaN") && isInString(configLines[i], ";")) { // It is the parameter "IgnoreLeadingNaN" and it is commented out
|
else if (isInString(configLines[i], "IgnoreLeadingNaN") && isInString(configLines[i], ";")) {
|
||||||
|
// It is the parameter "IgnoreLeadingNaN" and it is commented out
|
||||||
migrated = migrated | replaceString(configLines[i], "true", "false"); // Set it to its default value
|
migrated = migrated | replaceString(configLines[i], "true", "false"); // Set it to its default value
|
||||||
migrated = migrated | replaceString(configLines[i], ";", ""); // Enable it
|
migrated = migrated | replaceString(configLines[i], ";", ""); // Enable it
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ExtendedResolution has a <NUMBER> as prefix! */
|
/* ExtendedResolution has a <NUMBER> as prefix! */
|
||||||
if (isInString(configLines[i], "ExtendedResolution") && isInString(configLines[i], ";")) { // It is the parameter "ExtendedResolution" and it is commented out
|
else if (isInString(configLines[i], "ExtendedResolution") && isInString(configLines[i], ";")) {
|
||||||
|
// It is the parameter "ExtendedResolution" and it is commented out
|
||||||
migrated = migrated | replaceString(configLines[i], "true", "false"); // Set it to its default value
|
migrated = migrated | replaceString(configLines[i], "true", "false"); // Set it to its default value
|
||||||
migrated = migrated | replaceString(configLines[i], ";", ""); // Enable it
|
migrated = migrated | replaceString(configLines[i], ";", ""); // Enable it
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
migrated = migrated | replaceString(configLines[i], ";PreValueUse = true", ";PreValueUse = false"); // Set it to its default value
|
||||||
|
migrated = migrated | replaceString(configLines[i], ";PreValueUse", "PreValueUse"); // Enable it
|
||||||
|
|
||||||
migrated = migrated | replaceString(configLines[i], ";ErrorMessage = true", ";ErrorMessage = false"); // Set it to its default value
|
migrated = migrated | replaceString(configLines[i], ";ErrorMessage = true", ";ErrorMessage = false"); // Set it to its default value
|
||||||
migrated = migrated | replaceString(configLines[i], ";ErrorMessage", "ErrorMessage"); // Enable it
|
migrated = migrated | replaceString(configLines[i], ";ErrorMessage", "ErrorMessage"); // Enable it
|
||||||
|
|
||||||
migrated = migrated | replaceString(configLines[i], ";CheckDigitIncreaseConsistency = true", ";CheckDigitIncreaseConsistency = false"); // Set it to its default value
|
migrated = migrated | replaceString(configLines[i], ";CheckDigitIncreaseConsistency = true", ";CheckDigitIncreaseConsistency = false"); // Set it to its default value
|
||||||
migrated = migrated | replaceString(configLines[i], ";CheckDigitIncreaseConsistency", "CheckDigitIncreaseConsistency"); // Enable it
|
migrated = migrated | replaceString(configLines[i], ";CheckDigitIncreaseConsistency", "CheckDigitIncreaseConsistency"); // Enable it
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
else if (section == "[MQTT]") {
|
||||||
if (section == "[MQTT]") {
|
migrated = migrated | replaceString(configLines[i], "SetRetainFlag", "RetainMessages"); // First rename it, enable it with its default value
|
||||||
migrated = migrated | replaceString(configLines[i], "SetRetainFlag", "RetainMessages"); // First rename it, enable it with its default value
|
|
||||||
migrated = migrated | replaceString(configLines[i], ";RetainMessages = true", ";RetainMessages = false"); // Set it to its default value
|
migrated = migrated | replaceString(configLines[i], ";RetainMessages = true", ";RetainMessages = false"); // Set it to its default value
|
||||||
migrated = migrated | replaceString(configLines[i], ";RetainMessages", "RetainMessages"); // Enable it
|
migrated = migrated | replaceString(configLines[i], ";RetainMessages", "RetainMessages"); // Enable it
|
||||||
|
|
||||||
migrated = migrated | replaceString(configLines[i], ";HomeassistantDiscovery = true", ";HomeassistantDiscovery = false"); // Set it to its default value
|
migrated = migrated | replaceString(configLines[i], ";HomeassistantDiscovery = true", ";HomeassistantDiscovery = false"); // Set it to its default value
|
||||||
migrated = migrated | replaceString(configLines[i], ";HomeassistantDiscovery", "HomeassistantDiscovery"); // Enable it
|
migrated = migrated | replaceString(configLines[i], ";HomeassistantDiscovery", "HomeassistantDiscovery"); // Enable it
|
||||||
|
|
||||||
if (configLines[i].rfind("Topic", 0) != std::string::npos) // only if string starts with "Topic" (Was the naming in very old version)
|
// only if string starts with "Topic" (Was the naming in very old version)
|
||||||
{
|
if (configLines[i].rfind("Topic", 0) != std::string::npos) {
|
||||||
migrated = migrated | replaceString(configLines[i], "Topic", "MainTopic");
|
migrated = migrated | replaceString(configLines[i], "Topic", "MainTopic");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (section == "[InfluxDB]") {
|
||||||
if (section == "[InfluxDB]") {
|
|
||||||
/* Fieldname has a <NUMBER> as prefix! */
|
/* Fieldname has a <NUMBER> as prefix! */
|
||||||
if (isInString(configLines[i], "Fieldname")) { // It is the parameter "Fieldname"
|
if (isInString(configLines[i], "Fieldname")) {
|
||||||
|
// It is the parameter "Fieldname"
|
||||||
migrated = migrated | replaceString(configLines[i], "Fieldname", "Field"); // Rename it to Field
|
migrated = migrated | replaceString(configLines[i], "Fieldname", "Field"); // Rename it to Field
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (section == "[InfluxDBv2]") {
|
||||||
if (section == "[InfluxDBv2]") {
|
|
||||||
/* Fieldname has a <NUMBER> as prefix! */
|
/* Fieldname has a <NUMBER> as prefix! */
|
||||||
if (isInString(configLines[i], "Fieldname")) { // It is the parameter "Fieldname"
|
if (isInString(configLines[i], "Fieldname")) {
|
||||||
|
// It is the parameter "Fieldname"
|
||||||
migrated = migrated | replaceString(configLines[i], "Fieldname", "Field"); // Rename it to Field
|
migrated = migrated | replaceString(configLines[i], "Fieldname", "Field"); // Rename it to Field
|
||||||
}
|
}
|
||||||
/* Database got renamed to Bucket! */
|
/* Database got renamed to Bucket! */
|
||||||
if (isInString(configLines[i], "Database")) { // It is the parameter "Database"
|
else if (isInString(configLines[i], "Database")) {
|
||||||
|
// It is the parameter "Database"
|
||||||
migrated = migrated | replaceString(configLines[i], "Database", "Bucket"); // Rename it to Bucket
|
migrated = migrated | replaceString(configLines[i], "Database", "Bucket"); // Rename it to Bucket
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (section == "[GPIO]") {
|
||||||
if (section == "[GPIO]") {
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
else if (section == "[DataLogging]") {
|
||||||
if (section == "[DataLogging]") {
|
|
||||||
migrated = migrated | replaceString(configLines[i], "DataLogRetentionInDays", "DataFilesRetention");
|
migrated = migrated | replaceString(configLines[i], "DataLogRetentionInDays", "DataFilesRetention");
|
||||||
/* DataLogActive is true by default! */
|
/* DataLogActive is true by default! */
|
||||||
migrated = migrated | replaceString(configLines[i], ";DataLogActive = false", ";DataLogActive = true"); // Set it to its default value
|
migrated = migrated | replaceString(configLines[i], ";DataLogActive = false", ";DataLogActive = true"); // Set it to its default value
|
||||||
migrated = migrated | replaceString(configLines[i], ";DataLogActive", "DataLogActive"); // Enable it
|
migrated = migrated | replaceString(configLines[i], ";DataLogActive", "DataLogActive"); // Enable it
|
||||||
}
|
}
|
||||||
|
else if (section == "[AutoTimer]") {
|
||||||
if (section == "[AutoTimer]") {
|
|
||||||
migrated = migrated | replaceString(configLines[i], "Intervall", "Interval");
|
migrated = migrated | replaceString(configLines[i], "Intervall", "Interval");
|
||||||
migrated = migrated | replaceString(configLines[i], ";AutoStart = true", ";AutoStart = false"); // Set it to its default value
|
migrated = migrated | replaceString(configLines[i], ";AutoStart = true", ";AutoStart = false"); // Set it to its default value
|
||||||
migrated = migrated | replaceString(configLines[i], ";AutoStart", "AutoStart"); // Enable it
|
migrated = migrated | replaceString(configLines[i], ";AutoStart", "AutoStart"); // Enable it
|
||||||
|
|
||||||
}
|
}
|
||||||
|
else if (section == "[Debug]") {
|
||||||
if (section == "[Debug]") {
|
|
||||||
migrated = migrated | replaceString(configLines[i], "Logfile ", "LogLevel "); // Whitespace needed so it does not match `LogfileRetentionInDays`
|
migrated = migrated | replaceString(configLines[i], "Logfile ", "LogLevel "); // Whitespace needed so it does not match `LogfileRetentionInDays`
|
||||||
/* LogLevel (resp. LogFile) was originally a boolean, but we switched it to an int
|
/* LogLevel (resp. LogFile) was originally a boolean, but we switched it to an int
|
||||||
* For both cases (true/false), we set it to level 2 (WARNING) */
|
* For both cases (true/false), we set it to level 2 (WARNING) */
|
||||||
@@ -689,27 +738,102 @@ void migrateConfiguration(void) {
|
|||||||
migrated = migrated | replaceString(configLines[i], "LogLevel = false", "LogLevel = 2");
|
migrated = migrated | replaceString(configLines[i], "LogLevel = false", "LogLevel = 2");
|
||||||
migrated = migrated | replaceString(configLines[i], "LogfileRetentionInDays", "LogfilesRetention");
|
migrated = migrated | replaceString(configLines[i], "LogfileRetentionInDays", "LogfilesRetention");
|
||||||
}
|
}
|
||||||
|
else if (section == "[System]") {
|
||||||
if (section == "[System]") {
|
|
||||||
migrated = migrated | replaceString(configLines[i], "RSSIThreashold", "RSSIThreshold");
|
migrated = migrated | replaceString(configLines[i], "RSSIThreashold", "RSSIThreshold");
|
||||||
migrated = migrated | replaceString(configLines[i], "AutoAdjustSummertime", ";UNUSED_PARAMETER"); // This parameter is no longer used
|
migrated = migrated | replaceString(configLines[i], "AutoAdjustSummertime", ";UNUSED_PARAMETER"); // This parameter is no longer used
|
||||||
|
|
||||||
migrated = migrated | replaceString(configLines[i], ";SetupMode = true", ";SetupMode = false"); // Set it to its default value
|
migrated = migrated | replaceString(configLines[i], ";SetupMode = true", ";SetupMode = false"); // Set it to its default value
|
||||||
migrated = migrated | replaceString(configLines[i], ";SetupMode", "SetupMode"); // Enable it
|
migrated = migrated | replaceString(configLines[i], ";SetupMode", "SetupMode"); // Enable it
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (migrated) { // At least one replacement happened
|
if (CamZoom_found == true) {
|
||||||
if (! RenameFile(CONFIG_FILE, CONFIG_FILE_BACKUP)) {
|
if (CamZoomSize_value == 0) {
|
||||||
|
// mode0
|
||||||
|
// 1600 - 640 = 960 / 2 = max-Offset (+/-) 480
|
||||||
|
// 1200 - 480 = 720 / 2 = max-Offset (+/-) 360
|
||||||
|
|
||||||
|
if (CamZoomOffsetX_value > 960) {
|
||||||
|
CamZoomOffsetX_value = 960;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
CamZoomOffsetX_value = (floor((CamZoomOffsetX_value - 480) / 8) * 8);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (CamZoomOffsetY_value > 720) {
|
||||||
|
CamZoomOffsetY_value = 720;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
CamZoomOffsetY_value = (floor((CamZoomOffsetY_value - 360) / 8) * 8);
|
||||||
|
}
|
||||||
|
|
||||||
|
CamZoomSize_value = 29;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// mode1
|
||||||
|
// 800 - 640 = 160 / 2 = max-Offset (+/-) 80
|
||||||
|
// 600 - 480 = 120 / 2 = max-Offset (+/-) 60
|
||||||
|
|
||||||
|
if (CamZoomOffsetX_value > 160) {
|
||||||
|
CamZoomOffsetX_value = 160;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
CamZoomOffsetX_value = (floor(((CamZoomOffsetX_value - 80) * 2) / 8) * 8);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (CamZoomOffsetY_value > 120) {
|
||||||
|
CamZoomOffsetY_value = 120;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
CamZoomOffsetY_value = (floor(((CamZoomOffsetY_value - 60) * 2) / 8) * 8);
|
||||||
|
}
|
||||||
|
|
||||||
|
CamZoomSize_value = 9;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (CamZoom_lines > 0) {
|
||||||
|
if (CamZoom_value) {
|
||||||
|
configLines[CamZoom_lines] = ("CamZoom = true");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
configLines[CamZoom_lines] = ("CamZoom = false");
|
||||||
|
}
|
||||||
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Migrated Configfile line 'Zoom' to 'CamZoom'");
|
||||||
|
migrated = true;
|
||||||
|
}
|
||||||
|
if (CamZoomSize_lines > 0) {
|
||||||
|
configLines[CamZoomSize_lines] = ("CamZoomSize = " + std::to_string(CamZoomSize_value));
|
||||||
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Migrated Configfile line 'ZoomMode' to 'CamZoomSize'");
|
||||||
|
migrated = true;
|
||||||
|
}
|
||||||
|
if (CamZoomOffsetX_lines > 0) {
|
||||||
|
configLines[CamZoomOffsetX_lines] = ("CamZoomOffsetX = " + std::to_string(CamZoomOffsetX_value));
|
||||||
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Migrated Configfile line 'ZoomOffsetX' to 'CamZoomOffsetX'");
|
||||||
|
migrated = true;
|
||||||
|
}
|
||||||
|
if (CamZoomOffsetY_lines > 0) {
|
||||||
|
configLines[CamZoomOffsetY_lines] = ("CamZoomOffsetY = " + std::to_string(CamZoomOffsetY_value));
|
||||||
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Migrated Configfile line 'ZoomOffsetY' to 'CamZoomOffsetY'");
|
||||||
|
migrated = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (migrated) {
|
||||||
|
// At least one replacement happened
|
||||||
|
if (!RenameFile(CONFIG_FILE, CONFIG_FILE_BACKUP)) {
|
||||||
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Failed to create backup of Config file!");
|
LogFile.WriteToFile(ESP_LOG_ERROR, TAG, "Failed to create backup of Config file!");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
FILE* pfile = fopen(CONFIG_FILE, "w");
|
FILE *pfile = fopen(CONFIG_FILE, "w");
|
||||||
|
|
||||||
for (int i = 0; i < configLines.size(); i++) {
|
for (int i = 0; i < configLines.size(); i++) {
|
||||||
fwrite(configLines[i].c_str() , configLines[i].length(), 1, pfile);
|
if (!isInString(configLines[i], ";UNUSED_PARAMETER")) {
|
||||||
fwrite("\n" , 1, 1, pfile);
|
fwrite(configLines[i].c_str(), configLines[i].length(), 1, pfile);
|
||||||
|
fwrite("\n", 1, 1, pfile);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fclose(pfile);
|
fclose(pfile);
|
||||||
LogFile.WriteToFile(ESP_LOG_INFO, TAG, "Config file migrated. Saved backup to " + string(CONFIG_FILE_BACKUP));
|
LogFile.WriteToFile(ESP_LOG_INFO, TAG, "Config file migrated. Saved backup to " + string(CONFIG_FILE_BACKUP));
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# Parameter `<NUMBER>.AnalogDigitTransitionStart`
|
# Parameter `<NUMBER>.AnalogToDigitTransitionStart`
|
||||||
Default Value: `9.2`
|
Default Value: `9.2`
|
||||||
|
|
||||||
This can be used if you have wrong values, but the recognition of the individual ROIs are correct.
|
This can be used if you have wrong values, but the recognition of the individual ROIs are correct.
|
||||||
@@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
range on OV3660 and OV5640 (0 .. 8)
|
range on OV3660 and OV5640 (0 .. 8)
|
||||||
|
|
||||||
Default Value: `true`
|
Default Value: `0`
|
||||||
|
|
||||||
See [here](../datasheets/Camera.ov2640_ds_1.8_.pdf) for the ov2640 camera datasheet.<br>
|
See [here](../datasheets/Camera.ov2640_ds_1.8_.pdf) for the ov2640 camera datasheet.<br>
|
||||||
See [here](../datasheets/OV5640_datasheet.pdf) for the ov5640 camera datasheet.
|
See [here](../datasheets/OV5640_datasheet.pdf) for the ov5640 camera datasheet.
|
||||||
|
|||||||
@@ -36,11 +36,9 @@ Demo = false
|
|||||||
|
|
||||||
[Alignment]
|
[Alignment]
|
||||||
InitialRotate = 0.0
|
InitialRotate = 0.0
|
||||||
InitialMirror = false
|
|
||||||
SearchFieldX = 20
|
SearchFieldX = 20
|
||||||
SearchFieldY = 20
|
SearchFieldY = 20
|
||||||
AlignmentAlgo = Default
|
AlignmentAlgo = default
|
||||||
FlipImageSize = false
|
|
||||||
/config/ref0.jpg 103 271
|
/config/ref0.jpg 103 271
|
||||||
/config/ref1.jpg 442 142
|
/config/ref1.jpg 442 142
|
||||||
|
|
||||||
@@ -93,17 +91,18 @@ HomeassistantDiscovery = false
|
|||||||
;[InfluxDB]
|
;[InfluxDB]
|
||||||
;Uri = undefined
|
;Uri = undefined
|
||||||
;Database = undefined
|
;Database = undefined
|
||||||
;Measurement = undefined
|
|
||||||
;user = undefined
|
;user = undefined
|
||||||
;password = undefined
|
;password = undefined
|
||||||
|
;main.Measurement = undefined
|
||||||
|
;main.Field = undefined
|
||||||
|
|
||||||
;[InfluxDBv2]
|
;[InfluxDBv2]
|
||||||
;Uri = undefined
|
;Uri = undefined
|
||||||
;Bucket = undefined
|
;Bucket = undefined
|
||||||
;Measurement = undefined
|
|
||||||
;Org = undefined
|
;Org = undefined
|
||||||
;Token = undefined
|
;Token = undefined
|
||||||
;main.Fieldname = undefined
|
;main.Measurement = undefined
|
||||||
|
;main.Field = undefined
|
||||||
|
|
||||||
;[Webhook]
|
;[Webhook]
|
||||||
;Uri = undefined
|
;Uri = undefined
|
||||||
@@ -117,7 +116,7 @@ HomeassistantDiscovery = false
|
|||||||
;IO3 = input disabled 10 false false
|
;IO3 = input disabled 10 false false
|
||||||
;IO4 = built-in-led disabled 10 false false
|
;IO4 = built-in-led disabled 10 false false
|
||||||
;IO12 = input-pullup disabled 10 false false
|
;IO12 = input-pullup disabled 10 false false
|
||||||
;IO13 = input-pullup disabled 10 false false
|
;IO13 = input-pullup disabled 10 false false
|
||||||
LEDType = WS2812
|
LEDType = WS2812
|
||||||
LEDNumbers = 2
|
LEDNumbers = 2
|
||||||
LEDColor = 150 150 150
|
LEDColor = 150 150 150
|
||||||
@@ -140,4 +139,5 @@ TimeZone = CET-1CEST,M3.5.0,M10.5.0/3
|
|||||||
;Hostname = undefined
|
;Hostname = undefined
|
||||||
RSSIThreshold = -75
|
RSSIThreshold = -75
|
||||||
CPUFrequency = 160
|
CPUFrequency = 160
|
||||||
|
Tooltip = true
|
||||||
SetupMode = true
|
SetupMode = true
|
||||||
|
|||||||
BIN
sd-card/demo/530.07077.jpg
Normal file
|
After Width: | Height: | Size: 24 KiB |
BIN
sd-card/demo/530.07325.jpg
Normal file
|
After Width: | Height: | Size: 24 KiB |
BIN
sd-card/demo/530.12067.jpg
Normal file
|
After Width: | Height: | Size: 24 KiB |
BIN
sd-card/demo/530.21419.jpg
Normal file
|
After Width: | Height: | Size: 24 KiB |
BIN
sd-card/demo/530.48435.jpg
Normal file
|
After Width: | Height: | Size: 24 KiB |
BIN
sd-card/demo/530.70265.jpg
Normal file
|
After Width: | Height: | Size: 24 KiB |
BIN
sd-card/demo/530.95675.jpg
Normal file
|
After Width: | Height: | Size: 24 KiB |
BIN
sd-card/demo/531.10877.jpg
Normal file
|
After Width: | Height: | Size: 24 KiB |
BIN
sd-card/demo/531.24108.jpg
Normal file
|
After Width: | Height: | Size: 24 KiB |
BIN
sd-card/demo/531.38301.jpg
Normal file
|
After Width: | Height: | Size: 24 KiB |
BIN
sd-card/demo/531.63071.jpg
Normal file
|
After Width: | Height: | Size: 24 KiB |
BIN
sd-card/demo/531.82235.jpg
Normal file
|
After Width: | Height: | Size: 24 KiB |
137
sd-card/demo/config.ini
Normal file
@@ -0,0 +1,137 @@
|
|||||||
|
[TakeImage]
|
||||||
|
;RawImagesLocation = /log/source
|
||||||
|
;RawImagesRetention = 15
|
||||||
|
WaitBeforeTakingPicture = 2
|
||||||
|
CamGainceiling = x8
|
||||||
|
CamQuality = 10
|
||||||
|
CamBrightness = 0
|
||||||
|
CamContrast = 0
|
||||||
|
CamSaturation = 0
|
||||||
|
CamSharpness = 0
|
||||||
|
CamAutoSharpness = false
|
||||||
|
CamSpecialEffect = no_effect
|
||||||
|
CamWbMode = auto
|
||||||
|
CamAwb = true
|
||||||
|
CamAwbGain = true
|
||||||
|
CamAec = true
|
||||||
|
CamAec2 = true
|
||||||
|
CamAeLevel = 2
|
||||||
|
CamAecValue = 600
|
||||||
|
CamAgc = true
|
||||||
|
CamAgcGain = 8
|
||||||
|
CamBpc = true
|
||||||
|
CamWpc = true
|
||||||
|
CamRawGma = true
|
||||||
|
CamLenc = true
|
||||||
|
CamHmirror = false
|
||||||
|
CamVflip = false
|
||||||
|
CamDcw = true
|
||||||
|
CamDenoise = 0
|
||||||
|
CamZoom = false
|
||||||
|
CamZoomOffsetX = 0
|
||||||
|
CamZoomOffsetY = 0
|
||||||
|
CamZoomSize = 0
|
||||||
|
LEDIntensity = 0
|
||||||
|
Demo = true
|
||||||
|
|
||||||
|
[Alignment]
|
||||||
|
InitialRotate = -34.6
|
||||||
|
SearchFieldX = 20
|
||||||
|
SearchFieldY = 20
|
||||||
|
AlignmentAlgo = default
|
||||||
|
/config/ref0.jpg 30 189
|
||||||
|
/config/ref1.jpg 536 113
|
||||||
|
|
||||||
|
[Digits]
|
||||||
|
Model = /config/dig-cont_0710_s3_q.tflite
|
||||||
|
CNNGoodThreshold = 0.5
|
||||||
|
;ROIImagesLocation = /log/digit
|
||||||
|
;ROIImagesRetention = 3
|
||||||
|
main.dig1 438 62 49 71 false
|
||||||
|
|
||||||
|
[Analog]
|
||||||
|
Model = /config/ana-cont_1300_s2.tflite
|
||||||
|
;ROIImagesLocation = /log/analog
|
||||||
|
;ROIImagesRetention = 3
|
||||||
|
main.ana1 452 199 120 120 false
|
||||||
|
|
||||||
|
[PostProcessing]
|
||||||
|
main.DecimalShift = 0
|
||||||
|
;main.AnalogToDigitTransitionStart =
|
||||||
|
main.ChangeRateThreshold = 2
|
||||||
|
PreValueUse = true
|
||||||
|
PreValueAgeStartup = 720
|
||||||
|
main.AllowNegativeRates = true
|
||||||
|
;main.MaxRateValue = 0
|
||||||
|
;main.MaxRateType = AbsoluteChange
|
||||||
|
main.ExtendedResolution = true
|
||||||
|
main.IgnoreLeadingNaN = false
|
||||||
|
ErrorMessage = true
|
||||||
|
CheckDigitIncreaseConsistency = false
|
||||||
|
|
||||||
|
;[MQTT]
|
||||||
|
;Uri = mqtt://IP-ADRESS:1883
|
||||||
|
;MainTopic = watermeter
|
||||||
|
;ClientID = watermeter
|
||||||
|
;user = USERNAME
|
||||||
|
;password = PASSWORD
|
||||||
|
RetainMessages = false
|
||||||
|
HomeassistantDiscovery = false
|
||||||
|
;MeterType = other
|
||||||
|
;CACert = /config/certs/RootCA.pem
|
||||||
|
;ClientCert = /config/certs/client.pem.crt
|
||||||
|
;ClientKey = /config/certs/client.pem.key
|
||||||
|
|
||||||
|
;[InfluxDB]
|
||||||
|
;Uri = undefined
|
||||||
|
;Database = undefined
|
||||||
|
;user = undefined
|
||||||
|
;password = undefined
|
||||||
|
;main.Measurement = undefined
|
||||||
|
;main.Field =
|
||||||
|
|
||||||
|
;[InfluxDBv2]
|
||||||
|
;Uri = undefined
|
||||||
|
;Bucket = undefined
|
||||||
|
;Org = undefined
|
||||||
|
;Token = undefined
|
||||||
|
;main.Measurement = undefined
|
||||||
|
;main.Field = undefined
|
||||||
|
|
||||||
|
;[Webhook]
|
||||||
|
;Uri = undefined
|
||||||
|
;ApiKey = undefined
|
||||||
|
;UploadImg = 0
|
||||||
|
|
||||||
|
;[GPIO]
|
||||||
|
;IO0 = input disabled 10 false false
|
||||||
|
;IO1 = input disabled 10 false false
|
||||||
|
;IO3 = input disabled 10 false false
|
||||||
|
;IO4 = built-in-led disabled 10 false false
|
||||||
|
;IO12 = input-pullup disabled 10 false false
|
||||||
|
;IO13 = input-pullup disabled 10 false false
|
||||||
|
LEDType = WS2812
|
||||||
|
LEDNumbers = 2
|
||||||
|
LEDColor = 150 150 150
|
||||||
|
|
||||||
|
[AutoTimer]
|
||||||
|
AutoStart = true
|
||||||
|
Interval = 1
|
||||||
|
|
||||||
|
[DataLogging]
|
||||||
|
DataLogActive = false
|
||||||
|
DataFilesRetention = 3
|
||||||
|
|
||||||
|
[Debug]
|
||||||
|
LogLevel = 3
|
||||||
|
LogfilesRetention = 3
|
||||||
|
|
||||||
|
[System]
|
||||||
|
Tooltip = true
|
||||||
|
TimeZone = CET-1CEST,M3.5.0,M10.5.0/3
|
||||||
|
;TimeServer = pool.ntp.org
|
||||||
|
;Hostname = undefined
|
||||||
|
RSSIThreshold = -75
|
||||||
|
CPUFrequency = 160
|
||||||
|
SetupMode = false
|
||||||
|
|
||||||
12
sd-card/demo/files.txt
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
530.07077.jpg
|
||||||
|
530.07325.jpg
|
||||||
|
530.12067.jpg
|
||||||
|
530.21419.jpg
|
||||||
|
530.48435.jpg
|
||||||
|
530.70265.jpg
|
||||||
|
530.95675.jpg
|
||||||
|
531.10877.jpg
|
||||||
|
531.24108.jpg
|
||||||
|
531.38301.jpg
|
||||||
|
531.63071.jpg
|
||||||
|
531.82235.jpg
|
||||||
1
sd-card/demo/prevalue.ini
Normal file
@@ -0,0 +1 @@
|
|||||||
|
main 2024-10-06T23:02:42+0200 0.05
|
||||||
12
sd-card/demo/readme.txt
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
This folder contains a prepared demo setup.
|
||||||
|
|
||||||
|
All you need to do is:
|
||||||
|
1. Copy the following files to the config folder of your SD-Card:
|
||||||
|
- config.ini
|
||||||
|
- ref0.jpg
|
||||||
|
- ref1.jpg
|
||||||
|
- reference.jpg
|
||||||
|
- prevalue.ini
|
||||||
|
1. Restart the device
|
||||||
|
|
||||||
|
More details at https://jomjol.github.io/AI-on-the-edge-device-docs/Demo-Mode
|
||||||
BIN
sd-card/demo/ref0.jpg
Normal file
|
After Width: | Height: | Size: 1.1 KiB |
BIN
sd-card/demo/ref1.jpg
Normal file
|
After Width: | Height: | Size: 1.1 KiB |
BIN
sd-card/demo/reference.jpg
Normal file
|
After Width: | Height: | Size: 34 KiB |
@@ -363,8 +363,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamAutoSharpness_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamAutoSharpness_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamAutoSharpness</td>
|
<td>$TOOLTIP_TakeImage_CamAutoSharpness</td>
|
||||||
@@ -421,8 +421,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamAwb_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamAwb_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamAwb</td>
|
<td>$TOOLTIP_TakeImage_CamAwb</td>
|
||||||
@@ -434,8 +434,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamAwbGain_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamAwbGain_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamAwbGain</td>
|
<td>$TOOLTIP_TakeImage_CamAwbGain</td>
|
||||||
@@ -447,8 +447,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamAec_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamAec_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamAec</td>
|
<td>$TOOLTIP_TakeImage_CamAec</td>
|
||||||
@@ -460,8 +460,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamAec2_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamAec2_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamAec2</td>
|
<td>$TOOLTIP_TakeImage_CamAec2</td>
|
||||||
@@ -495,8 +495,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamAgc_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamAgc_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamAgc</td>
|
<td>$TOOLTIP_TakeImage_CamAgc</td>
|
||||||
@@ -520,8 +520,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamBpc_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamBpc_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamBpc</td>
|
<td>$TOOLTIP_TakeImage_CamBpc</td>
|
||||||
@@ -533,8 +533,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamWpc_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamWpc_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamWpc</td>
|
<td>$TOOLTIP_TakeImage_CamWpc</td>
|
||||||
@@ -546,8 +546,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamRawGma_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamRawGma_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamRawGma</td>
|
<td>$TOOLTIP_TakeImage_CamRawGma</td>
|
||||||
@@ -559,8 +559,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamLenc_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamLenc_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamLenc</td>
|
<td>$TOOLTIP_TakeImage_CamLenc</td>
|
||||||
@@ -572,8 +572,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamHmirror_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamHmirror_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamHmirror</td>
|
<td>$TOOLTIP_TakeImage_CamHmirror</td>
|
||||||
@@ -585,8 +585,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamVflip_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamVflip_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamVflip</td>
|
<td>$TOOLTIP_TakeImage_CamVflip</td>
|
||||||
@@ -598,8 +598,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamDcw_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamDcw_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamDcw</td>
|
<td>$TOOLTIP_TakeImage_CamDcw</td>
|
||||||
@@ -622,8 +622,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamZoom_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamZoom_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamZoom</td>
|
<td>$TOOLTIP_TakeImage_CamZoom</td>
|
||||||
@@ -681,8 +681,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_Demo_value1">
|
<select id="TakeImage_Demo_value1">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_Demo</td>
|
<td>$TOOLTIP_TakeImage_Demo</td>
|
||||||
@@ -850,8 +850,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="PostProcessing_PreValueUse_value1">
|
<select id="PostProcessing_PreValueUse_value1">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_PostProcessing_PreValueUse</td>
|
<td>$TOOLTIP_PostProcessing_PreValueUse</td>
|
||||||
@@ -875,8 +875,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="PostProcessing_ErrorMessage_value1">
|
<select id="PostProcessing_ErrorMessage_value1">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_PostProcessing_ErrorMessage</td>
|
<td>$TOOLTIP_PostProcessing_ErrorMessage</td>
|
||||||
@@ -888,8 +888,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="PostProcessing_CheckDigitIncreaseConsistency_value1">
|
<select id="PostProcessing_CheckDigitIncreaseConsistency_value1">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_PostProcessing_CheckDigitIncreaseConsistency</td>
|
<td>$TOOLTIP_PostProcessing_CheckDigitIncreaseConsistency</td>
|
||||||
@@ -910,8 +910,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="PostProcessing_AllowNegativeRates_value1">
|
<select id="PostProcessing_AllowNegativeRates_value1">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_PostProcessing_NUMBER.AllowNegativeRates</td>
|
<td>$TOOLTIP_PostProcessing_NUMBER.AllowNegativeRates</td>
|
||||||
@@ -933,11 +933,11 @@
|
|||||||
<tr>
|
<tr>
|
||||||
<td class="indent2">
|
<td class="indent2">
|
||||||
<input type="checkbox" id="PostProcessing_AnalogToDigitTransitionStart_enabled" value="1" onclick = 'InvertEnableItem("PostProcessing", "AnalogToDigitTransitionStart")' unchecked >
|
<input type="checkbox" id="PostProcessing_AnalogToDigitTransitionStart_enabled" value="1" onclick = 'InvertEnableItem("PostProcessing", "AnalogToDigitTransitionStart")' unchecked >
|
||||||
<label for=PostProcessing_AnalogToDigitTransitionStart_enabled><class id="PostProcessing_AnalogToDigitTransitionStart_text" style="color:black;">Analog/Digital Transition Start</class></label>
|
<label for=PostProcessing_AnalogToDigitTransitionStart_enabled><class id="PostProcessing_AnalogToDigitTransitionStart_text" style="color:black;">Analog to Digit Transition Start</class></label>
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<input required type="number" id="PostProcessing_AnalogToDigitTransitionStart_value1" step="0.1" min="5.0" max="9.9" value="9.2"
|
<input required type="number" id="PostProcessing_AnalogToDigitTransitionStart_value1" step="0.1" min="3.0" max="9.9" value="9.2"
|
||||||
oninput="(!validity.rangeUnderflow||(value=5.0)) && (!validity.rangeOverflow||(value=9.9)) &&
|
oninput="(!validity.rangeUnderflow||(value=3.0)) && (!validity.rangeOverflow||(value=9.9)) &&
|
||||||
(!validity.stepMismatch||(value=parseInt(this.value)));">
|
(!validity.stepMismatch||(value=parseInt(this.value)));">
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_PostProcessing_NUMBER.AnalogToDigitTransitionStart</td>
|
<td>$TOOLTIP_PostProcessing_NUMBER.AnalogToDigitTransitionStart</td>
|
||||||
@@ -988,8 +988,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="PostProcessing_ExtendedResolution_value1">
|
<select id="PostProcessing_ExtendedResolution_value1">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_PostProcessing_NUMBER.ExtendedResolution</td>
|
<td>$TOOLTIP_PostProcessing_NUMBER.ExtendedResolution</td>
|
||||||
@@ -1001,8 +1001,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="PostProcessing_IgnoreLeadingNaN_value1">
|
<select id="PostProcessing_IgnoreLeadingNaN_value1">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_PostProcessing_NUMBER.IgnoreLeadingNaN</td>
|
<td>$TOOLTIP_PostProcessing_NUMBER.IgnoreLeadingNaN</td>
|
||||||
@@ -1014,8 +1014,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="PostProcessing_IgnoreAllNaN_value1">
|
<select id="PostProcessing_IgnoreAllNaN_value1">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_PostProcessing_NUMBER.IgnoreAllNaN</td>
|
<td>$TOOLTIP_PostProcessing_NUMBER.IgnoreAllNaN</td>
|
||||||
@@ -1126,8 +1126,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="MQTT_RetainMessages_value1">
|
<select id="MQTT_RetainMessages_value1">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_MQTT_RetainMessages</td>
|
<td>$TOOLTIP_MQTT_RetainMessages</td>
|
||||||
@@ -1148,8 +1148,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="MQTT_HomeassistantDiscovery_value1">
|
<select id="MQTT_HomeassistantDiscovery_value1">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_MQTT_HomeassistantDiscovery</td>
|
<td>$TOOLTIP_MQTT_HomeassistantDiscovery</td>
|
||||||
@@ -1900,8 +1900,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="AutoTimer_AutoStart_value1">
|
<select id="AutoTimer_AutoStart_value1">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_AutoTimer_AutoStart</td>
|
<td>$TOOLTIP_AutoTimer_AutoStart</td>
|
||||||
@@ -1930,8 +1930,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="DataLogging_DataLogActive_value1">
|
<select id="DataLogging_DataLogActive_value1">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_DataLogging_DataLogActive</td>
|
<td>$TOOLTIP_DataLogging_DataLogActive</td>
|
||||||
@@ -2053,8 +2053,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="System_Tooltip_value1" onchange="UpdateTooltipModus()">
|
<select id="System_Tooltip_value1" onchange="UpdateTooltipModus()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td></td>
|
<td></td>
|
||||||
@@ -2323,7 +2323,7 @@ function UpdateInput() {
|
|||||||
|
|
||||||
WriteParameter(param, category, "Webhook", "Uri", true);
|
WriteParameter(param, category, "Webhook", "Uri", true);
|
||||||
WriteParameter(param, category, "Webhook", "ApiKey", true);
|
WriteParameter(param, category, "Webhook", "ApiKey", true);
|
||||||
WriteParameter(param, category, "Webhook", "UploadImg", true);
|
WriteParameter(param, category, "Webhook", "UploadImg", false);
|
||||||
|
|
||||||
WriteParameter(param, category, "GPIO", "IO0", true);
|
WriteParameter(param, category, "GPIO", "IO0", true);
|
||||||
WriteParameter(param, category, "GPIO", "IO1", true);
|
WriteParameter(param, category, "GPIO", "IO1", true);
|
||||||
@@ -2374,12 +2374,12 @@ function WriteModelFiles() {
|
|||||||
|
|
||||||
var text = list_tflite[i].replace("/config/", "");
|
var text = list_tflite[i].replace("/config/", "");
|
||||||
|
|
||||||
if (list_tflite[i].includes("/dig")) { // Its a digital file, only show in the digital list box
|
if (list_tflite[i].includes("/dig")) { // Its a digit file, only show in the digits list box
|
||||||
optionDig.text = text;
|
optionDig.text = text;
|
||||||
optionDig.value = list_tflite[i];
|
optionDig.value = list_tflite[i];
|
||||||
_indexDig.add(optionDig);
|
_indexDig.add(optionDig);
|
||||||
}
|
}
|
||||||
else if (list_tflite[i].includes("/ana")) { // Its a digital file, only show in the analog list box
|
else if (list_tflite[i].includes("/ana")) { // Its a digit file, only show in the analog list box
|
||||||
optionAna.text = text;
|
optionAna.text = text;
|
||||||
optionAna.value = list_tflite[i];
|
optionAna.value = list_tflite[i];
|
||||||
_indexAna.add(optionAna);
|
_indexAna.add(optionAna);
|
||||||
@@ -2489,7 +2489,7 @@ function ReadParameterAll() {
|
|||||||
|
|
||||||
ReadParameter(param, "Webhook", "Uri", true);
|
ReadParameter(param, "Webhook", "Uri", true);
|
||||||
ReadParameter(param, "Webhook", "ApiKey", true);
|
ReadParameter(param, "Webhook", "ApiKey", true);
|
||||||
ReadParameter(param, "Webhook", "UploadImg", true);
|
ReadParameter(param, "Webhook", "UploadImg", false);
|
||||||
|
|
||||||
ReadParameter(param, "GPIO", "IO0", true);
|
ReadParameter(param, "GPIO", "IO0", true);
|
||||||
ReadParameter(param, "GPIO", "IO1", true);
|
ReadParameter(param, "GPIO", "IO1", true);
|
||||||
@@ -2555,7 +2555,7 @@ function UpdateExpertModus() {
|
|||||||
_style_pur = '';
|
_style_pur = '';
|
||||||
_hidden = false;
|
_hidden = false;
|
||||||
document.getElementById("Button_Edit_Config_Raw").style.display = "";
|
document.getElementById("Button_Edit_Config_Raw").style.display = "";
|
||||||
firework.launch("Expert view activated. Please use carefully", 'warning', 5000);
|
firework.launch("Expert view activated. Please use it carefully", 'warning', 5000);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
document.getElementById("Button_Edit_Config_Raw").style.display = "none";
|
document.getElementById("Button_Edit_Config_Raw").style.display = "none";
|
||||||
@@ -2821,7 +2821,7 @@ function camSettingsSet(){
|
|||||||
}
|
}
|
||||||
catch (error){}
|
catch (error){}
|
||||||
|
|
||||||
document.getElementById("overlaytext").innerHTML = "Device is busy, plase waiting...<br><br>Current step: " + _xhttp.responseText;
|
document.getElementById("overlaytext").innerHTML = "Device is busy, please wait.<br><br>Current step: " + _xhttp.responseText;
|
||||||
console.log("Device is busy, waiting 2s then checking again...");
|
console.log("Device is busy, waiting 2s then checking again...");
|
||||||
await sleep(2000);
|
await sleep(2000);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -51,9 +51,12 @@ p {font-size: 1em;}
|
|||||||
if (!loadConfig(domainname)) {
|
if (!loadConfig(domainname)) {
|
||||||
firework.launch('Setup mode could not be deactivated! Please try again!', 'danger', 30000);
|
firework.launch('Setup mode could not be deactivated! Please try again!', 'danger', 30000);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
ParseConfig();
|
|
||||||
param = getConfigParameters();
|
// ParseConfig();
|
||||||
|
// param = getConfigParameters();
|
||||||
|
param = getCamConfig();
|
||||||
|
|
||||||
param["System"]["SetupMode"]["enabled"] = true;
|
param["System"]["SetupMode"]["enabled"] = true;
|
||||||
param["System"]["SetupMode"]["value1"] = "false";
|
param["System"]["SetupMode"]["value1"] = "false";
|
||||||
|
|
||||||
|
|||||||
@@ -174,8 +174,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamZoom_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamZoom_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamZoom</td>
|
<td>$TOOLTIP_TakeImage_CamZoom</td>
|
||||||
@@ -232,8 +232,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamAec2_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamAec2_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamAec2</td>
|
<td>$TOOLTIP_TakeImage_CamAec2</td>
|
||||||
@@ -245,8 +245,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamHmirror_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamHmirror_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamHmirror</td>
|
<td>$TOOLTIP_TakeImage_CamHmirror</td>
|
||||||
@@ -267,8 +267,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamVflip_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamVflip_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamVflip</td>
|
<td>$TOOLTIP_TakeImage_CamVflip</td>
|
||||||
@@ -332,8 +332,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamAec_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamAec_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamAec</td>
|
<td>$TOOLTIP_TakeImage_CamAec</td>
|
||||||
@@ -355,8 +355,8 @@
|
|||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<select id="TakeImage_CamAutoSharpness_value1" onchange="cameraParameterChanged()">
|
<select id="TakeImage_CamAutoSharpness_value1" onchange="cameraParameterChanged()">
|
||||||
<option value="true">enable</option>
|
<option value="true">enable (true)</option>
|
||||||
<option value="false" selected>disable</option>
|
<option value="false" selected>disable (false)</option>
|
||||||
</select>
|
</select>
|
||||||
</td>
|
</td>
|
||||||
<td>$TOOLTIP_TakeImage_CamAutoSharpness</td>
|
<td>$TOOLTIP_TakeImage_CamAutoSharpness</td>
|
||||||
@@ -617,7 +617,7 @@
|
|||||||
}
|
}
|
||||||
catch (error){}
|
catch (error){}
|
||||||
|
|
||||||
document.getElementById("overlaytext").innerHTML = "Device is busy, plase waiting...<br><br>Current step: " + _xhttp.responseText;
|
document.getElementById("overlaytext").innerHTML = "Device is busy, please wait.<br><br>Current step: " + _xhttp.responseText;
|
||||||
console.log("Device is busy, waiting 5s then checking again...");
|
console.log("Device is busy, waiting 5s then checking again...");
|
||||||
await sleep(2000);
|
await sleep(2000);
|
||||||
}
|
}
|
||||||
@@ -1053,7 +1053,7 @@
|
|||||||
if (document.getElementById("ExpertModus_enabled").checked) {
|
if (document.getElementById("ExpertModus_enabled").checked) {
|
||||||
_style_pur = '';
|
_style_pur = '';
|
||||||
_hidden = false;
|
_hidden = false;
|
||||||
firework.launch("Expert parameter view activated. Please use carefully", 'warning', 5000);
|
firework.launch("Expert parameter view activated. Please use it carefully", 'warning', 5000);
|
||||||
}
|
}
|
||||||
|
|
||||||
const expert = document.querySelectorAll(".expert");
|
const expert = document.querySelectorAll(".expert");
|
||||||
|
|||||||