Compare commits
4 Commits
Author | SHA1 | Date | |
---|---|---|---|
28f26a8624 | |||
d24a29b5ca | |||
900a83be54 | |||
79b8960e43 |
4
.gitignore
vendored
@ -3,4 +3,6 @@
|
||||
/build
|
||||
/dist
|
||||
Calc3D.spec
|
||||
/releases
|
||||
/releases
|
||||
*.ui
|
||||
__pycache__
|
122
Calc3D.py
@ -1,122 +0,0 @@
|
||||
import datetime
|
||||
import json
|
||||
import os
|
||||
import PySimpleGUI as Sgi
|
||||
import gettext
|
||||
import requests
|
||||
|
||||
from calculating import calculating, amortization, cost_prise
|
||||
from setts import window_setts, language, currency_setts
|
||||
from texts import calc, about, new_marge, ver, not_connect
|
||||
from update import upd_check
|
||||
|
||||
now = datetime.datetime.now()
|
||||
|
||||
|
||||
lang = gettext.translation('locale', localedir='locale', languages=[language()])
|
||||
lang.install()
|
||||
_ = lang.gettext
|
||||
|
||||
|
||||
def create_window():
|
||||
with open(os.path.expanduser('setts.json')) as f:
|
||||
theme = json.load(f)['settings']['theme']
|
||||
Sgi.theme(theme)
|
||||
menu_def = [
|
||||
[_('Файл'), [_('Настройки')], [_('Выход')]],
|
||||
[_('Помощь'), [_('Как рассчитывается стоимость'), _('Обо мне'), _('Проверить обновления')]],
|
||||
]
|
||||
|
||||
layout = [
|
||||
[Sgi.Menu(menu_def)],
|
||||
[Sgi.Txt('_' * 46)],
|
||||
[Sgi.Text('0', size=(7, 1), font=('Consolas', 32),
|
||||
text_color='white', key='result', auto_size_text=True, justification='right', expand_x=True),
|
||||
Sgi.Text(currency_setts(), font=('Consolas', 32), text_color='white', key='result')],
|
||||
[Sgi.Text(_('Себестоимость:'), font=12, text_color='white'),
|
||||
Sgi.Text('0', size=(7, 1), font=12, text_color='white', key='cost', auto_size_text=True,
|
||||
justification='right', expand_x=True),
|
||||
Sgi.Text(currency_setts(), font=('Consolas', 12), text_color='white', key='cost')],
|
||||
[Sgi.Txt('_' * 46, pad=(10, 5))],
|
||||
[Sgi.Text(_('Время печати')), Sgi.Push(), Sgi.InputText('0', size=(5, 20)), Sgi.Text(_('ч.')),
|
||||
Sgi.InputText('0', size=(5, 0)), Sgi.Text(_('мин. '))],
|
||||
[Sgi.Text(_('Масса детали')), Sgi.Push(), Sgi.InputText('0', size=(10, 20), justification='right', ),
|
||||
Sgi.Text(_('г. '))],
|
||||
[Sgi.Text(_('Количество экземпляров')), Sgi.Push(), Sgi.InputText('1', size=(10, 20), justification='right', ),
|
||||
Sgi.Text(_('шт. '))],
|
||||
[Sgi.Txt('_' * 46)],
|
||||
[Sgi.Text(_('Моделирование')), Sgi.Push(), Sgi.InputText('0', size=(10, 20), justification='right', ),
|
||||
Sgi.Text(f'{currency_setts()} ')],
|
||||
[Sgi.Text(_('Постобработка')), Sgi.Push(), Sgi.InputText('0', size=(10, 20), justification='right', ),
|
||||
Sgi.Text(f'{currency_setts()} ')],
|
||||
[Sgi.Txt('_' * 46)],
|
||||
[Sgi.Txt(' ' * 15), Sgi.ReadFormButton(_('Рассчитать'), size=(10, 2)), Sgi.Cancel(_('Выход'), size=(10, 2))]
|
||||
|
||||
]
|
||||
return Sgi.Window(f'Calc3D by Risen ver.{ver}', layout, icon='logo.ico')
|
||||
|
||||
|
||||
def main():
|
||||
window = create_window()
|
||||
|
||||
while True:
|
||||
event, values = window.read()
|
||||
|
||||
if event == _("Настройки"):
|
||||
window_setts()
|
||||
window.close()
|
||||
window = create_window()
|
||||
|
||||
elif event == _("Как рассчитывается стоимость"):
|
||||
Sgi.popup_ok(calc)
|
||||
|
||||
elif event == _("Обо мне"):
|
||||
Sgi.popup(about)
|
||||
|
||||
elif event == "Проверить обновления":
|
||||
try:
|
||||
upd_check()
|
||||
except requests.exceptions.ConnectionError:
|
||||
Sgi.popup_ok(not_connect)
|
||||
|
||||
elif event == _('Рассчитать'):
|
||||
with open(os.path.expanduser('setts.json')) as f:
|
||||
params = json.load(f)["settings"]
|
||||
try:
|
||||
hours = float(values[1])
|
||||
except ValueError:
|
||||
hours = 0
|
||||
try:
|
||||
minutes = float(values[2])
|
||||
except ValueError:
|
||||
minutes = 0
|
||||
|
||||
if minutes > 60:
|
||||
hours = hours + minutes // 60
|
||||
minutes = minutes % 60
|
||||
t = hours * 60 + minutes
|
||||
|
||||
try:
|
||||
md = values[3]
|
||||
except ValueError:
|
||||
md = 0
|
||||
|
||||
am = amortization(params['a'], t, params['spi'], now.year) # a, t, spi, year
|
||||
|
||||
cost = cost_prise(params['p'], t, params['h'], md, params['d'], params['st'], params['mk'], am,
|
||||
values[6], values[4]) # p, t, h, md, d, st, mk, am, post, x
|
||||
|
||||
try:
|
||||
result = calculating(abs(cost), values[5], params['marge']) # cost, mod, marg
|
||||
except KeyError:
|
||||
Sgi.popup_ok(new_marge)
|
||||
result = 0
|
||||
window.find_element('result').Update(result)
|
||||
window.find_element('cost').Update(cost)
|
||||
|
||||
elif event in (Sgi.WIN_CLOSED, _('Выход')):
|
||||
break
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
38
Calc3D.spec
@ -1,38 +0,0 @@
|
||||
# -*- mode: python ; coding: utf-8 -*-
|
||||
|
||||
|
||||
a = Analysis(
|
||||
['Calc3D.py'],
|
||||
pathex=[],
|
||||
binaries=[],
|
||||
datas=[],
|
||||
hiddenimports=[],
|
||||
hookspath=[],
|
||||
hooksconfig={},
|
||||
runtime_hooks=[],
|
||||
excludes=[],
|
||||
noarchive=False,
|
||||
)
|
||||
pyz = PYZ(a.pure)
|
||||
|
||||
exe = EXE(
|
||||
pyz,
|
||||
a.scripts,
|
||||
a.binaries,
|
||||
a.datas,
|
||||
[],
|
||||
name='Calc3D',
|
||||
debug=False,
|
||||
bootloader_ignore_signals=False,
|
||||
strip=False,
|
||||
upx=True,
|
||||
upx_exclude=[],
|
||||
runtime_tmpdir=None,
|
||||
console=False,
|
||||
disable_windowed_traceback=False,
|
||||
argv_emulation=False,
|
||||
target_arch=None,
|
||||
codesign_identity=None,
|
||||
entitlements_file=None,
|
||||
icon=['test.ico'],
|
||||
)
|
9
LICENSE
@ -1,9 +0,0 @@
|
||||
MIT License
|
||||
|
||||
Copyright (c) 2024 risen
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
98
README.md
@ -1,98 +0,0 @@
|
||||
# Calc3D by Risen
|
||||
Калькулятор Calc3D by Risen предназначен для быстрой оценки стоимости печати на 3D принтере,
|
||||
исходя из стоимости пластика, веса, тарифа электроэнергии и прочего...
|
||||
|
||||
## Содержание
|
||||
- [Формула расчета](#формула-расчета)
|
||||
- [Как скачать](#как-скачать)
|
||||
- [FAQ](#faq)
|
||||
- [Зачем это всё](#почему-я-решил-реализовать-этот-проект?)
|
||||
- [Команда проекта](#команда-проекта)
|
||||
- [Лицензия](#лицензия)
|
||||
-
|
||||
## Формула расчета
|
||||
|
||||
```
|
||||
S = ((p/1000*t/60*h)+(md*d*st/mk)+(a+post))*x+mod
|
||||
```
|
||||
где
|
||||
```
|
||||
S - стоимость печати, руб.
|
||||
|
||||
p - мощность принтера, Вт
|
||||
|
||||
t - время печати, мин.
|
||||
|
||||
h - тариф на электроэнергию, кВт/ч
|
||||
|
||||
md - вес детали, гр.
|
||||
|
||||
d - множитель отбраковки.
|
||||
|
||||
st - стоимость катушки пластика, руб.
|
||||
|
||||
mk - вес пластика в катушке, гр.
|
||||
|
||||
a - амортизация принтера, руб.
|
||||
|
||||
post - стоимость постобработки, руб.
|
||||
|
||||
х - количество печатаемых дубликатов, шт.
|
||||
|
||||
mod - стоимость моделирования, руб
|
||||
```
|
||||
|
||||
|
||||
## Как скачать
|
||||
Переходим в раздел "Релизы" по это ссылке: [релизы](https://git.risenhome.xyz/risen/Calc3D_by_Risen/releases)
|
||||
|
||||
Качаем последнюю версию, настраиваем свои параметры и пользуемся.
|
||||
|
||||
|
||||
## FAQ
|
||||
Раздел в процессе написания
|
||||
|
||||
## Почему я решил реализовать этот проект?
|
||||
Не нашел в интернете таких калькуляторов офлайн. Решил сделать для себя, заодно потренироваться в программировании.
|
||||
|
||||
|
||||
## Команда проекта
|
||||
Вы можете написать мне в личку в телеграм, если у Вас есть каие-то вопросы по работе калькулятора.
|
||||
|
||||
- [Risen (Colin Robinson)](tg://resolve?domain=RisenYT) — разработчик-любитель
|
||||
|
||||
## Лицензия
|
||||
MIT
|
||||
```
|
||||
Copyright (c) <2024> <Risen>
|
||||
|
||||
Данная лицензия разрешает лицам, получившим копию данного программного обеспечения и сопутствующей документации
|
||||
(далее — Программное обеспечение), безвозмездно использовать Программное обеспечение без ограничений, включая
|
||||
неограниченное право на использование, копирование, изменение, слияние, публикацию, распространение, сублицензирование
|
||||
и/или продажу копий Программного обеспечения, а также лицам, которым предоставляется данное Программное обеспечение,
|
||||
при соблюдении следующих условий:
|
||||
|
||||
Указанное выше уведомление об авторском праве и данные условия должны быть включены во все копии или значимые части
|
||||
данного Программного обеспечения.
|
||||
|
||||
ДАННОЕ ПРОГРАММНОЕ ОБЕСПЕЧЕНИЕ ПРЕДОСТАВЛЯЕТСЯ «КАК ЕСТЬ», БЕЗ КАКИХ-ЛИБО ГАРАНТИЙ, ЯВНО ВЫРАЖЕННЫХ ИЛИ ПОДРАЗУМЕВАЕМЫХ,
|
||||
ВКЛЮЧАЯ ГАРАНТИИ ТОВАРНОЙ ПРИГОДНОСТИ, СООТВЕТСТВИЯ ПО ЕГО КОНКРЕТНОМУ НАЗНАЧЕНИЮ И ОТСУТСТВИЯ НАРУШЕНИЙ,
|
||||
НО НЕ ОГРАНИЧИВАЯСЬ ИМИ. НИ В КАКОМ СЛУЧАЕ АВТОРЫ ИЛИ ПРАВООБЛАДАТЕЛИ НЕ НЕСУТ ОТВЕТСТВЕННОСТИ ПО КАКИМ-ЛИБО ИСКАМ,
|
||||
ЗА УЩЕРБ ИЛИ ПО ИНЫМ ТРЕБОВАНИЯМ, В ТОМ ЧИСЛЕ, ПРИ ДЕЙСТВИИ КОНТРАКТА, ДЕЛИКТЕ ИЛИ ИНОЙ СИТУАЦИИ,
|
||||
ВОЗНИКШИМ ИЗ-ЗА ИСПОЛЬЗОВАНИЯ ПРОГРАММНОГО ОБЕСПЕЧЕНИЯ ИЛИ ИНЫХ ДЕЙСТВИЙ С ПРОГРАММНЫМ ОБЕСПЕЧЕНИЕМ.
|
||||
```
|
||||
```
|
||||
Copyright (c) <2024> <Risen>
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated
|
||||
documentation files (the "Software"), to deal in the Software without restriction, including without limitation
|
||||
the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software,
|
||||
and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
|
||||
TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
||||
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||||
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE
|
||||
OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.```
|
BIN
__pycache__/calc3dui.cpython-311.pyc
Normal file
BIN
__pycache__/calculating.cpython-311.pyc
Normal file
50
calculating.c
Normal file
@ -0,0 +1,50 @@
|
||||
#include "calculating.h"
|
||||
|
||||
// Функция cost_prise
|
||||
double cost_prise(double p, double t, double h, double md, double d, double st, double mk, double am, double post, int x) {
|
||||
p = fabs(p); // номинальная мощность принтера (insignet int 0-5000)
|
||||
t = fabs(t); // время печати, в минутах (insignet int)
|
||||
h = fabs(h); // тариф электроэнергии, руб. (double)
|
||||
md = fabs(md); // вес детали, гр. (double)
|
||||
d = (d < 1) ? 1 : fabs(d); // коэффициент выбраковки (double)
|
||||
st = fabs(st); // стоимость катушки, руб (double 0-10000)
|
||||
mk = fabs(mk); // вес катушки, гр. (1- 10000)
|
||||
am = fabs(am); // амортизация, руб. (double)
|
||||
post = fabs(post); // постобработка, руб. (double)
|
||||
x = abs(x); // количество экземпляров, шт. (insignet int)
|
||||
|
||||
double result = ((p / 1000) * (t / 60) * h + (md * d * (st / mk)) + (am + post)) * x;
|
||||
return round(result * 100) / 100; // округление до 2 знаков после запятой
|
||||
}
|
||||
|
||||
// Функция calculating
|
||||
double calculating(double cost, double mod, double marg) {
|
||||
mod = fabs(mod); // моделирование
|
||||
double margin = fabs(marg); // процент наценки
|
||||
|
||||
double result = (margin / 100 * cost + cost) + mod;
|
||||
return round(result * 100) / 100; // округление до 2 знаков после запятой
|
||||
}
|
||||
|
||||
// Функция amortization
|
||||
double amortization(double a, double t, double spi, int year) {
|
||||
|
||||
// количество минут в году
|
||||
double minutes_in_year = 525600;
|
||||
|
||||
// Если СПИ установлен на 0, то присваеваем 1 (год)
|
||||
double year_norm;
|
||||
if (spi == 0) {
|
||||
year_norm = 100 / 1;
|
||||
} else {
|
||||
year_norm = 100 / spi;
|
||||
}
|
||||
|
||||
//Считаем годовую амортизацию
|
||||
double year_am = a * year_norm / 100;
|
||||
|
||||
//Считаем амортизацию за минуту и умножаем на время печати
|
||||
double am_per_minute = year_am / minutes_in_year * (t*60);
|
||||
|
||||
return am_per_minute; // округление до 2 знаков после запятой
|
||||
}
|
12
calculating.h
Normal file
@ -0,0 +1,12 @@
|
||||
#ifndef CALCULATING_H
|
||||
#define CALCULATING_H
|
||||
|
||||
#include <math.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
// Объявления функций
|
||||
double cost_prise(double p, double t, double h, double md, double d, double st, double mk, double am, double post, int x);
|
||||
double calculating(double cost, double mod, double marg);
|
||||
double amortization(double a, double t, double spi, int year);
|
||||
|
||||
#endif // CALCULATING_H
|
@ -1,49 +0,0 @@
|
||||
def cost_prise(p, t, h, md, d, st, mk, am, post, x):
|
||||
p = int(p) # номинальная мощность принтера
|
||||
t = int(t) # время печати, в минутах!!!
|
||||
h = float(h) # тариф электроэнергии
|
||||
md = float(md) # вес детали
|
||||
if float(d) < 1:
|
||||
d = 1
|
||||
else:
|
||||
d = float(d) # коэффициент выбраковки
|
||||
st = float(st) # стоимость катушки
|
||||
mk = float(mk) # вес катушки
|
||||
am = float(am) # амортизация
|
||||
try:
|
||||
post = float(post) # постобработка
|
||||
except ValueError:
|
||||
post = 0
|
||||
try:
|
||||
x = int(x) # количество экземпляров
|
||||
except ValueError:
|
||||
x = 1
|
||||
result = ((abs(p) / 1000) * (abs(t) / 60) * abs(h) * abs(x)) + (abs(md) * abs(d) * (abs(st) / abs(mk) * abs(x)) + abs(am) + abs(post) * abs(x))
|
||||
return round(result, 2)
|
||||
|
||||
|
||||
def calculating(cost, mod, marg):
|
||||
try:
|
||||
mod = float(mod) # моделирование
|
||||
except ValueError:
|
||||
mod = 0
|
||||
try:
|
||||
margin = float(marg) # процент наценки
|
||||
except ValueError:
|
||||
margin = 0
|
||||
result = (cost / 100 * margin + cost) + mod
|
||||
return round(result, 2)
|
||||
|
||||
|
||||
def amortization(a, t, spi, year):
|
||||
if (year % 400 == 0) or (year % 100 != 0) and (year % 4 == 0):
|
||||
minutes_in_year = 527040 / 2
|
||||
else:
|
||||
minutes_in_year = 525600 / 2
|
||||
try:
|
||||
year_norm = 100 / float(spi)
|
||||
except ZeroDivisionError:
|
||||
year_norm = 100 / 1
|
||||
year_am = float(a) / 100 * round(year_norm, 1)
|
||||
am_per_minute = year_am / minutes_in_year * t
|
||||
return round(am_per_minute, 2)
|
BIN
img/calc.png
Normal file
After Width: | Height: | Size: 1.1 KiB |
1
img/calc.svg
Normal file
@ -0,0 +1 @@
|
||||
<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 -960 960 960" width="24px" fill="#D9D9D9"><path d="M320-240h60v-80h80v-60h-80v-80h-60v80h-80v60h80v80Zm200-30h200v-60H520v60Zm0-100h200v-60H520v60Zm44-152 56-56 56 56 42-42-56-58 56-56-42-42-56 56-56-56-42 42 56 56-56 58 42 42Zm-314-70h200v-60H250v60Zm-50 472q-33 0-56.5-23.5T120-200v-560q0-33 23.5-56.5T200-840h560q33 0 56.5 23.5T840-760v560q0 33-23.5 56.5T760-120H200Zm0-80h560v-560H200v560Zm0-560v560-560Z"/></svg>
|
After Width: | Height: | Size: 482 B |
BIN
img/exit.png
Normal file
After Width: | Height: | Size: 1.9 KiB |
1
img/exit.svg
Normal file
@ -0,0 +1 @@
|
||||
<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 -960 960 960" width="24px" fill="#D9D9D9"><path d="m256-200-56-56 224-224-224-224 56-56 224 224 224-224 56 56-224 224 224 224-56 56-224-224-224 224Z"/></svg>
|
After Width: | Height: | Size: 222 B |
BIN
img/logo-1.png
Normal file
After Width: | Height: | Size: 71 KiB |
BIN
img/logo-2.png
Normal file
After Width: | Height: | Size: 14 KiB |
BIN
img/logo-3.png
Normal file
After Width: | Height: | Size: 13 KiB |
BIN
img/logo-4.png
Normal file
After Width: | Height: | Size: 7.8 KiB |
BIN
img/logo-5.png
Normal file
After Width: | Height: | Size: 6.3 KiB |
BIN
img/logo-6.png
Normal file
After Width: | Height: | Size: 3.5 KiB |
BIN
img/logo-7.png
Normal file
After Width: | Height: | Size: 2.2 KiB |
BIN
img/logo-8.png
Normal file
After Width: | Height: | Size: 776 B |
BIN
img/modeling.png
Normal file
After Width: | Height: | Size: 1.2 KiB |
BIN
img/quantity.png
Normal file
After Width: | Height: | Size: 1.4 KiB |
BIN
img/rubl.png
Normal file
After Width: | Height: | Size: 993 B |
BIN
img/time.png
Normal file
After Width: | Height: | Size: 1.7 KiB |
BIN
img/weight.png
Normal file
After Width: | Height: | Size: 1.2 KiB |
26
lists.py
@ -1,26 +0,0 @@
|
||||
themes_list = ['Black', 'BlueMono', 'BluePurple', 'BrightColors', 'BrownBlue', 'Dark', 'Dark2', 'DarkAmber',
|
||||
'DarkBlack', 'DarkBlack1', 'DarkBlue', 'DarkBlue1', 'DarkBlue10', 'DarkBlue11', 'DarkBlue12',
|
||||
'DarkBlue13', 'DarkBlue14', 'DarkBlue15', 'DarkBlue16', 'DarkBlue17', 'DarkBlue2', 'DarkBlue3',
|
||||
'DarkBlue4', 'DarkBlue5', 'DarkBlue6', 'DarkBlue7', 'DarkBlue8', 'DarkBlue9', 'DarkBrown',
|
||||
'DarkBrown1', 'DarkBrown2', 'DarkBrown3', 'DarkBrown4', 'DarkBrown5', 'DarkBrown6', 'DarkBrown7',
|
||||
'DarkGreen', 'DarkGreen1', 'DarkGreen2', 'DarkGreen3', 'DarkGreen4', 'DarkGreen5', 'DarkGreen6',
|
||||
'DarkGreen7', 'DarkGrey', 'DarkGrey1', 'DarkGrey10', 'DarkGrey11', 'DarkGrey12', 'DarkGrey13',
|
||||
'DarkGrey14', 'DarkGrey15', 'DarkGrey2', 'DarkGrey3', 'DarkGrey4', 'DarkGrey5', 'DarkGrey6',
|
||||
'DarkGrey7', 'DarkGrey8', 'DarkGrey9', 'DarkPurple', 'DarkPurple1', 'DarkPurple2', 'DarkPurple3',
|
||||
'DarkPurple4', 'DarkPurple5', 'DarkPurple6', 'DarkPurple7', 'DarkRed', 'DarkRed1', 'DarkRed2',
|
||||
'DarkTanBlue', 'DarkTeal', 'DarkTeal1', 'DarkTeal10', 'DarkTeal11', 'DarkTeal12', 'DarkTeal2',
|
||||
'DarkTeal3', 'DarkTeal4', 'DarkTeal5', 'DarkTeal6', 'DarkTeal7', 'DarkTeal8', 'DarkTeal9', 'Default',
|
||||
'Default1', 'DefaultNoMoreNagging', 'GrayGrayGray', 'Green', 'GreenMono', 'GreenTan', 'HotDogStand',
|
||||
'Kayak', 'LightBlue', 'LightBlue1', 'LightBlue2', 'LightBlue3', 'LightBlue4', 'LightBlue5',
|
||||
'LightBlue6', 'LightBlue7', 'LightBrown', 'LightBrown1', 'LightBrown10', 'LightBrown11',
|
||||
'LightBrown12', 'LightBrown13', 'LightBrown2', 'LightBrown3', 'LightBrown4', 'LightBrown5',
|
||||
'LightBrown6', 'LightBrown7', 'LightBrown8', 'LightBrown9', 'LightGray1', 'LightGreen',
|
||||
'LightGreen1', 'LightGreen10', 'LightGreen2', 'LightGreen3', 'LightGreen4', 'LightGreen5',
|
||||
'LightGreen6', 'LightGreen7', 'LightGreen8', 'LightGreen9', 'LightGrey', 'LightGrey1', 'LightGrey2',
|
||||
'LightGrey3', 'LightGrey4', 'LightGrey5', 'LightGrey6', 'LightPurple', 'LightTeal', 'LightYellow',
|
||||
'Material1', 'Material2', 'NeutralBlue', 'Purple', 'Python', 'PythonPlus', 'Reddit', 'Reds',
|
||||
'SandyBeach', 'SystemDefault', 'SystemDefault1', 'SystemDefaultForReal', 'Tan', 'TanBlue',
|
||||
'TealMono', 'Topanga']
|
||||
lang_list = ['Русский', 'English']
|
||||
|
||||
currency_list = ['руб.', '$', '€']
|
75
main.c
Normal file
@ -0,0 +1,75 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <time.h>
|
||||
#include <math.h>
|
||||
#include "calculating.h" // Подключаем заголовочный файл
|
||||
|
||||
// Загрузка настроек (заглушка, нужно заменить на чтение из БД)
|
||||
void load_settings(double *p, double *h, double *d, double *st, double *mk, double *a, double *spi, double *marge) {
|
||||
*p = 270; // номинальная мощность принтера
|
||||
*h = 3; // тариф электроэнергии
|
||||
*d = 1.5; // коэффициент выбраковки
|
||||
*st = 1500; // стоимость катушки
|
||||
*mk = 1000; // вес катушки
|
||||
*a = 15000; // амортизация
|
||||
*spi = 3; // срок полезного использования
|
||||
*marge = 150; // наценка
|
||||
}
|
||||
|
||||
int main() {
|
||||
// Загрузка настроек
|
||||
double p, h, d, st, mk, a, spi, marge;
|
||||
load_settings(&p, &h, &d, &st, &mk, &a, &spi, &marge);
|
||||
|
||||
// Ввод данных от пользователя
|
||||
printf("Введите параметры для расчета:\n");
|
||||
|
||||
double hours, minutes;
|
||||
printf("Время печати (часы): ");
|
||||
scanf("%lf", &hours);
|
||||
printf("Время печати (минуты): ");
|
||||
scanf("%lf", &minutes);
|
||||
|
||||
if (minutes > 60) {
|
||||
hours += (int)(minutes / 60);
|
||||
minutes = fmod(minutes, 60); // Используем fmod для остатка от деления
|
||||
}
|
||||
double t = hours * 60 + minutes; // Общее время в минутах
|
||||
|
||||
double md;
|
||||
printf("Масса детали (г): ");
|
||||
scanf("%lf", &md);
|
||||
|
||||
int x;
|
||||
printf("Количество экземпляров (шт): ");
|
||||
scanf("%d", &x);
|
||||
|
||||
double mod;
|
||||
printf("Моделирование (руб): ");
|
||||
scanf("%lf", &mod);
|
||||
|
||||
double post;
|
||||
printf("Постобработка (руб): ");
|
||||
scanf("%lf", &post);
|
||||
|
||||
// Получение текущего года
|
||||
time_t now = time(NULL);
|
||||
struct tm *local = localtime(&now);
|
||||
int year = local->tm_year + 1900;
|
||||
|
||||
// Расчет амортизации
|
||||
double am = amortization(a, t, spi, year);
|
||||
|
||||
// Расчет себестоимости
|
||||
double cost = cost_prise(p, t, h, md, d, st, mk, am, post, x);
|
||||
|
||||
// Расчет итоговой стоимости
|
||||
double result = calculating(cost, mod, marge);
|
||||
|
||||
// Вывод результатов
|
||||
printf("\nРезультаты расчета:\n");
|
||||
printf("Себестоимость: %.2f руб.\n", cost);
|
||||
printf("Итоговая стоимость: %.2f руб.\n", result);
|
||||
|
||||
return 0;
|
||||
}
|
15
setts.json
@ -1,15 +0,0 @@
|
||||
{
|
||||
"settings": {
|
||||
"theme": "Dark",
|
||||
"p": "270",
|
||||
"h": "3",
|
||||
"d": "0",
|
||||
"st": "1500",
|
||||
"mk": "1000",
|
||||
"a": "0",
|
||||
"spi": "0",
|
||||
"marge": "0",
|
||||
"locale": "Ru",
|
||||
"currency": "\u0440\u0443\u0431."
|
||||
}
|
||||
}
|
76
texts.py
@ -1,76 +0,0 @@
|
||||
import gettext
|
||||
import json
|
||||
import os
|
||||
|
||||
if not os.path.isfile('setts.json'):
|
||||
with open('setts.json', 'w') as file:
|
||||
data = {"settings": {"theme": "Dark",
|
||||
"p": "270",
|
||||
"h": "3",
|
||||
"d": "1.5",
|
||||
"st": "1500",
|
||||
"mk": "1000",
|
||||
"a": "0",
|
||||
"spi": "3",
|
||||
"marg": "0",
|
||||
"locale": "Ru",
|
||||
"currency": "руб."}}
|
||||
json.dump(data, file, indent=2)
|
||||
|
||||
with open('setts.json') as file:
|
||||
old_data = json.load(file)
|
||||
if old_data['settings']["locale"] == 'English':
|
||||
locale = 'en_US'
|
||||
else:
|
||||
locale = 'ru_RU'
|
||||
|
||||
lang = gettext.translation('locale', localedir='locale', languages=[locale])
|
||||
lang.install()
|
||||
_ = lang.gettext
|
||||
|
||||
calc = (_("Формула расчета стоимости печати выглядит так:\n\n"
|
||||
"S = ((p/1000*t/60*h)+(md*d*st/mk)+am+post))*x+mod\n\n"
|
||||
"где:\n"
|
||||
"S - стоимость печати, руб.\n"
|
||||
"p - мощность принтера, Вт\n"
|
||||
"t - время печати, мин.\n"
|
||||
"h - тариф на электроэнергию, кВт/ч\n"
|
||||
"md - вес детали, гр.\n"
|
||||
"st - стоимость катушки пластика, руб.\n"
|
||||
"mk - вес пластика в катушке, гр.\n"
|
||||
"d - коэффициент выбраковки\n"
|
||||
"am - амортизация, руб.\n"
|
||||
"post - стоимость постобработки, руб.\n"
|
||||
"х - количество печатаемых дубликатов, шт.\n"
|
||||
"mod - стоимость моделирования, руб.\n\n"
|
||||
"При этом в расчете вес детали, умножается на 1.5,\n"
|
||||
"это сделано для выбраковки и тестовой печати,"
|
||||
"т.е. при калькуляции вес одной детали для печати\n"
|
||||
"считается как 1,5 детали "
|
||||
"Можете изменить этот пункт в настройках.\n\n"))
|
||||
|
||||
about = (_("По вопросам и предложениям писать в телеграм на @RisenYT\n\n"))
|
||||
|
||||
amortization_calc = (_('Как считается амортизация:\n\n'
|
||||
'Отчисления записываются \n'
|
||||
'частями в зависимости от времени \n'
|
||||
'печати конкретного изделия\n'
|
||||
'Рекомендую задавать СПИ (это время\n'
|
||||
'окупаемости принтера) 3 года.\n'
|
||||
'Калькулятор считает амортизацию в\n'
|
||||
'минуту и умножает на количество минут,\n'
|
||||
'которые принтер будет печатать.'))
|
||||
|
||||
not_connect = (_('Невозможно проверить обновление.\n\n'
|
||||
'Отсутствует подключение к интернету\n'
|
||||
'или программа заблокирована фаерволом.\n\n'
|
||||
'Для продолжения работы нажмите "Ok"'))
|
||||
|
||||
new_sets = (_('Задайте стоимость принтера, \n'
|
||||
'срок полезного использования\n'
|
||||
'в настройках амортизации\n'))
|
||||
|
||||
new_marge = (_('Задайте процент желаемой наценки\n'
|
||||
'в настройках (можно просто проставить ноль)'))
|
||||
|
||||
ver = '0.6.4'
|
90
update.py
@ -1,90 +0,0 @@
|
||||
import requests
|
||||
import webbrowser
|
||||
import json
|
||||
import PySimpleGUI as Sgi
|
||||
import gettext
|
||||
|
||||
from texts import ver
|
||||
from setts import language
|
||||
|
||||
|
||||
lang = gettext.translation('locale', localedir='locale', languages=[language()])
|
||||
lang.install()
|
||||
_ = lang.gettext
|
||||
|
||||
|
||||
def upd_check():
|
||||
with open('setts.json') as json_file:
|
||||
data = json.load(json_file)
|
||||
set_theme = data["settings"]["theme"]
|
||||
|
||||
version_new = requests.get('https://risenhome.xyz/feed/Risen.json').json()["version"]["ver"]
|
||||
version_old = ver
|
||||
|
||||
if version_new > version_old:
|
||||
|
||||
Sgi.theme(set_theme)
|
||||
layout = [
|
||||
[Sgi.Text(_("Обновление"))],
|
||||
[Sgi.Text(_("Вышла новая версия программы\nНужно обновиться"))],
|
||||
[Sgi.Button(_(' Скачать ')), Sgi.Push(), Sgi.Button(_(' Отмена '))]
|
||||
]
|
||||
|
||||
window = Sgi.Window(_("Проверка обновления"), layout, modal=True)
|
||||
|
||||
while True:
|
||||
event, button = window.read()
|
||||
if event == _(' Скачать '):
|
||||
webbrowser.open('https://risenhome.xyz/calc.html', new=2, autoraise=True)
|
||||
window.close()
|
||||
elif event == _(' Отмена '):
|
||||
window.close()
|
||||
elif event == "Exit" or event == Sgi.WIN_CLOSED:
|
||||
break
|
||||
else:
|
||||
Sgi.theme(set_theme)
|
||||
layout = [
|
||||
[Sgi.Text(_('Последняя версия: ')+f'{version_new}'+_('\nВаша версия: ')+f'{version_old}'+_('\n\n'
|
||||
'Обновление не'
|
||||
' требуется'))],
|
||||
[Sgi.Button(_(' Закрыть '))]
|
||||
]
|
||||
|
||||
window = Sgi.Window(_("Проверка обновления"), layout, modal=True)
|
||||
|
||||
while True:
|
||||
event, button = window.read()
|
||||
if event == _(' Закрыть '):
|
||||
window.close()
|
||||
elif event == "Exit" or event == Sgi.WIN_CLOSED:
|
||||
break
|
||||
|
||||
|
||||
# def upd_start():
|
||||
# with open('setts.json') as json_file:
|
||||
# data = json.load(json_file)
|
||||
# set_theme = data["settings"]["theme"]
|
||||
#
|
||||
# version_new = requests.get('https://risenhome.xyz/feed/Risen.json').json()["version"]["ver"]
|
||||
# version_old = ver
|
||||
#
|
||||
# if version_new > version_old:
|
||||
#
|
||||
# Sgi.theme(set_theme)
|
||||
# layout = [
|
||||
# [Sgi.Text(_("Обновление"))],
|
||||
# [Sgi.Text(_("Вышла новая версия программы\nНужно обновиться"))],
|
||||
# [Sgi.Button(_(' Скачать ')), Sgi.Push(), Sgi.Button(' Отмена ')]
|
||||
# ]
|
||||
#
|
||||
# window = Sgi.Window(_("Вышла новая версия!"), layout, modal=True)
|
||||
#
|
||||
# while True:
|
||||
# event, button = window.read()
|
||||
# if event == _(' Скачать '):
|
||||
# webbrowser.open('https://risenhome.xyz', new=2, autoraise=True)
|
||||
# window.close()
|
||||
# elif event == _(' Отмена '):
|
||||
# window.close()
|
||||
# elif event == "Exit" or event == Sgi.WIN_CLOSED:
|
||||
# break
|