水印效果

图片涂鸦和水印其实是一个功能,实现的方式是一样的,就是一张大图片和一张小点图片叠加即可。前面在android图像处理系列之六--给图片添加边框(下)-图片叠加中也讲到了图片叠加,里面实现的原理是直接操作像素点。下面给出别外一种方式让图片叠加--用Canvas处理图片,canvas已经封装好了,直接调用就行。

下面看效果:

+=

代码:

[java] view plaincopy

  1. /**
  2. * 组合涂鸦图片和源图片
  3. * @param src 源图片
  4. * @param watermark 涂鸦图片
  5. * @return
  6. */
  7. public Bitmap doodle(Bitmap src, Bitmap watermark)
  8. {
  9. // 另外创建一张图片
  10. Bitmap newb = Bitmap.createBitmap(src.getWidth(), src.getHeight(), Config.ARGB_8888);// 创建一个新的和SRC长度宽度一样的位图
  11. Canvas canvas = new Canvas(newb);
  12. canvas.drawBitmap(src, 0, 0, null);// 在 0,0坐标开始画入原图片src
  13. canvas.drawBitmap(watermark, (src.getWidth() - watermark.getWidth()) / 2, (src.getHeight() - watermark.getHeight()) / 2, null); // 涂鸦图片画到原图片中间位置
  14. canvas.save(Canvas.ALL_SAVE_FLAG);
  15. canvas.restore();
  16. watermark.recycle();
  17. watermark = null;
  18. return newb;
  19. }

跟前面一样,要注意图片最好放在assets目录,另外注意图片回收,不然图片过到会造成内存紧张。这种叠加方式一般选用PNG格式的图片做为涂鸦图片或者水印,当然也可以用JPG,那就需要按照前面所说的android图像处理系列之六--给图片添加边框(下)-图片叠加进行像素点过滤,这样会影响处理速度,所以不建议用JPG图片,如果能写更高效的算法,也可以。

另外在做涂鸦的时候,需求可能会是用户可以按住涂鸦图片,然后进行拖动效果。这样的话,我给个思路,重写ImageView里面的onTouchEvent方法,MotionEvent.getAction()里面有三种状态,MotionEvent.ACTION_DOWN、MotionEvent.ACTION_UP和MotionEvent.ACTION_MOVE,根据这三种状态来判断用户的行为,决定是否移动图片,另外要注意判断涂鸦图片是否移动到原图片的边缘。由于这部分代码是跟裁剪放在一样的,不好贴出来,所以给大家一个思路,后面会把裁剪的代码贴出来。

OK,这篇就写到这里,后面还有一种图片叠加的方式,敬请期待!

水印效果,布布扣,bubuko.com

时间: 2024-08-10 02:11:15

水印效果的相关文章

WPF的TextBox水印效果详解

一种自以为是的方式: 本来只是想简单的做个水印效果,在文本框内容为空的时候提示用户输入,这种需求挺常见.网上一搜 都是丢给你你一大段xaml代码.用c#代码实现我是不倾向了 既然用wpf就得Xaml啊.首先我想到的是template嘛 wpf到处离不开template .我想到的是一个border 套一个textblock嘛 然后让文本内容通过templateBinding到Text嘛 搞得不亦乐乎 ,并且也确实很快就达到了我要的效果: 1 <TextBox> 2 <TextBox.Te

iOS图片加水印效果的实现并保存至相冊

图片加水印效果的实现并保存至相冊 实现效果如图: project下载:githubproject下载链接 代码: - (void)viewDidLoad { [super viewDidLoad]; UIImage *image = [UIImage imageNamed:@"pushu.jpg"]; UIImage *waterImage = [self waterMarkImage:image withText:@"朴树水印測试"]; UIImageWriteT

WPF之TextBox和PasswordBox水印效果

在博客园里看到了好多关于文本框和密码框水印效果的文章,今天有空也来实现一把,最终效果图如下: 文本框的话,稍微好一点直接可以绑定它的Text属性,因为他是个依赖属性,我用了二种方式来实现水印效果:触发器和数据绑定的形式: 一.触发器方式: <!--触发器的形式进行水印效果--> <Style x:Key="TxbTrigger" TargetType="TextBox" BasedOn="{StaticResource TxbBase}&

PHP实现水印效果(文字、图片)

第一种 <?php /**  * 功能:给一张图片加上水印效果  *      $i 要加水印效果的图片  *      $t 水印文字  *      $size 文字大小  *      $pos 水印的位置  *      $color 文字的颜色  *      $flag 是布尔值,主要用来区分是不是原图上加水印  *      $type 如果$flag等于false 则新图上加上水印 新文件名为 原名_txt.jpg  */ function txt($i,$t='版权所有',$s

WIN7系统IIS上发布站点后水印效果失效的解决方法

关于使用一般处理程序给图片添加水印的方法,请参考: 使用一般处理程序(IHttpHandler)制作图片水印 有些时候,给图片添加水印了,在本机运行也都正常,但是发布到IIS上后就没有水印效果了.本人做这个功能的时候就碰到这个问题了,百度了好久,都没找到合适的答案,最后还是自己慢慢摸索出来了以下几点,希望能对碰到这种问题的朋友们有些帮助: 1. 在IIS上部署HttpHandler: 选定节点,点击相应的“处理程序映射”,进入页面 选定“处理程序映射”后,点击右侧的“添加脚本映射”选项,进入相应

Winform控件的水印效果制作

在我们的项目中,为控件绘制水印效果是十分常见的事情,下面我就来说说水印效果的制作方式.其实在绝大多数情况下只有下拉框和输入框多会使用水印,比如我们看到的新浪邮箱,(如:图1).下面是输入框水印效果的代码实现:using System.Drawing;using System.Windows.Forms;namespace TextBoxWithWaterkmarkExample{ /// <summary> /// 带水印效果的TextBox /// </summary>    p

WPF实现TextBox水印效果

在日常项目中,一个TextBox需要输入用户名,我们通常的做法是先用一个TextBlock来说明,例如下面的截图: 今天将使用另外一种方式来展示,使用水印的方式.请参考下面的代码: <Window.Resources> <BooleanToVisibilityConverter x:Key="booleanToVisibilityConverter"/> <Style x:Key="EntryFieldStyle" TargetType

图片加水印效果

<div id="divpic" class="portlet" style="position: absolute; width: 600px; left: 50%; margin-left: -300px; z-index: 999; top: 788.273px; display: block;"> <img id="imgdiffrent" src="/20151015/1644012487

kindeditor HTML 编辑器 ,增加文字水印效果

<%@ Page Language="C#" AutoEventWireup="true" ValidateRequest="false" %> <!doctype html> <html> <head runat="server"> <meta charset="utf-8" /> <title>KindEditor ASP.NET&