简单二次封装的Golang图像处理库:图片裁剪
简单二次封装的Golang图像处理库:图片裁剪
一.功能
- Go语言下的官方图像处理库
- 简单封装后对jpg和png图像进行缩放/裁剪的库
二.使用说明
1.首先下载
go get -v -u github.com/hunterhug/go_image
2.主要函数
按照宽度进行等比例缩放,第一参数是图像文件,第二个参数是缩放后的保存文件路径
err := ScaleF2F(filename, savepath, width)
按照宽度和高度进行等比例缩放,第一参数是图像文件,第二个参数是缩放后的保存文件路径
err = ThumbnailF2F(filename, save1path, width, height)
检测图像文件真正文件类型,并返回真实文件名,参数为图像文件位置
realfilename, err := RealImageName(savepath)
改变图像文件名,第一个参数为文件原始名字,第二个参数是文件改名后名字,第三个参数表示是否强制改名
err=ChangeImageName(savepath,realfilename,false)
三.使用示例
3.1.example.go
package main
import (
"fmt"
. "github.com/hunterhug/go_image/go_image"
)
//将某一图片文件进行缩放后存入另外的文件中
func main() {
//打印当前文件夹位置
fmt.Printf("本文件文件夹位置:%s\n", CurDir())
//图像位置
filename := "./testdata/gopher.png"
//保存位置
savepath := "./testdata/gopher400.jpg"
save1path := "./testdata/gopher400*400.png"
//宽度,高度
width := 200
height := 400
//按照宽度进行等比例缩放
err := ScaleF2F(filename, savepath, width)
if err != nil {
fmt.Printf("%s\n", err.Error())
}else{
fmt.Printf("生成按宽度缩放图%s\n",savepath)
}
//按照宽度和高度进行等比例缩放
err = ThumbnailF2F(filename, save1path, width, height)
if err != nil {
fmt.Printf("%s\n", err.Error())
}else{
fmt.Printf("生成按宽度高度缩放图%s\n",save1path)
}
//查看图像文件的真正名字
//如 ./testdata/gopher400.jpg其实是png类型,但是命名错误,需要纠正!
realfilename, err := RealImageName(savepath)
if err != nil {
fmt.Printf("%s\n", err.Error())
} else {
fmt.Printf("真正的文件名:%s\n", realfilename)
}
//文件改名,不强制性
err=ChangeImageName(savepath,realfilename,false)
if err!=nil{
fmt.Printf("文件改名失败:%s%s",realfilename,err.Error())
}
//文件改名,强制性
err=ChangeImageName(savepath,realfilename,true)
if err!=nil{
fmt.Printf("文件改名失败:%s%s",realfilename,err.Error())
}else{
fmt.Println("改名成功")
}
}
3.2.结果
本文件文件夹位置:/home/silly/golang/pikapika/src/github.com/hunterhug/go_image
生成按宽度缩放图./testdata/gopher400.jpg
生成按宽度高度缩放图./testdata/gopher400*400.png
真正的文件名:./testdata/gopher400.png
文件改名失败:./testdata/gopher400.png文件已经存在
原始图片

宽度200px等比例缩放裁剪

