iis服务器助手广告
返回顶部
首页 > 资讯 > 精选 >Android如何制作画画板
  • 199
分享到

Android如何制作画画板

android 2023-05-30 21:05:28 199人浏览 八月长安
摘要

这篇文章主要为大家展示了“Android如何制作画画板”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Android如何制作画画板”这篇文章吧。本文实例为大家分享了Android画画板展示的具体代

这篇文章主要为大家展示了“Android如何制作画画板”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Android如何制作画画板”这篇文章吧。

本文实例为大家分享了Android画画板展示的具体代码,供大家参考,具体内容如下

main.xml布局

<RelativeLayout xmlns:android="Http://schemas.android.com/apk/res/android"  xmlns:tools="http://schemas.android.com/tools" android:id="@+id/activity_main"  android:layout_width="match_parent" android:layout_height="match_parent"  tools:context="com.example.demo.MainActivity">  <ImageView    android:id="@+id/iv"    android:layout_width="wrap_content"    android:layout_height="wrap_content"    android:src="@drawable/bg"    />  <LinearLayout    android:layout_width="match_parent"    android:layout_height="wrap_content"    android:orientation="horizontal"    android:layout_alignParentBottom="true"    >    <Button      android:id="@+id/red"      android:layout_width="wrap_content"      android:layout_height="wrap_content"      android:text="红色"      android:onClick="onplay"      />    <Button      android:id="@+id/green"      android:layout_width="wrap_content"      android:layout_height="wrap_content"      android:text="绿色"      android:onClick="onplay"      />    <Button      android:id="@+id/root"      android:layout_width="wrap_content"      android:layout_height="wrap_content"      android:text="刷子"      android:onClick="onplay"      />    <Button      android:id="@+id/save"      android:layout_width="wrap_content"      android:layout_height="wrap_content"      android:text="保存"      android:onClick="onplay"      />    <Button      android:id="@+id/finish"      android:layout_width="wrap_content"      android:layout_height="wrap_content"      android:text="涂漆"      android:onClick="onplay"      />  </LinearLayout></RelativeLayout>

main布局

