android将图片宽高定死,Android 图片裁剪功能实现详解(类似QQ自定义头像裁剪) - 酷_莫名简单、KNothing - 51CTO技术博客...

packagecom.xiaoma.piccut.demo;

/**

* 下面这些注释是下载这个类的时候本来就有的,本来要删除的,但看了下竟然是license,吼吼,

* 好东西,留在注释里,以备不时之用,大家有需要加license的可以到下面的网址找哦

*/

//EPL, Eclipse Public License, V1.0 or later, http://www.eclipse.org/legal

//LGPL, GNU Lesser General Public License, V2.1 or later, http://www.gnu.org/licenses/lgpl.html

//GPL, GNU General Public License, V2 or later, http://www.gnu.org/licenses/gpl.html

//AL, Apache License, V2.0 or later, http://www.apache.org/licenses

//BSD, BSD License, http://www.opensource.org/licenses/bsd-license.php

/**

* A Base64 encoder/decoder.

*

* This class is used to encode and decode data in Base64 format as described in RFC 1521.

*

* Project home page: www.source-code.biz/base64coder/java

* Author: Christian d'Heureuse, Inventec Informatik AG, Zurich, Switzerland

* Multi-licensed: EPL / LGPL / GPL / AL / BSD.

*/

/**

* 这个类在上面注释的网址中有,大家可以自行下载下,也可以直接用这个,

* 公开的Base64Coder类(不用深究它是怎么实现的,

* 还是那句话,有轮子直接用轮子),好用的要死人了...

* 小马也很无耻的引用了这个网址下的东东,吼吼...

* @Title: Base64Coder.java

* @Package com.xiaoma.piccut.demo

* @Description: TODO

* @author XiaoMa

*/

