-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcmd.go
50 lines (47 loc) · 1.57 KB
/
cmd.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
package main
import (
"context"
"flag"
)
func run() {
constructor, manual := flags()
if !manual {
ctx, cancel := context.WithCancel(context.Background())
ffmpegProcessor := ImageProcessor{
Input: make(chan ImageInput),
endCtx: cancel,
}
StartWorkers(constructor.CreateWorkerPool(&ffmpegProcessor))
<-ctx.Done()
} else {
StartWorkers(constructor.CreateWorkerPool())
}
}
func flags() (WorkerPoolConstructor, bool) {
width := flag.Int("image-width", 1600, "width of resulting video or images")
height := flag.Int("image-height", 1600, "height of resulting video or images")
workerCount := flag.Int("worker-count", 2, "number of threads to use")
cReal := flag.Float64("constant-real", 0.280, "constant real value to be used in processing of julia set")
cImaginary := flag.Float64("constant-imaginary", 0.01, "constant imaginary value to be used in processing of julia set")
endRange := flag.Float64("end-range", 0.005, "worker loop range")
increment := flag.Float64("increment", 0.0001, "loop increment (smaller is slower, larger is faster)")
zoom := flag.Float64("zoom", 1., "zoom value")
manual := flag.Bool("manual", false, "generate a set of png's and manually convert them yourself")
flag.Parse()
return WorkerPoolConstructor{
WorkerCount: *workerCount,
endRange: *endRange,
increment: *increment,
InitialCondition: InitialCondition{
cReal: *cReal,
cImaginary: *cImaginary,
},
ImageProperties: ImageProperties{
imageHeight: *height,
imageWidth: *width,
},
CameraModifiers: CameraModifiers{
zoom: *zoom,
},
}, *manual
}