public class MainActivity extends AppCompatActivity {private Bitmap bitmap;  private canvas canvas;private ImageView iv;  private int startx;  private int starty;  private Paint paint;  private Bitmap bmSrc;  @Override  protected void onCreate(Bundle savedInstanceState) {    super.onCreate(savedInstanceState);    setContentView(R.layout.activity_main);    //加载原图    bmSrc = BitmapFactory.decodeResource(getResources(), R.drawable.bg);    //创建白纸,宽,高,图片的参数     bitmap = Bitmap.createBitmap(bmSrc.getWidth(), bmSrc.getHeight(), bmSrc.getConfig());    //创建画板,参数是白纸对象    canvas = new Canvas(bitmap);    //创建画笔    paint = new Paint();    //在纸上作画    iv=(ImageView)findViewById(R.id.iv);    canvas.drawBitmap(bmSrc,new Matrix(), paint);    //-----------------手势识别器和画笔结合的知识-------------------  //给控件设置手势适配器,可以得到用户在这个控件上所做的手势    iv.setOnTouchListener(new View.OnTouchListener() {      //当用户手在这个控件时,指的就是用户的手对控件滑动,按下,松开的三种场景,自动回调      @Override      public boolean onTouch(View view, MotionEvent motionEvent) {        switch (motionEvent.getAction()){          case MotionEvent.ACTION_DOWN://按下时回调一次            //获取用户手指按下时的坐标            startx = (int) motionEvent.getX();            starty = (int) motionEvent.getY();            break;          case MotionEvent.ACTION_MOVE://手指滑动时,不停地调用            int newx = (int) motionEvent.getX();            int newy = (int) motionEvent.getY();            //在背景图画线            canvas.drawLine(startx,starty,newx,newy, paint);            startx=newx;            starty=newy;            iv.setImageBitmap(bitmap);            break;          case MotionEvent.ACTION_UP://松开时回调一次            break;        }        //事情分发机制        //true:iv处理该触摸事件        //false:iv不处理该触摸事件,事件传递给上一级        return true;      }    });  }  public void onplay(View view){   switch (view.getId()){     case R.id.red:       paint.setColor(Color.RED);       break;     case R.id.green:       paint.setColor(Color.GREEN);       break;     case R.id.root:       paint.setStrokeWidth(5);       break;     case R.id.save:       if(SaveViewUtil.saveScreen(iv)){         Toast.makeText(this, "截图成功", Toast.LENGTH_SHORT).show();       }else{         Toast.makeText(this, "截图失败,请检查sdcard是否可用", Toast.LENGTH_SHORT).show();       }       break;     //涂漆     case R.id.finish:       canvas.drawRect(new Rect(0,0,width,height), paint);       break;     }   }  }

这是一个把画的图存储SD卡的工具

public class SaveViewUtil {    private static final File rootDir = new File(Environment.getExternalStorageDirectory()+File.separator);    public static boolean saveScreen(View view){   //判断sdcard是否可用   if(!Environment.MEDIA_MOUNTED.equals(Environment.getExternalStorageState())){     return false;   }   if(!rootDir.exists()){     rootDir.mkdir();   }   view.setDrawinGCacheEnabled(true);   view.buildDrawingCache();   Bitmap bitmap = view.getDrawingCache();   try {     bitmap.compress(CompressFORMat.JPEG, 100, new FileOutputStream(new File(rootDir,System.currentTimeMillis()+".jpg")));     return true;   } catch (FileNotFoundException e) {     e.printStackTrace();     return false;   }finally{     view.setDrawingCacheEnabled(false);     bitmap = null;   }  }}<!-- 往SDCard写入数据权限 --><uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>

以上是“Android如何制作画画板”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网精选频道!

--结束END--

本文标题: Android如何制作画画板

本文链接: https://www.lsjlt.com/news/221384.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Android如何制作画画板
    这篇文章主要为大家展示了“Android如何制作画画板”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Android如何制作画画板”这篇文章吧。本文实例为大家分享了Android画画板展示的具体代...
    99+
    2023-05-30
    android
  • HTML5如何制作简单画板
    这篇文章主要介绍了HTML5如何制作简单画板,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 代码如下: <!DOCTYPE HTM...
    99+
    2024-04-02
  • windows几何画板如何画logax
    这篇“windows几何画板如何画logax”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“windows几何画板如何画log...
    99+
    2023-07-04
  • Android如何实现绘画板功能
    这篇文章主要介绍了Android如何实现绘画板功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。实现流程:     &nbs...
    99+
    2023-06-15
  • windows几何画板如何做动画
    这篇文章主要讲解了“windows几何画板如何做动画”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“windows几何画板如何做动画”吧!几何画板做动画的方法:首先我们在软件中画一条以AB的线...
    99+
    2023-07-04
  • 如何制作flash动画
    本文小编为大家详细介绍“如何制作flash动画”,内容详细,步骤清晰,细节处理妥当,希望这篇“如何制作flash动画”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。制作flash动画:首先下载安装flash并打开,...
    99+
    2023-07-02
  • windows几何画板如何画数轴
    这篇文章主要讲解了“windows几何画板如何画数轴”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“windows几何画板如何画数轴”吧!几何画板画数轴的方法:在几何画板中,点击菜单栏数据,新...
    99+
    2023-07-04
  • windows几何画板如何画椭圆
    本文小编为大家详细介绍“windows几何画板如何画椭圆”,内容详细,步骤清晰,细节处理妥当,希望这篇“windows几何画板如何画椭圆”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。方法一:打开几何画板,选择椭圆...
    99+
    2023-07-04
  • windows几何画板如何画三角形
    今天小编给大家分享一下windows几何画板如何画三角形的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。几何画板画三角形的方法...
    99+
    2023-07-04
  • windows几何画板如何画坐标系
    这篇“windows几何画板如何画坐标系”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“windows几何画板如何画坐标系”文...
    99+
    2023-07-04
  • html5如何实现画板画笔功能
    这篇文章主要介绍了html5如何实现画板画笔功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。   实现画板画笔功能,效果如下:   1...
    99+
    2024-04-02
  • windows几何画板如何画定长线段
    这篇“windows几何画板如何画定长线段”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“windows几何画板如何画定长线段...
    99+
    2023-07-04
  • Android画中画窗口如何开启
    这篇文章主要讲解了“Android画中画窗口如何开启”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Android画中画窗口如何开启”吧!基础画中画manifest 设置为了适配开启画中画状态...
    99+
    2023-07-04
  • Android实现画板功能(二)
    本文实例为大家分享了Android实现画板功能的具体代码,讲解使用imageView,bitmap的方式实现画板功能,供大家参考,具体内容如下 前言 在上一篇Android实现画板功...
    99+
    2024-04-02
  • Android实现绘画板功能
    目录实现流程:实现步骤:一、预期效果二、设置横竖屏切换三、确定布局四、自定义滑动条五、绘画区域六、MainActivity实现流程:     ...
    99+
    2024-04-02
  • Android实现画板功能(一)
    本文实例为大家分享了Android实现画板功能的具体代码,供大家参考,具体内容如下 前言 最近看到了一些Android手写相关的功能,比如说: 钉钉手写签名功能,输入法手写功能,笔记...
    99+
    2024-04-02
  • windows几何画板如何画绝对值函数
    本篇内容主要讲解“windows几何画板如何画绝对值函数”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“windows几何画板如何画绝对值函数”吧!几何画板画绝对值函数的方法:打开几何画板软件,在...
    99+
    2023-07-04
  • html5制作简单画板代码怎么写
    本篇文章给大家分享的是有关html5制作简单画板代码怎么写,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。HTML5制作简单画板代码如下:<...
    99+
    2024-04-02
  • 怎样使用html5 canvas制作涂鸦画板
    这篇文章给大家分享的是有关怎样使用html5 canvas制作涂鸦画板的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。   清空画板   Line width : 1   3...
    99+
    2024-04-02
  • 基于WPF制作一个可编程画板
    目录先上一张效果动图本次扩展的主要内容可编程模块的实现原理代码编辑模块的实现代码编辑模块的编译与测试WPF打印控制台数据动态编译模块的输入输出自动生成先上一张效果动图 同样老规矩,...
    99+
    2023-05-18
    WPF制作可编程画板 WPF可编程画板 WPF 画板
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作