publicclassBase64Coder {

//The line separator string of the operating system.

privatestaticfinalString systemLineSeparator = System.getProperty('line.separator');

//Mapping table from 6-bit nibbles to Base64 characters.

privatestaticchar[]    map1 =newchar[64];

static{

inti=0;

for(charc='A'; c<='Z'; c++) map1[i++] = c;

for(charc='a'; c<='z'; c++) map1[i++] = c;

for(charc='0'; c<='9'; c++) map1[i++] = c;

map1[i++] ='+'; map1[i++] ='/'; }

//Mapping table from Base64 characters to 6-bit nibbles.

privatestaticbyte[]    map2 =newbyte[128];

static{

for(inti=0; i

for(inti=0; i<64; i++) map2[map1[i]] = (byte)i; }

/**

* Encodes a string into Base64 format.

* No blanks or line breaks are inserted.

* @param s  A String to be encoded.

* @return   A String containing the Base64 encoded data.

*/

publicstaticString encodeString (String s) {

returnnewString(encode(s.getBytes())); }

/**

* Encodes a byte array into Base 64 format and breaks the output into lines of 76 characters.

* This method is compatible with sun.misc.BASE64Encoder.encodeBuffer(byte[]).

* @param in  An array containing the data bytes to be encoded.

* @return    A String containing the Base64 encoded data, broken into lines.

*/

publicstaticString encodeLines (byte[] in) {

returnencodeLines(in,0, in.length,76, systemLineSeparator); }

/**

* Encodes a byte array into Base 64 format and breaks the output into lines.

* @param in            An array containing the data bytes to be encoded.

* @param iOff          Offset of the first byte in in to be processed.

* @param iLen          Number of bytes to be processed in in, starting at iOff.

* @param lineLen       Line length for the output data. Should be a multiple of 4.

* @param lineSeparator The line separator to be used to separate the output lines.

* @return              A String containing the Base64 encoded data, broken into lines.

*/

publicstaticString encodeLines (byte[] in,intiOff,intiLen,intlineLen, String lineSeparator) {

intblockLen = (lineLen*3) /4;

if(blockLen <=0)thrownewIllegalArgumentException();

intlines = (iLen+blockLen-1) / blockLen;

intbufLen = ((iLen+2)/3)*4+ lines*lineSeparator.length();

StringBuilder buf =newStringBuilder(bufLen);

intip =0;

while(ip 

intl = Math.min(iLen-ip, blockLen);

buf.append (encode(in, iOff+ip, l));

buf.append (lineSeparator);

ip += l; }

returnbuf.toString(); }

/**

* Encodes a byte array into Base64 format.

* No blanks or line breaks are inserted in the output.

* @param in  An array containing the data bytes to be encoded.

* @return    A character array containing the Base64 encoded data.

*/

publicstaticchar[] encode (byte[] in) {

returnencode(in,0, in.length); }

/**

* Encodes a byte array into Base64 format.

* No blanks or line breaks are inserted in the output.

* @param in    An array containing the data bytes to be encoded.

* @param iLen  Number of bytes to process in in.

* @return      A character array containing the Base64 encoded data.

*/

publicstaticchar[] encode (byte[] in,intiLen) {

returnencode(in,0, iLen); }

/**

* Encodes a byte array into Base64 format.

* No blanks or line breaks are inserted in the output.

* @param in    An array containing the data bytes to be encoded.

* @param iOff  Offset of the first byte in in to be processed.

* @param iLen  Number of bytes to process in in, starting at iOff.

* @return      A character array containing the Base64 encoded data.

*/

publicstaticchar[] encode (byte[] in,intiOff,intiLen) {

intoDataLen = (iLen*4+2)/3;// output length without padding

intoLen = ((iLen+2)/3)*4;// output length including padding

char[] out =newchar[oLen];

intip = iOff;

intiEnd = iOff + iLen;

intop =0;

while(ip 

inti0 = in[ip++] &0xff;

inti1 = ip 

inti2 = ip 

into0 = i0 >>>2;

into1 = ((i0 &3) <<4) | (i1 >>>4);

into2 = ((i1 &0xf) <<2) | (i2 >>>6);

into3 = i2 &0x3F;

out[op++] = map1[o0];

out[op++] = map1[o1];

out[op] = op 

out[op] = op 

returnout; }

/**

* Decodes a string from Base64 format.

* No blanks or line breaks are allowed within the Base64 encoded input data.

* @param s  A Base64 String to be decoded.

* @return   A String containing the decoded data.

* @throws   IllegalArgumentException If the input is not valid Base64 encoded data.

*/

publicstaticString decodeString (String s) {

returnnewString(decode(s)); }

/**

* Decodes a byte array from Base64 format and ignores line separators, tabs and blanks.

* CR, LF, Tab and Space characters are ignored in the input data.

* This method is compatible with sun.misc.BASE64Decoder.decodeBuffer(String).

* @param s  A Base64 String to be decoded.

* @return   An array containing the decoded data bytes.

* @throws   IllegalArgumentException If the input is not valid Base64 encoded data.

*/

publicstaticbyte[] decodeLines (String s) {

char[] buf =newchar[s.length()+3];

intp =0;

for(intip =0; ip 

charc = s.charAt(ip);

if(c !=' '&& c !='\r'&& c !='\n'&& c !='\t')

buf[p++] = c; }

while((p %4) !=0)

buf[p++] ='0';

returndecode(buf,0, p); }

/**

* Decodes a byte array from Base64 format.

* No blanks or line breaks are allowed within the Base64 encoded input data.

* @param s  A Base64 String to be decoded.

* @return   An array containing the decoded data bytes.

* @throws   IllegalArgumentException If the input is not valid Base64 encoded data.

*/

publicstaticbyte[] decode (String s) {

returndecode(s.toCharArray()); }

/**

* Decodes a byte array from Base64 format.

* No blanks or line breaks are allowed within the Base64 encoded input data.

* @param in  A character array containing the Base64 encoded data.

* @return    An array containing the decoded data bytes.

* @throws    IllegalArgumentException If the input is not valid Base64 encoded data.

*/

publicstaticbyte[] decode (char[] in) {

returndecode(in,0, in.length); }

/**

* Decodes a byte array from Base64 format.

* No blanks or line breaks are allowed within the Base64 encoded input data.

* @param in    A character array containing the Base64 encoded data.

* @param iOff  Offset of the first character in in to be processed.

* @param iLen  Number of characters to process in in, starting at iOff.

* @return      An array containing the decoded data bytes.

* @throws      IllegalArgumentException If the input is not valid Base64 encoded data.

*/

publicstaticbyte[] decode (char[] in,intiOff,intiLen) {

if(iLen%4!=0)thrownewIllegalArgumentException ('Length of Base64 encoded input string is not a multiple of 4.');

while(iLen >0&& in[iOff+iLen-1] =='=') iLen--;

intoLen = (iLen*3) /4;

byte[] out =newbyte[oLen];

intip = iOff;

intiEnd = iOff + iLen;

intop =0;

while(ip 

inti0 = in[ip++];

inti1 = in[ip++];

inti2 = ip 

inti3 = ip 

if(i0 >127|| i1 >127|| i2 >127|| i3 >127)

thrownewIllegalArgumentException ('Illegal character in Base64 encoded data.');

intb0 = map2[i0];

intb1 = map2[i1];

intb2 = map2[i2];

intb3 = map2[i3];

if(b0 <0|| b1 <0|| b2 <0|| b3 <0)

thrownewIllegalArgumentException ('Illegal character in Base64 encoded data.');

into0 = ( b0       <<2) | (b1>>>4);

into1 = ((b1 &0xf)<<4) | (b2>>>2);

into2 = ((b2 &3)<<6) |  b3;

out[op++] = (byte)o0;

if(op

if(op

returnout; }

//Dummy constructor.

privateBase64Coder() {}

}// end class Base64Coder

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【优质项目推荐】 1、项目代码均经过严格本地测试,运行OK,确保功能稳定后才上传平台。可放心下载并立即投入使用,若遇到任何使用问题,随时欢迎私信反馈与沟通,博主会第一时间回复。 2、项目适用于计算机相关专业(如计科、信息安全、数据科学、人工智能、通信、物联网、自动化、电子信息等)的在校学生、专业教师,或企业员工,小白入门等都适用。 3、该项目不仅具有很高的学习借鉴价值,对于初学者来说,也是入门进阶的绝佳选择;当然也可以直接用于 毕设、课设、期末大作业或项目初期立项演示等。 3、开放创新:如果您有一定基础,且热爱探索钻研,可以在此代码基础上二次开发,进行修改、扩展,创造出属于自己的独特应用。 欢迎下载使用优质资源!欢迎借鉴使用,并欢迎学习交流,共同探索编程的无穷魅力! 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip 基于业务逻辑生成特征变量python实现源码+数据集+超详细注释.zip
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值