commit b03790f796bb3a3a78e71d00e60f0c35e99455e2 Author: Rzy <465386466@qq.com> Date: Thu Jun 12 16:06:02 2025 +0800 first diff --git a/.idea/.gitignore b/.idea/.gitignore new file mode 100644 index 0000000..35410ca --- /dev/null +++ b/.idea/.gitignore @@ -0,0 +1,8 @@ +# 默认忽略的文件 +/shelf/ +/workspace.xml +# 基于编辑器的 HTTP 客户端请求 +/httpRequests/ +# Datasource local storage ignored files +/dataSources/ +/dataSources.local.xml diff --git a/.idea/makePpt.iml b/.idea/makePpt.iml new file mode 100644 index 0000000..5e764c4 --- /dev/null +++ b/.idea/makePpt.iml @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/.idea/modules.xml b/.idea/modules.xml new file mode 100644 index 0000000..a80b5c7 --- /dev/null +++ b/.idea/modules.xml @@ -0,0 +1,8 @@ + + + + + + + + \ No newline at end of file diff --git a/a.md b/a.md new file mode 100644 index 0000000..da70c26 --- /dev/null +++ b/a.md @@ -0,0 +1,3 @@ +```json +{"outline":{"sections":[{"contents":[{"items":[{"items":["三级章节内容"],"title":"三级章节标题"}],"subtitle":"二级章节副标题","title":"二级章节标题"}],"subtitle":"章节副标题","title":"章节标题"}],"subtitle":"ppt副标题","title":"ppt标题"}} +``` diff --git a/coze.go b/coze.go new file mode 100644 index 0000000..b4904d8 --- /dev/null +++ b/coze.go @@ -0,0 +1,134 @@ +package main + +import ( + "context" + "encoding/json" + "fmt" + "github.com/coze-dev/coze-go" + "net/http" + "time" +) + +var ( + token = "pat_3Qryy0Dgo1nA0eZ9CoTlC4GDQECphJcD7ZVWF5iSQ1qXMahca8xeWU08NFv9i8XY" + api = "https://api.coze.cn" +) + +type OutlineResp struct { + Sections []struct { + Contents []struct { + Items []struct { + Items []string `json:"items"` + Title string `json:"title"` + } `json:"items"` + Subtitle string `json:"subtitle"` + Title string `json:"title"` + } `json:"contents"` + Subtitle string `json:"subtitle"` + Title string `json:"title"` + } `json:"sections"` + Subtitle string `json:"subtitle"` + Title string `json:"title"` +} + +type ThemeResp struct { + Data []struct { + ID int `json:"id"` + Keywords string `json:"keywords"` + Thumbnail string `json:"thumbnail"` + Title string `json:"title"` + Type string `json:"type"` + } `json:"data"` +} + +type PptResp struct { + FileUrl string `json:"file_url"` +} + +func WorkflowOutline(ctx context.Context, keyword string) (resData OutlineResp, err error) { + + workflowId := "7514159115984617524" + auth := coze.NewTokenAuth(token) + // Init the Coze client through the access_token. + cozeCli := coze.NewCozeAPI(auth, coze.WithBaseURL(api), coze.WithHttpClient(&http.Client{ + Timeout: time.Second * 5000, + })) + + // if your workflow need input params, you can send them by map + data := map[string]interface{}{ + "keyword": keyword, + } + + req := &coze.RunWorkflowsReq{ + WorkflowID: workflowId, + Parameters: data, + IsAsync: false, + } + + resp, err := cozeCli.Workflows.Runs.Create(ctx, req) + + if err != nil { + return + } + json.Unmarshal([]byte(resp.Data), &resData) + return +} + +func WorkflowTheme(ctx context.Context, keyword string) (res ThemeResp, err error) { + + workflowId := "7514593043828539407" + auth := coze.NewTokenAuth(token) + // Init the Coze client through the access_token. + cozeCli := coze.NewCozeAPI(auth, coze.WithBaseURL(api), coze.WithHttpClient(&http.Client{ + Timeout: time.Second * 5000, + })) + + // if your workflow need input params, you can send them by map + data := map[string]interface{}{ + "keyword": keyword, + } + + req := &coze.RunWorkflowsReq{ + WorkflowID: workflowId, + Parameters: data, + IsAsync: false, + } + + resp, err := cozeCli.Workflows.Runs.Create(ctx, req) + fmt.Println(resp, req) + if err != nil { + return + } + err = json.Unmarshal([]byte(resp.Data), &res) + return +} + +func WorkflowPpt(ctx context.Context, outline string, themeId int) (res PptResp, err error) { + + workflowId := "7514654025384951820" + auth := coze.NewTokenAuth(token) + // Init the Coze client through the access_token. + cozeCli := coze.NewCozeAPI(auth, coze.WithBaseURL(api), coze.WithHttpClient(&http.Client{ + Timeout: time.Second * 5000, + })) + + // if your workflow need input params, you can send them by map + data := map[string]interface{}{ + "outline": outline, + "themeId": themeId, + } + + req := &coze.RunWorkflowsReq{ + WorkflowID: workflowId, + Parameters: data, + IsAsync: false, + } + fmt.Println(themeId) + resp, err := cozeCli.Workflows.Runs.Create(ctx, req) + fmt.Println(resp, err) + if err != nil { + return + } + err = json.Unmarshal([]byte(resp.Data), &res) + return +} diff --git a/coze_test.go b/coze_test.go new file mode 100644 index 0000000..b267dd5 --- /dev/null +++ b/coze_test.go @@ -0,0 +1,10 @@ +package main + +import ( + "context" + "testing" +) + +func TestFlowApi(t *testing.T) { + Workflow(context.Background(), "手搓核弹") +} diff --git a/go.mod b/go.mod new file mode 100644 index 0000000..b5cc243 --- /dev/null +++ b/go.mod @@ -0,0 +1,42 @@ +module makePpt + +go 1.24.3 + +require fyne.io/fyne/v2 v2.6.1 + +require ( + fyne.io/systray v1.11.0 // indirect + github.com/BurntSushi/toml v1.4.0 // indirect + github.com/coze-dev/coze-go v0.0.0-20250604025746-0d3b62f445d2 // indirect + github.com/davecgh/go-spew v1.1.1 // indirect + github.com/fredbi/uri v1.1.0 // indirect + github.com/fsnotify/fsnotify v1.7.0 // indirect + github.com/fyne-io/gl-js v0.1.0 // indirect + github.com/fyne-io/glfw-js v0.2.0 // indirect + github.com/fyne-io/image v0.1.1 // indirect + github.com/fyne-io/oksvg v0.1.0 // indirect + github.com/go-gl/gl v0.0.0-20231021071112-07e5d0ea2e71 // indirect + github.com/go-gl/glfw/v3.3/glfw v0.0.0-20240506104042-037f3cc74f2a // indirect + github.com/go-text/render v0.2.0 // indirect + github.com/go-text/typesetting v0.2.1 // indirect + github.com/godbus/dbus/v5 v5.1.0 // indirect + github.com/golang-jwt/jwt v3.2.2+incompatible // indirect + github.com/hack-pad/go-indexeddb v0.3.2 // indirect + github.com/hack-pad/safejs v0.1.0 // indirect + github.com/jeandeaual/go-locale v0.0.0-20241217141322-fcc2cadd6f08 // indirect + github.com/jsummers/gobmp v0.0.0-20230614200233-a9de23ed2e25 // indirect + github.com/kr/text v0.2.0 // indirect + github.com/nfnt/resize v0.0.0-20180221191011-83c6a9932646 // indirect + github.com/nicksnyder/go-i18n/v2 v2.5.1 // indirect + github.com/pmezard/go-difflib v1.0.0 // indirect + github.com/rymdport/portal v0.4.1 // indirect + github.com/srwiley/oksvg v0.0.0-20221011165216-be6e8873101c // indirect + github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef // indirect + github.com/stretchr/testify v1.10.0 // indirect + github.com/yuin/goldmark v1.7.8 // indirect + golang.org/x/image v0.24.0 // indirect + golang.org/x/net v0.35.0 // indirect + golang.org/x/sys v0.30.0 // indirect + golang.org/x/text v0.22.0 // indirect + gopkg.in/yaml.v3 v3.0.1 // indirect +) diff --git a/go.sum b/go.sum new file mode 100644 index 0000000..b4718a1 --- /dev/null +++ b/go.sum @@ -0,0 +1,84 @@ +fyne.io/fyne/v2 v2.6.1 h1:kjPJD4/rBS9m2nHJp+npPSuaK79yj6ObMTuzR6VQ1Is= +fyne.io/fyne/v2 v2.6.1/go.mod h1:YZt7SksjvrSNJCwbWFV32WON3mE1Sr7L41D29qMZ/lU= +fyne.io/systray v1.11.0 h1:D9HISlxSkx+jHSniMBR6fCFOUjk1x/OOOJLa9lJYAKg= +fyne.io/systray v1.11.0/go.mod h1:RVwqP9nYMo7h5zViCBHri2FgjXF7H2cub7MAq4NSoLs= +github.com/BurntSushi/toml v1.4.0 h1:kuoIxZQy2WRRk1pttg9asf+WVv6tWQuBNVmK8+nqPr0= +github.com/BurntSushi/toml v1.4.0/go.mod h1:ukJfTF/6rtPPRCnwkur4qwRxa8vTRFBF0uk2lLoLwho= +github.com/coze-dev/coze-go v0.0.0-20250604025746-0d3b62f445d2 h1:2OyH/CtCYSL8qzOS4dxpLWymNF6sZ5yVOsZl54mthG8= +github.com/coze-dev/coze-go v0.0.0-20250604025746-0d3b62f445d2/go.mod h1:kQAGkjYgJXNCmXDgb32ukpGvkNjM1Z4qHegTu8Eyjb0= +github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= +github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= +github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= +github.com/felixge/fgprof v0.9.3 h1:VvyZxILNuCiUCSXtPtYmmtGvb65nqXh2QFWc0Wpf2/g= +github.com/felixge/fgprof v0.9.3/go.mod h1:RdbpDgzqYVh/T9fPELJyV7EYJuHB55UTEULNun8eiPw= +github.com/fredbi/uri v1.1.0 h1:OqLpTXtyRg9ABReqvDGdJPqZUxs8cyBDOMXBbskCaB8= +github.com/fredbi/uri v1.1.0/go.mod h1:aYTUoAXBOq7BLfVJ8GnKmfcuURosB1xyHDIfWeC/iW4= +github.com/fsnotify/fsnotify v1.7.0 h1:8JEhPFa5W2WU7YfeZzPNqzMP6Lwt7L2715Ggo0nosvA= +github.com/fsnotify/fsnotify v1.7.0/go.mod h1:40Bi/Hjc2AVfZrqy+aj+yEI+/bRxZnMJyTJwOpGvigM= +github.com/fyne-io/gl-js v0.1.0 h1:8luJzNs0ntEAJo+8x8kfUOXujUlP8gB3QMOxO2mUdpM= +github.com/fyne-io/gl-js v0.1.0/go.mod h1:ZcepK8vmOYLu96JoxbCKJy2ybr+g1pTnaBDdl7c3ajI= +github.com/fyne-io/glfw-js v0.2.0 h1:8GUZtN2aCoTPNqgRDxK5+kn9OURINhBEBc7M4O1KrmM= +github.com/fyne-io/glfw-js v0.2.0/go.mod h1:Ri6te7rdZtBgBpxLW19uBpp3Dl6K9K/bRaYdJ22G8Jk= +github.com/fyne-io/image v0.1.1 h1:WH0z4H7qfvNUw5l4p3bC1q70sa5+YWVt6HCj7y4VNyA= +github.com/fyne-io/image v0.1.1/go.mod h1:xrfYBh6yspc+KjkgdZU/ifUC9sPA5Iv7WYUBzQKK7JM= +github.com/fyne-io/oksvg v0.1.0 h1:7EUKk3HV3Y2E+qypp3nWqMXD7mum0hCw2KEGhI1fnBw= +github.com/fyne-io/oksvg v0.1.0/go.mod h1:dJ9oEkPiWhnTFNCmRgEze+YNprJF7YRbpjgpWS4kzoI= +github.com/go-gl/gl v0.0.0-20231021071112-07e5d0ea2e71 h1:5BVwOaUSBTlVZowGO6VZGw2H/zl9nrd3eCZfYV+NfQA= +github.com/go-gl/gl v0.0.0-20231021071112-07e5d0ea2e71/go.mod h1:9YTyiznxEY1fVinfM7RvRcjRHbw2xLBJ3AAGIT0I4Nw= +github.com/go-gl/glfw/v3.3/glfw v0.0.0-20240506104042-037f3cc74f2a h1:vxnBhFDDT+xzxf1jTJKMKZw3H0swfWk9RpWbBbDK5+0= +github.com/go-gl/glfw/v3.3/glfw v0.0.0-20240506104042-037f3cc74f2a/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8= +github.com/go-text/render v0.2.0 h1:LBYoTmp5jYiJ4NPqDc2pz17MLmA3wHw1dZSVGcOdeAc= +github.com/go-text/render v0.2.0/go.mod h1:CkiqfukRGKJA5vZZISkjSYrcdtgKQWRa2HIzvwNN5SU= +github.com/go-text/typesetting v0.2.1 h1:x0jMOGyO3d1qFAPI0j4GSsh7M0Q3Ypjzr4+CEVg82V8= +github.com/go-text/typesetting v0.2.1/go.mod h1:mTOxEwasOFpAMBjEQDhdWRckoLLeI/+qrQeBCTGEt6M= +github.com/go-text/typesetting-utils v0.0.0-20241103174707-87a29e9e6066 h1:qCuYC+94v2xrb1PoS4NIDe7DGYtLnU2wWiQe9a1B1c0= +github.com/go-text/typesetting-utils v0.0.0-20241103174707-87a29e9e6066/go.mod h1:DDxDdQEnB70R8owOx3LVpEFvpMK9eeH1o2r0yZhFI9o= +github.com/godbus/dbus/v5 v5.1.0 h1:4KLkAxT3aOY8Li4FRJe/KvhoNFFxo0m6fNuFUO8QJUk= +github.com/godbus/dbus/v5 v5.1.0/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA= +github.com/golang-jwt/jwt v3.2.2+incompatible h1:IfV12K8xAKAnZqdXVzCZ+TOjboZ2keLg81eXfW3O+oY= +github.com/golang-jwt/jwt v3.2.2+incompatible/go.mod h1:8pz2t5EyA70fFQQSrl6XZXzqecmYZeUEB8OUGHkxJ+I= +github.com/google/pprof v0.0.0-20211214055906-6f57359322fd h1:1FjCyPC+syAzJ5/2S8fqdZK1R22vvA0J7JZKcuOIQ7Y= +github.com/google/pprof v0.0.0-20211214055906-6f57359322fd/go.mod h1:KgnwoLYCZ8IQu3XUZ8Nc/bM9CCZFOyjUNOSygVozoDg= +github.com/hack-pad/go-indexeddb v0.3.2 h1:DTqeJJYc1usa45Q5r52t01KhvlSN02+Oq+tQbSBI91A= +github.com/hack-pad/go-indexeddb v0.3.2/go.mod h1:QvfTevpDVlkfomY498LhstjwbPW6QC4VC/lxYb0Kom0= +github.com/hack-pad/safejs v0.1.0 h1:qPS6vjreAqh2amUqj4WNG1zIw7qlRQJ9K10eDKMCnE8= +github.com/hack-pad/safejs v0.1.0/go.mod h1:HdS+bKF1NrE72VoXZeWzxFOVQVUSqZJAG0xNCnb+Tio= +github.com/jeandeaual/go-locale v0.0.0-20241217141322-fcc2cadd6f08 h1:wMeVzrPO3mfHIWLZtDcSaGAe2I4PW9B/P5nMkRSwCAc= +github.com/jeandeaual/go-locale v0.0.0-20241217141322-fcc2cadd6f08/go.mod h1:ZDXo8KHryOWSIqnsb/CiDq7hQUYryCgdVnxbj8tDG7o= +github.com/jsummers/gobmp v0.0.0-20230614200233-a9de23ed2e25 h1:YLvr1eE6cdCqjOe972w/cYF+FjW34v27+9Vo5106B4M= +github.com/jsummers/gobmp v0.0.0-20230614200233-a9de23ed2e25/go.mod h1:kLgvv7o6UM+0QSf0QjAse3wReFDsb9qbZJdfexWlrQw= +github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= +github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= +github.com/nfnt/resize v0.0.0-20180221191011-83c6a9932646 h1:zYyBkD/k9seD2A7fsi6Oo2LfFZAehjjQMERAvZLEDnQ= +github.com/nfnt/resize v0.0.0-20180221191011-83c6a9932646/go.mod h1:jpp1/29i3P1S/RLdc7JQKbRpFeM1dOBd8T9ki5s+AY8= +github.com/nicksnyder/go-i18n/v2 v2.5.1 h1:IxtPxYsR9Gp60cGXjfuR/llTqV8aYMsC472zD0D1vHk= +github.com/nicksnyder/go-i18n/v2 v2.5.1/go.mod h1:DrhgsSDZxoAfvVrBVLXoxZn/pN5TXqaDbq7ju94viiQ= +github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e h1:fD57ERR4JtEqsWbfPhv4DMiApHyliiK5xCTNVSPiaAs= +github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e/go.mod h1:zD1mROLANZcx1PVRCS0qkT7pwLkGfwJo4zjcN/Tysno= +github.com/pkg/profile v1.7.0 h1:hnbDkaNWPCLMO9wGLdBFTIZvzDrDfBM2072E1S9gJkA= +github.com/pkg/profile v1.7.0/go.mod h1:8Uer0jas47ZQMJ7VD+OHknK4YDY07LPUC6dEvqDjvNo= +github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= +github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= +github.com/rymdport/portal v0.4.1 h1:2dnZhjf5uEaeDjeF/yBIeeRo6pNI2QAKm7kq1w/kbnA= +github.com/rymdport/portal v0.4.1/go.mod h1:kFF4jslnJ8pD5uCi17brj/ODlfIidOxlgUDTO5ncnC4= +github.com/srwiley/oksvg v0.0.0-20221011165216-be6e8873101c h1:km8GpoQut05eY3GiYWEedbTT0qnSxrCjsVbb7yKY1KE= +github.com/srwiley/oksvg v0.0.0-20221011165216-be6e8873101c/go.mod h1:cNQ3dwVJtS5Hmnjxy6AgTPd0Inb3pW05ftPSX7NZO7Q= +github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef h1:Ch6Q+AZUxDBCVqdkI8FSpFyZDtCVBc2VmejdNrm5rRQ= +github.com/srwiley/rasterx v0.0.0-20220730225603-2ab79fcdd4ef/go.mod h1:nXTWP6+gD5+LUJ8krVhhoeHjvHTutPxMYl5SvkcnJNE= +github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA= +github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY= +github.com/yuin/goldmark v1.7.8 h1:iERMLn0/QJeHFhxSt3p6PeN9mGnvIKSpG9YYorDMnic= +github.com/yuin/goldmark v1.7.8/go.mod h1:uzxRWxtg69N339t3louHJ7+O03ezfj6PlliRlaOzY1E= +golang.org/x/image v0.24.0 h1:AN7zRgVsbvmTfNyqIbbOraYL8mSwcKncEj8ofjgzcMQ= +golang.org/x/image v0.24.0/go.mod h1:4b/ITuLfqYq1hqZcjofwctIhi7sZh2WaCjvsBNjjya8= +golang.org/x/net v0.35.0 h1:T5GQRQb2y08kTAByq9L4/bz8cipCdA8FbRTXewonqY8= +golang.org/x/net v0.35.0/go.mod h1:EglIi67kWsHKlRzzVMUD93VMSWGFOMSZgxFjparz1Qk= +golang.org/x/sys v0.30.0 h1:QjkSwP/36a20jFYWkSue1YwXzLmsV5Gfq7Eiy72C1uc= +golang.org/x/sys v0.30.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/text v0.22.0 h1:bofq7m3/HAFvbF51jz3Q9wLg3jkvSPuiZu/pD1XwgtM= +golang.org/x/text v0.22.0/go.mod h1:YRoo4H8PVmsu+E3Ou7cqLVH8oXWIHVoX0jqUWALQhfY= +gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= +gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f h1:BLraFXnmrev5lT+xlilqcH8XK9/i0At2xKjWk4p6zsU= +gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= +gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= +gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= diff --git a/icon.png b/icon.png new file mode 100644 index 0000000..5fe9211 Binary files /dev/null and b/icon.png differ diff --git a/img/1.png b/img/1.png new file mode 100644 index 0000000..c7d4283 Binary files /dev/null and b/img/1.png differ diff --git a/main.go b/main.go new file mode 100644 index 0000000..67c4385 --- /dev/null +++ b/main.go @@ -0,0 +1,55 @@ +package main + +import ( + "context" + "fyne.io/fyne/v2" + "fyne.io/fyne/v2/app" + + "fyne.io/fyne/v2/container" + "fyne.io/fyne/v2/theme" + "fyne.io/fyne/v2/widget" +) + +type themeObj struct { + id int +} + +func main() { + var ( + content []fyne.CanvasObject + theme themeObj + ) + myWindow, myApp := InitApp() + ctx := context.Background() + keyword := widget.NewEntry() + keyword.SetPlaceHolder("请输入主题,eg:核弹的手搓过程") + //大纲 + outLine, input := ModuleOutline(ctx, keyword, myApp) + //主题 + themes := ModuleTheme(ctx, keyword, &theme) + //生成ppt + ppt := ModulePpt(ctx, input, &theme, keyword) + //添加到窗口 + + content = append(content, keyword) + content = append(content, outLine...) + content = append(content, themes...) + content = append(content, ppt...) + myWindow.SetContent(container.NewVBox( + content..., + ), + ) + //// 显示并运行窗口 + myWindow.ShowAndRun() + +} + +func InitApp() (fyne.Window, fyne.App) { + myApp := app.New() + myApp.Settings().SetTheme(theme.DefaultTheme()) + // 创建一个窗口 + myWindow := myApp.NewWindow("蓝色兄弟ppt创建测试版") + myWindow.Resize(fyne.NewSize(800, 500)) + myWindow.CenterOnScreen() + return myWindow, myApp +} diff --git a/module.go b/module.go new file mode 100644 index 0000000..b7ecf24 --- /dev/null +++ b/module.go @@ -0,0 +1,181 @@ +package main + +import ( + "context" + "encoding/json" + "fmt" + "fyne.io/fyne/v2" + "fyne.io/fyne/v2/canvas" + "fyne.io/fyne/v2/widget" +) + +type themeList struct { + Id int + url string +} + +func ModuleOutline(ctx context.Context, keyword *widget.Entry, app fyne.App) (object []fyne.CanvasObject, preview *widget.Entry) { + preview = widget.NewMultiLineEntry() + label := widget.NewLabel("") + label.Hide() + + errLabel := widget.NewLabel("") + errLabel.Hide() + keywordButton := widget.NewButton("生成大纲", nil) + keywordButton.OnTapped = func() { + label.Hide() + if keyword.Text == "" { + label.SetText("请输入主题") + label.Show() + return + } + keywordButton.SetText("大纲生成中...生成需要40-90秒,请耐心等待") + keywordButton.Disable() + go func() { + pptInfo, err := WorkflowOutline(ctx, keyword.Text) + if err != nil { + errLabel.SetText(fmt.Sprintf("生成失败:%s", err.Error())) + errLabel.Show() + } + + formattedJSON, _ := json.MarshalIndent(pptInfo, "", " ") + fyne.Do(func() { + preview.SetText("") + preview.SetText(string(formattedJSON)) + preview.SetMinRowsVisible(20) + preview.Show() + + keywordButton.SetText("生成大纲") + keywordButton.Enable() + }) + }() + } + return []fyne.CanvasObject{keyword, label, keywordButton, errLabel, preview}, preview +} + +func ModuleTheme(ctx context.Context, keyword *widget.Entry, themeObj *themeObj) []fyne.CanvasObject { + var ( + selectBox = widget.NewSelect(nil, nil) + img = canvas.NewImageFromFile("./img/1.png") + ) + img.SetMinSize(fyne.NewSize(200, 200)) + img.FillMode = canvas.ImageFillContain + img.Hide() + errLabel := widget.NewLabel("") + errLabel.Hide() + themeButton := widget.NewButton("生成主题", nil) + themeButton.OnTapped = func() { + errLabel.Hide() + if keyword.Text == "" { + errLabel.SetText("请输入主题") + errLabel.Show() + return + } + themeButton.SetText("主题生成中...") + themeButton.Disable() + themes, err := WorkflowTheme(ctx, keyword.Text) + fmt.Println(themes) + fmt.Println(err) + if err != nil || len(themes.Data) == 0 { + errLabel.SetText(fmt.Sprintf("生成失败:%v", err)) + errLabel.Show() + themeButton.SetText("生成主题") + themeButton.Enable() + return + } + var ( + themeMap = make(map[string]themeList, len(themes.Data)) + themeNameSlice = make([]string, len(themes.Data)) + ) + if len(themes.Data) == 0 { + return + } + + for k, theme := range themes.Data { + themeMap[theme.Title] = themeList{ + Id: theme.ID, + url: theme.Thumbnail, + } + fmt.Println(theme.Title) + themeNameSlice[k] = theme.Title + } + + selectBox.ClearSelected() + selectBox.SetOptions(themeNameSlice) + selectBox.SetSelectedIndex(0) + img.File = GetImg(themes.Data[0].Thumbnail) + themeObj.id = themes.Data[0].ID + img.Refresh() + img.Show() + selectBox.OnChanged = func(value string) { + themeObj.id = themeMap[value].Id + img.File = GetImg(themeMap[value].url) + fmt.Println(themeObj.id, img.File) + img.Refresh() + img.Show() + } + selectBox.Refresh() + selectBox.Show() + themeButton.SetText("生成主题") + themeButton.Enable() + } + + return []fyne.CanvasObject{themeButton, errLabel, img, selectBox} + +} + +func ModulePpt(ctx context.Context, sectionInput *widget.Entry, themeObj *themeObj, keyword *widget.Entry) []fyne.CanvasObject { + hyperlink := widget.NewHyperlink("点击查看ppt", nil) + hyperlink.Hide() + + errLabel := widget.NewLabel("") + errLabel.Hide() + createButton := widget.NewButton("生成ppt", nil) + createButton.OnTapped = func() { + if sectionInput.Text == "" { + errLabel.SetText("请输入大纲") + errLabel.Show() + return + } + if themeObj.id == 0 { + errLabel.SetText("请选择主题") + errLabel.Show() + return + } + createButton.SetText("ppt生成中...") + createButton.Disable() + go func() { + ppt, err := WorkflowPpt(ctx, sectionInput.Text, themeObj.id) + + if err != nil { + errLabel.SetText(fmt.Sprintf("生成失败:%s", err.Error())) + errLabel.Show() + return + } + fileUrl := ppt.FileUrl + //fileUrl := "https://lf-bot-studio-plugin-resource.coze.cn/obj/bot-studio-platform-plugin-tos/artist/image/a37e601ca0f64de8844279a138210c5e.ppt" + + file := DownloadPpt(fileUrl, keyword.Text) + fmt.Println(fileUrl) + fmt.Println("文件地址:" + file) + fyne.Do(func() { + errLabel.SetText("ppt生成成功") + hyperlink.SetURLFromString(file) + hyperlink.Refresh() + hyperlink.Show() + createButton.SetText("生成ppt") + createButton.Enable() + }) + }() + + } + return []fyne.CanvasObject{createButton, errLabel, hyperlink} + +} +func Eg() string { + return "\n================================================================================\n\n## 1. 核弹的基础知识\n##### 🌈核弹的起源、分类及其基本原理\n\n---\n\n## 1.1 核能的发现与发展\n##### 从核裂变到核聚变的历史进程\n\n🌟**核裂变的发现**: 揭示核裂变原理及其对科学界的影响,奠定核能利用的基础。\n\n🌟**早期核能研究**: 回顾二战期间核能开发的关键事件与技术突破,推动历史进程。\n\n🌟**核聚变的研究**: 探讨核聚变理论发展及其实验进展,展望其未来潜力与挑战。\n\n🌟**核技术的演变**: 总结从核裂变到核聚变的技术进步,分析其对社会的深远意义。\n\n---\n\n## 1.2 核弹的类型与特点\n##### 原子弹、氢弹及中子弹的区别与应用场景\n\n🌟**原子弹原理**: 介绍原子弹的基本工作原理及裂变反应过程,分析其在军事中的应用特点。\n\n🌟**氢弹构造**: 阐述氢弹的聚变反应机制,探讨其威力远超原子弹的原因及战略意义。\n\n🌟**中子弹特性**: 解释中子弹的设计理念,强调其高辐射低爆炸的特点及其特殊用途。\n\n🌟**各类型对比**: 对比原子弹、氢弹和中子弹在技术实现和杀伤效果上的主要差异。\n\n🌟**应用场景分析**: 分析三种核弹在不同作战环境下的适用性及可能带来的后果。\n\n🌟**发展趋势展望**: 探讨未来核弹技术发展方向及国际社会对其使用的限制与管控。\n\n---\n\n## 1.3 核弹的工作原理\n##### 裂变反应与聚变反应的核心机制\n\n🌟**裂变反应基础**: 介绍原子核裂变过程及链式反应形成原理。\n\n🌟**聚变反应机制**: 解析轻核聚变条件及其释放能量的核心过程。\n\n🌟**反应触发方式**: 探讨如何通过引爆装置启动核反应过程。\n\n🌟**材料与临界质量**: 分析核材料特性及达到链式反应所需的临界条件。\n\n🌟**能量释放过程**: 描述核反应中能量的转化与释放的具体步骤。\n\n🌟**反应控制技术**: 研究在实验条件下对核反应速率的控制方法。\n\n🌟**反应产物分析**: 总结核反应后生成物的种类及其放射性特征。\n\n🌟**安全防护措施**: 讨论核反应过程中防止辐射泄漏的技术手段。\n\n---\n\n## 1.4 核弹的历史背景\n##### 第二次世界大战期间核武器的研发历程\n\n🌟**二战核研发开端**: 描述二战期间核武器研发的起因与初期探索。\n\n🌟**曼哈顿计划详情**: 介绍美国曼哈顿计划的核心内容及关键进展。\n\n🌟**核武时代序幕**: 总结二战后核武器对国际局势的影响及后续发展。\n\n---\n\n## 1.5 核武器对全球的影响\n##### 冷战时期核威慑与现代国际关系\n\n🌟**冷战核威慑**: 冷战期间核武器如何形成相互确保摧毁的威慑态势。\n\n🌟**核军备竞赛**: 各大国在冷战时期的核武器研发与部署竞争及其后果。\n\n🌟**现代核战略**: 当前国际关系中核武器的角色与影响,包括核裁军努力。\n\n🌟**全球安全挑战**: 核武器对全球安全的持续威胁及国际合作应对措施。\n\n\n================================================================================\n\n## 2. 模拟核弹的设计与构建\n##### 🌈理解核弹设计的关键要素\n\n---\n\n## 2.1 核材料的选择与制备\n##### 铀-235和钚-239的提取与纯化技术\n\n🌟**铀-235提取技术**: 介绍铀-235的提取方法,包括气体扩散和离心法。\n\n🌟**钚-239制备工艺**: 讲解钚-239的生产流程,涉及反应堆中铀-238的转化。\n\n🌟**材料纯化步骤**: 描述核材料纯化的关键步骤,确保高纯度标准。\n\n🌟**安全处理措施**: 强调在核材料制备过程中必须遵循的安全规范。\n\n🌟**质量控制体系**: 阐述质量检测与控制方法,保证材料符合设计要求。\n\n---\n\n## 2.2 核装置的核心结构\n##### 触发器、反射层及引爆系统的功能\n\n🌟**触发器设计**: 揭示触发器的工作原理及其在核装置中的关键作用,确保精准引爆。\n\n🌟**反射层功能**: 分析反射层如何提高核反应效率,减少中子流失,增强爆炸威力。\n\n🌟**引爆系统组成**: 详解引爆系统的结构与功能,确保各部件协同工作以实现可靠引爆。\n\n---\n\n## 2.3 核爆炸的触发机制\n##### 中子源的作用与临界质量的计算\n\n🌟**中子源功能解析**: 解释中子源在核爆炸触发中的关键作用及类型选择。\n\n🌟**临界质量计算方法**: 探讨如何精确计算不同材料的临界质量以确保链式反应。\n\n🌟**触发机制设计原理**: 分析触发机制的设计原则及其对核爆炸效率的影响。\n\n---\n\n## 2.4 核弹的安全性设计\n##### 如何防止意外引爆与误用风险\n\n🌟**防护机制**: 设计多重防护确保核弹不会因意外触发引爆。\n\n🌟**授权系统**: 建立严格授权流程避免核弹被未经授权使用。\n\n🌟**环境监测**: 通过环境感应技术防止非正常条件下启动核弹。\n\n🌟**故障检测**: 实施实时故障检测减少因技术问题导致的误用风险。\n\n---\n\n## 2.5 核试验的模拟过程\n##### 数字化仿真与理论验证的重要性\n\n🌟**仿真模型构建**: 探讨数字化仿真在核试验中的应用,建立精确的物理模型。\n\n🌟**数据分析与验证**: 利用理论计算验证仿真结果,确保数据准确性与可靠性。\n\n🌟**爆炸过程模拟**: 模拟核弹爆炸全过程,分析能量释放与冲击波传播特性。\n\n🌟**环境影响评估**: 数字化仿真预测核试验对环境的影响,提供决策依据。\n\n🌟**技术优化改进**: 通过仿真结果反馈,不断优化设计提高核弹性能。\n\n\n================================================================================\n\n## 3. 核弹的技术挑战与科学突破\n##### 🌈克服核武器研发中的技术难题\n\n---\n\n## 3.1 材料科学的进展\n##### 新型核材料的研究与应用\n\n🌟**新型核材料研究**: 探讨用于核弹的新型核材料特性及其潜在应用价值。\n\n🌟**材料稳定性提升**: 分析如何通过技术手段提高核材料在极端条件下的稳定性。\n\n🌟**应用技术突破**: 介绍新型核材料在实际应用中的技术突破与创新点。\n\n🌟**材料安全性改进**: 概述提升核材料安全性的方法及其对核技术发展的影响。\n\n---\n\n## 3.2 工程设计的复杂性\n##### 多学科协作解决核装置设计问题\n\n🌟**多学科协作**: 各领域专家共同解决核装置设计中的复杂问题,确保技术可行性。\n\n🌟**设计优化**: 通过模拟与实验不断改进设计方案,提升性能与安全性。\n\n🌟**材料选择**: 精选适合极端条件的材料,保障核装置稳定运行与长效使用。\n\n---\n\n## 3.3 计算机建模与仿真\n##### 高性能计算在核武器研究中的作用\n\n🌟**高性能计算基础**: 探讨高性能计算在核武器研究中的核心作用,包括其对复杂物理过程的模拟能力。\n\n🌟**核爆仿真技术**: 介绍计算机建模如何重现核爆炸过程,提升对核反应机制的理解和预测能力。\n\n🌟**数据处理与分析**: 分析海量数据处理方法,优化计算资源利用,提高仿真的精确度和效率。\n\n🌟**模型验证与优化**: 研究模型验证流程,确保仿真结果的可靠性,并通过持续优化改进计算方法。\n\n---\n\n## 3.4 精确引爆技术的发展\n##### 微电子技术与核弹控制系统的结合\n\n🌟**微电子技术应用**: 探讨微电子技术在核弹控制系统中的关键作用与实现方式。\n\n🌟**控制系统设计**: 分析核弹精确引爆技术中控制系统的结构与功能优化方法。\n\n🌟**数据传输安全**: 研究微电子技术支持下核弹控制系统中的数据传输加密与防护。\n\n🌟**实时监测技术**: 介绍微电子技术如何助力核弹引爆过程中的实时监测与反馈调整。\n\n---\n\n## 3.5 核废料的处理与管理\n##### 核武器生产后的环境影响与解决方案\n\n🌟**核废料的环境影响**: 分析核武器生产对环境造成的长期污染及生态破坏。\n\n🌟**废料处理技术发展**: 探讨当前核废料处理技术的进步与未来发展方向。\n\n🌟**安全储存解决方案**: 介绍核废料安全储存的方法及其面临的挑战与风险。\n\n🌟**国际管理标准**: 概述全球核废料管理的标准与合作机制以减少环境危害。\n\n🌟**可持续管理策略**: 提出实现核废料可持续管理的政策建议与技术创新。\n\n\n================================================================================\n\n## 4. 核武器的伦理与法律问题\n##### 🌈探讨核武器使用与和平发展的平衡\n\n---\n\n## 4.1 核武器的人道主义争议\n##### 核战争对人类社会的毁灭性后果\n\n🌟**毁灭性后果**: 核战争将导致大规模死亡与生态灾难,威胁全人类生存。\n\n🌟**人道主义影响**: 核武器使用造成无辜平民的巨大痛苦与长期健康损害。\n\n🌟**国际法约束**: 当前国际法对核武器使用的限制及其在人道主义争议中的作用。\n\n🌟**和平解决方案**: 推动全球无核化以避免核战争带来的毁灭性人道主义后果。\n\n---\n\n## 4.2 国际条约与核不扩散机制\n##### 《不扩散核武器条约》的意义与执行\n\n🌟**条约背景**: 介绍《不扩散核武器条约》诞生的历史背景与国际形势。\n\n🌟**核心内容**: 概述条约的主要条款及其对核不扩散机制的贡献。\n\n🌟**执行挑战**: 分析条约在执行过程中面临的困难与争议问题。\n\n🌟**未来展望**: 探讨如何加强条约效力以应对新的国际安全威胁。\n\n---\n\n## 4.3 核军备竞赛的历史教训\n##### 冷战时期的军备竞赛对全球安全的影响\n\n🌟**冷战背景**: 冷战时期美苏核军备竞赛的起因与过程。\n\n🌟**安全影响**: 核武器扩张对全球安全局势的深远威胁。\n\n🌟**古巴危机**: 古巴导弹危机揭示核战争边缘的危险性。\n\n🌟**裁军努力**: 国际社会为缓解核竞赛所作的努力与协议。\n\n🌟**历史反思**: 核军备竞赛的历史教训对当今世界的启示。\n\n---\n\n## 4.4 和平利用核能的可能性\n##### 核技术在医疗、能源等领域的应用前景\n\n🌟**核能在医疗的应用**: 探讨核技术在癌症治疗和医学成像中的应用前景。\n\n🌟**核能发电的优势**: 分析核能作为清洁能源在缓解能源危机中的作用。\n\n🌟**核技术在农业的潜力**: 介绍核技术提高农作物产量和品质的可能应用。\n\n🌟**核废料的安全处理**: 研究如何通过技术创新减少核能利用带来的环境风险。\n\n🌟**国际合作与监管**: 探讨和平利用核能所需的国际合作与法律框架。\n\n🌟**公众认知与接受度**: 分析如何提升公众对核能和平利用的信任和支持。\n\n---\n\n## 4.5 全球无核化的未来展望\n##### 国际社会如何推动核裁军与和平发展\n\n🌟**核裁军进程**: 探讨国际社会推动核裁军的具体措施与历史进程。\n\n🌟**和平利用核能**: 分析如何在无核化背景下促进核能的和平与发展应用。\n\n🌟**未来展望**: 展望全球无核化的可能性及其对世界和平的深远影响。\n\n\n================================================================================\n\n## 5. 科幻视角下的核武器\n##### 🌈文学与影视作品中的核武器想象\n\n---\n\n## 5.1 核战争题材的经典作品\n##### 《末日之战》与《核子惊爆》的文学价值\n\n🌟**末日之战解析**: 探讨《末日之战》中核战争的描写及其对人类社会的影响。\n\n🌟**核子惊爆主题**: 分析《核子惊爆》如何展现核武器威胁与人性挣扎。\n\n🌟**文学价值探讨**: 深入挖掘两部作品在文学史上的地位及独特贡献。\n\n🌟**社会反思意义**: 揭示经典作品对核战争的警示作用及推动和平的价值。\n\n🌟**创作背景研究**: 回顾作者创作动机与时代背景,理解作品深层含义。\n\n---\n\n## 5.2 核武器在科幻电影中的表现\n##### 《星球大战》与《红色警戒》中的科技幻想\n\n🌟**星球大战的幻想**: 探讨《星球大战》中核武器般的超级武器,展现其对宇宙战争的影响与科技想象。\n\n🌟**红色警戒的技术**: 分析《红色警戒》中核弹技术的应用,展示未来战争中科技与策略的结合。\n\n🌟**科幻中的现实思考**: 从科幻作品反思核武器的潜在威胁及人类对科技力量的依赖与恐惧。\n\n---\n\n## 5.3 核灾难的文化反思\n##### 核武器对人类文明的警示意义\n\n🌟**核爆后的世界**: 描绘核灾难对地球环境与人类社会的毁灭性影响。\n\n🌟**科幻作品中的反思**: 探讨科幻小说和电影中对核武器使用的深刻警示意义。\n\n🌟**文化艺术的表达**: 分析文化艺术如何通过核主题传达对和平的渴望与追求。\n\n🌟**历史教训的总结**: 回顾历史上的核事件,总结其对人类文明发展的深远启示。\n\n🌟**和平主义的兴起**: 讨论核武器威胁下全球和平主义思潮的兴起及其影响。\n\n🌟**未来可能性展望**: 展望避免核灾难的技术与政策发展方向,强调国际合作的重要性。\n\n---\n\n## 5.4 虚构核武器的技术可能性\n##### 科幻设定中的科学依据与合理性\n\n🌟**科学依据分析**: 探讨科幻设定中核武器的技术原理与现实科学的联系。\n\n🌟**技术可行性评估**: 分析虚构核武器在当前科技水平下的实现可能性与挑战。\n\n🌟**合理性探讨**: 研究科幻作品中核武器设计是否符合物理规律与逻辑。\n\n---\n\n## 5.5 未来核武器的形态预测\n##### 下一代核武器可能的发展方向\n\n🌟**智能化核武器**: 探讨人工智能在核武器中的应用,提升精准度与自主决策能力。\n\n🌟**可控小型核弹**: 分析未来小型化核弹头趋势,实现高威力低附带损伤。\n\n🌟**定向能核装置**: 研究定向能技术结合核反应,开发新型高效能武器系统。\n\n🌟**量子加密防护**: 探索量子技术保障核武通讯安全,防止未经授权使用。\n\n🌟**太空部署核威慑**: 讨论未来太空核武器化可能性及其对全球战略平衡的影响。\n\n🌟**环保型核材料**: 预测使用更清洁核燃料减少长期辐射污染的潜在发展方向。\n" +} + +func Eg2() string { + return "\n================================================================================\n\n## 1. 核弹的基础知识\n##### 🌈核弹的起源、" +} diff --git a/ppt/2025中国足球-1749709451.pptx b/ppt/2025中国足球-1749709451.pptx new file mode 100644 index 0000000..6654ad7 Binary files /dev/null and b/ppt/2025中国足球-1749709451.pptx differ diff --git a/theme.go b/theme.go new file mode 100644 index 0000000..3761ea6 --- /dev/null +++ b/theme.go @@ -0,0 +1,32 @@ +package main + +import ( + "fyne.io/fyne/v2" + "fyne.io/fyne/v2/theme" + "image/color" +) + +type myTheme struct{} + +func (t myTheme) Color(name fyne.ThemeColorName, variant fyne.ThemeVariant) color.Color { + //TODO implement me + return color.RGBA{0, 128, 255, 255} +} + +func (t myTheme) Font(style fyne.TextStyle) fyne.Resource { + //TODO implement me + return theme.DefaultTextFont() +} + +func (t myTheme) Icon(name fyne.ThemeIconName) fyne.Resource { + //TODO implement me + return theme.DefaultTextFont() +} + +func (t myTheme) Size(name fyne.ThemeSizeName) float32 { + //TODO implement me + return 0 +} + +func (myTheme) BackgroundColor() color.Color { return color.RGBA{0, 128, 255, 255} } +func (myTheme) ButtonColor() color.Color { return color.RGBA{0, 255, 128, 255} } diff --git a/tools.go b/tools.go new file mode 100644 index 0000000..892513d --- /dev/null +++ b/tools.go @@ -0,0 +1,56 @@ +package main + +import ( + "fmt" + "io" + "net/http" + "os" + "path/filepath" + "strings" + "time" +) + +func GetImg(url string) string { + path, _ := os.Getwd() + imgPath := fmt.Sprintf("%s/%s", path, "img") + dir := filepath.Dir(imgPath) + if _, err := os.Stat(dir); os.IsNotExist(err) { + os.MkdirAll(dir, 0755) + } + urlSlice := strings.Split(url, "/") + fileName := fmt.Sprintf("%s/%s", imgPath, urlSlice[len(urlSlice)-1]) + _, err := os.Stat(fileName) + if os.IsNotExist(err) { + DownloadFile(url, fileName) + } + return fileName + +} + +func DownloadFile(url string, fileName string) { + resp, _ := http.Get(url) + + defer resp.Body.Close() + out, _ := os.Create(fileName) + io.Copy(out, resp.Body) + defer out.Close() +} + +func DownloadPpt(url string, fileName string) (file string) { + path, _ := os.Getwd() + pptPath := fmt.Sprintf("%s/%s", path, "ppt") + dir := filepath.Dir(pptPath) + fmt.Println(pptPath) + if _, err := os.Stat(dir); os.IsNotExist(err) { + e := os.MkdirAll(dir, 0755) + fmt.Println(e) + } + fileName = fmt.Sprintf("%s-%d", fileName, time.Now().Unix()) + file = fmt.Sprintf("%s/%s.%s", pptPath, fileName, "pptx") + resp, _ := http.Get(url) + defer resp.Body.Close() + out, _ := os.Create(file) + io.Copy(out, resp.Body) + defer out.Close() + return +}