summaryrefslogtreecommitdiff
path: root/teleirc/matterbridge/vendor/github.com/Benau/tgsconverter/libtgsconverter/imagewriter.go
diff options
context:
space:
mode:
authorMistivia <i@mistivia.com>2025-11-02 15:27:18 +0800
committerMistivia <i@mistivia.com>2025-11-02 15:27:18 +0800
commite9c24f4af7ed56760f6db7941827d09f6db9020b (patch)
tree62128c43b883ce5e3148113350978755779bb5de /teleirc/matterbridge/vendor/github.com/Benau/tgsconverter/libtgsconverter/imagewriter.go
parent58d5e7cfda4781d8a57ec52aefd02983835c301a (diff)
add matterbridge
Diffstat (limited to 'teleirc/matterbridge/vendor/github.com/Benau/tgsconverter/libtgsconverter/imagewriter.go')
-rw-r--r--teleirc/matterbridge/vendor/github.com/Benau/tgsconverter/libtgsconverter/imagewriter.go40
1 files changed, 40 insertions, 0 deletions
diff --git a/teleirc/matterbridge/vendor/github.com/Benau/tgsconverter/libtgsconverter/imagewriter.go b/teleirc/matterbridge/vendor/github.com/Benau/tgsconverter/libtgsconverter/imagewriter.go
new file mode 100644
index 0000000..9549e33
--- /dev/null
+++ b/teleirc/matterbridge/vendor/github.com/Benau/tgsconverter/libtgsconverter/imagewriter.go
@@ -0,0 +1,40 @@
+package libtgsconverter
+
+import "image"
+
+type imageWriter interface {
+ init(w uint, h uint, options ConverterOptions)
+ SupportsAnimation() bool
+ AddFrame(image *image.RGBA, fps uint) error
+ Result() []byte
+}
+
+func sameImage(a *image.RGBA, b *image.RGBA) bool {
+ if len(a.Pix) != len(b.Pix) {
+ return false
+ }
+ for i, v := range a.Pix {
+ if v != b.Pix[i] {
+ return false
+ }
+ }
+ return true
+}
+
+func newImageWriter(extension string, w uint, h uint, options ConverterOptions) imageWriter {
+ var writer imageWriter
+ switch extension {
+ case "apng":
+ writer = &toapng{}
+ case "gif":
+ writer = &togif{}
+ case "png":
+ writer = &topng{}
+ case "webp":
+ writer = &towebp{}
+ default:
+ return nil
+ }
+ writer.init(w, h, options)
+ return writer
+}