简单二次封装的Golang图像处理库:图片裁剪的更多相关文章
- 对百度WebUploader的二次封装,精简前端代码之图片预览上传(两句代码搞定上传)
前言 本篇文章上一篇: 对百度WebUploader开源上传控件的二次封装,精简前端代码(两句代码搞定上传) 此篇是在上面的基础上扩展出来专门上传图片的控件封装. 首先我们看看效果: 正文 使用方式同 ...
- Volley的简单二次封装
新建一个application package com.honghe.myvolley.app; import com.android.volley.RequestQueue; import com. ...
- axios 简单二次封装
import axios from 'axios' import { Message } from 'element-ui'; // 设置baseURL //axios.defaults.baseUR ...
- 毕加索的艺术——Picasso,一个强大的Android图片下载缓存库,OkHttpUtils的使用,二次封装PicassoUtils实现微信精选
毕加索的艺术--Picasso,一个强大的Android图片下载缓存库,OkHttpUtils的使用,二次封装PicassoUtils实现微信精选 官网: http://square.github.i ...
- Glide二次封装库的使用
更多代码可以查询本人GitHub:欢迎阅读,star点起来. Glide二次封装库源码 前言 为什么选择Glide? Glide 轻量级 速度快 可以根据所需加载图片的大小自动适配所需分辨率的图 支持 ...
- 图像处理库GPUImage简单使用
一.介绍 GPUImage是一个基于OpenGL ES 2.0的开源的图像处理库,作者是Brad Larson.GPUImage将OpenGL ES封装为简洁的Objective-C或Swift接口, ...
- Vue:对axios进行简单的二次封装
主要做3点: 1.配置一个请求地址前缀 2.请求拦截(在请求发出去之前拦截),给所有的请求都带上 token 3.拦截响应,遇到 token 不合法则报错 // 对 axios 的二次封装 impor ...
- golang mongodb 驱动二次封装
mongodb 官方的go驱动包 go.mongodb.org/mongo-driver 使用起来比较繁琐,最近对其进行了二次封装 github地址:https://github.com/w3liu/ ...
- OkHttp框架从入门到放弃,解析图片使用Picasso裁剪,二次封装OkHttpUtils,Post提交表单数据
OkHttp框架从入门到放弃,解析图片使用Picasso裁剪,二次封装OkHttpUtils,Post提交表单数据 我们这片博文就来聊聊这个反响很不错的OkHttp了,标题是我恶搞的,本篇将着重详细的 ...
随机推荐
- RK3399 删除开机锁屏界面
CPU:RK3399 系统:Android 7.1 删除开机锁屏界面 diff --git a/frameworks/base/packages/SettingsProvider/res/values ...
- Fiddler自动响应AutoResponder正则匹配
AutoResponder-Add-Rule Editor 两个文本框,先说第一个: Mathes: 前缀为“EXACT:”表示完全匹配(大小写敏感) 无前缀表示基本搜索,表示搜索到字符串就匹配 前缀 ...
- OpenJudge计算概论-找出第k大的数
/*================================================ 找出第k大的数 总时间限制: 1000ms 内存限制: 1000kB 描述 用户输入N和K,然后接 ...
- 知乎千万级高性能长连接网关 https://zhuanlan.zhihu.com/p/66807833
知乎千万级高性能长连接网关揭秘 9 天前 · 来自专栏 知乎技术专栏 实时的响应总是让人兴奋的,就如你在微信里看到对方正在输入,如你在王者峡谷里一呼百应,如你们在直播弹幕里不约而同的 666,它们的背 ...
- SpringBoot缓存技术
一.SpringBoot整合Ehhcache 添加maven依赖 <dependency> <groupId>org.springframework.boot</grou ...
- React 高阶组件浅析
高阶组件的这种写法的诞生来自于社区的实践,目的是解决一些交叉问题(Cross-Cutting Concerns).而最早时候 React 官方给出的解决方案是使用 mixin .而 React 也在官 ...
- 为什么vue-cli创建的build文件下没有dev-server.js文件
在新版本的Vue开发中,通过vue-cli创建的build文件夹下面已经没有了旧版本中的dev-server.js文件新版本的vue已将dev-server.js与webpack.dev.conf.j ...
- iOS笔试题01
1. #import 跟#include.@class有什么区别?#import<> 跟 #import”"又什么区别? 1> #import和#include都能完整地包 ...
- Redis集群部署与维护
Redis集群部署与维护 目录: 一. 集群架构 二. 集群部署 1. 创建redis-cluster目录 2. 编译redis 3. 编辑redis配置文件 4. 配置redis集群 5. redi ...
- layer弹出层,结合art-template实现弹出编辑
模板 <!-- 模板 --> <script id="render-tpl" type="text/html"> <div cla ...