`

单手操作图片控件 镜像、置顶、缩放、移动:StickerView

阅读更多
单手操作图片控件 镜像、置顶、缩放、移动



import android.content.Intent;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.RelativeLayout;
  
import com.example.abner.stickerdemo.utils.FileUtils;
import com.example.abner.stickerdemo.view.StickerView;
  
import java.util.ArrayList;
  
public class MainActivity extends AppCompatActivity {
  
    //当前处于编辑状态的贴纸
    private StickerView mCurrentView;
  
    //存储贴纸列表
    private ArrayList<View> mStickers;
  
    private RelativeLayout mContentRootView;
  
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mContentRootView = (RelativeLayout) findViewById(R.id.rl_content_root);
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);
  
        FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                addStickerView();
            }
        });
        mStickers = new ArrayList<>();
  
    }
  
    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.menu_main, menu);
        return true;
    }
  
    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();
  
        //noinspection SimplifiableIfStatement
        if (id == R.id.action_complete) {
            mCurrentView.setInEdit(false);
            generateBitmap();
            return true;
        }
  
        return super.onOptionsItemSelected(item);
    }
  
    //添加表情
    private void addStickerView() {
        final StickerView stickerView = new StickerView(this);
        stickerView.setImageResource(R.mipmap.ic_cat);
        stickerView.setOperationListener(new StickerView.OperationListener() {
            @Override
            public void onDeleteClick() {
                mStickers.remove(stickerView);
                mContentRootView.removeView(stickerView);
            }
  
            @Override
            public void onEdit(StickerView stickerView) {
                mCurrentView.setInEdit(false);
                mCurrentView = stickerView;
                mCurrentView.setInEdit(true);
            }
  
            @Override
            public void onTop(StickerView stickerView) {
                int position = mStickers.indexOf(stickerView);
                if (position == mStickers.size() - 1) {
                    return;
                }
                StickerView stickerTemp = (StickerView) mStickers.remove(position);
                mStickers.add(mStickers.size(), stickerTemp);
            }
        });
        RelativeLayout.LayoutParams lp = new RelativeLayout.LayoutParams(RelativeLayout.LayoutParams.MATCH_PARENT, RelativeLayout.LayoutParams.MATCH_PARENT);
        mContentRootView.addView(stickerView, lp);
        mStickers.add(stickerView);
        setCurrentEdit(stickerView);
    }
  
    /**
     * 设置当前处于编辑模式的贴纸
     */
    private void setCurrentEdit(StickerView stickerView) {
        if (mCurrentView != null) {
            mCurrentView.setInEdit(false);
        }
        mCurrentView = stickerView;
        stickerView.setInEdit(true);
    }
  
    private void generateBitmap() {
  
        Bitmap bitmap = Bitmap.createBitmap(mContentRootView.getWidth(),
                mContentRootView.getHeight()
                , Bitmap.Config.ARGB_8888);
        Canvas canvas = new Canvas(bitmap);
        mContentRootView.draw(canvas);
  
        String iamgePath = FileUtils.saveBitmapToLocal(bitmap, this);
        Intent intent = new Intent(this, DisplayActivity.class);
        intent.putExtra("image", iamgePath);
        startActivity(intent);
    }
  
}




http://www.23code.com/imageprocessing/
ImageProcessing这个贴纸Demo是基于 http://blog.isming.me/2015/05/10/sticker-view/ 现有基础的优化。

优化内容

1、加入了多张贴纸功能

2、对于贴纸边界的判断
  • 大小: 4.8 MB
分享到:
评论
1 楼 纯洁的坏蛋 2015-10-17  
如果我要添加字体呢? 

相关推荐

    Android-StickerView单手操作图片控件镜像置顶缩放移动

    `StickerView`就是这样一个专门用于处理图片控件的组件,它提供了丰富的交互功能,包括单手操作图片的镜像、置顶、缩放和移动。这篇文章将深入探讨`StickerView`的实现原理和使用方法。 首先,`StickerView`的核心...

    安卓手绘图片处理画板相关-StickerView单手操作图片控件镜像置顶缩放移动.rar

    在给定的压缩包文件中,我们关注的是一个名为"StickerView"的控件,它提供了单手操作图片的能力,包括镜像、置顶、缩放和移动等功能。这个控件对于构建具有高级图像编辑功能的应用非常有用。 1. **StickerView**:...

    Android 单手操作图片控件(镜像/置顶/缩放/移动)源码

    StickerView单手操作图片控件 镜像、置顶、缩放、移动。自定义一个StickerView用来 设置当前处于编辑状态的贴纸,设置当前状态为可编辑状态,stickerView.setInEdit(true); 添加ArrayList&lt;View&gt; mStickers存储贴纸...

    StickerView-单手控制图片 镜像、置顶、缩放、移动的贴纸控件.zip

    单手控制图片 镜像、置顶、缩放、移动的贴纸控件项目地址:https://github.com/nimengbo/StickerView 效果图:如何使用:即如何创建贴纸(sticker):StickerView stickerView = new StickerView(this);...

    电信设备-实现单手操作移动终端的方法和移动终端.zip

    "电信设备-实现单手操作移动终端的方法和移动终端.zip"这个文件包,包含了关于如何优化移动设备设计,使得用户能更方便地单手操作的技术和策略。 首先,我们要理解单手操作的重要性。随着屏幕尺寸的增加,传统的...

    电信设备-基于移动终端的单手操作触摸屏的方法及其移动终端.zip

    《电信设备:基于移动终端的单手操作触摸屏方法及其移动终端》 随着智能手机的普及,用户对于移动设备的操作便捷性需求越来越高。特别是在大屏幕设备上,如何实现单手高效操作成为了重要的设计课题。本资料主要探讨...

    电信设备-单手操作的方法及移动终端.zip

    3. **手势操作**:手势操作是实现单手操作的有效手段,比如缩放、滑动、捏合等。例如,可以通过捏合手势缩小屏幕内容,使得手指能够触及屏幕更远的位置。 4. **悬浮按钮和快捷菜单**:许多应用和系统提供了悬浮按钮...

    电信设备-单手操作移动终端的信息采集方法、操作方法及移动终端.zip

    针对这一问题,"电信设备-单手操作移动终端的信息采集方法、操作方法及移动终端"提供了一种解决方案,旨在提升用户在使用大屏设备时的便利性和效率。 该技术主要关注的是如何在不影响用户体验的前提下,实现移动...

    电信设备-一种实现移动设备单手操作的方法和装置.zip

    标题中的“电信设备-一种实现移动设备单手操作的方法和装置”揭示了这个主题的核心,即探讨在电信设备,特别是移动设备(如智能手机)中如何优化用户体验,使得用户能够更方便地进行单手操作。这样的设计对于现代...

    电信设备-可单手操作移动终端触屏的控制装置及控制方法.zip

    标题中的“电信设备-可单手操作移动终端触屏的控制装置及控制方法”表明了这份资料主要关注的是移动通信设备中,特别是智能手机和平板电脑等触屏设备的设计与使用方式,尤其是如何优化用户在单手操作时的体验。...

    Android View 跟随手势移动和缩放

    "Android View 跟随手势移动和缩放"的主题聚焦于如何实现View在屏幕上跟随用户的触摸手势进行平移(translate)和缩放(zoom)操作。这种功能广泛应用于图片查看器、地图应用以及各种需要用户自定义布局的场景。 ...

    微信小程序单手实现图片的拖动、旋转、缩放

    实现了微信小程序内单手对图片进行拖动、缩放、旋转 可以根据此原理进一步升级到对各种组件的拖动、缩放、旋转,不单单是图片 把项目克隆到本地,放在微信开发工具就可以了 新添加的图片合成功能 特别需要注意的是:...

    网络游戏-游戏机单手操作装置.zip

    1. 移动游戏:对于手机和平板用户,单手操作装置可以解决屏幕遮挡问题,提高游戏舒适度,尤其适用于需要频繁操作的游戏。 2. 家用游戏机:在客厅或有限空间内,单手操作装置让玩家不必受制于传统双控制器,提供更多...

    电信设备-一种便于单手操作的移动终端的解锁方法及装置.zip

    "电信设备-一种便于单手操作的移动终端的解锁方法及装置"的主题,正是针对这一需求,提出了一种创新的解决方案。 该主题的核心在于提高移动终端的解锁效率和便捷性,特别是考虑到用户可能在各种情况下(如驾驶、...

    电信设备-单手手持式移动设备辅助操作装置.zip

    《电信设备-单手手持式移动设备辅助操作装置》是一个重要的技术主题,主要涉及的是如何在日益小巧便携的移动设备上实现更高效、舒适的单手操作。在现代生活中,智能手机和其他手持设备已经成为我们日常生活、工作和...

    单手手势交互设计分析.docx

    研究表明,近一半的用户倾向于单手操作手机,而市场上也出现了许多辅助单手操作的应用程序,表明单手操作有着巨大的市场需求。 #### 更好地单手手势设计 为了提升单手操作的便利性,设计时应遵循以下原则: **3.1...

    加了单手操作的文件管理器源码前后对比

    这里拿小米的开源文件管理器开源代码,加入了一个单手操作的功能.此功能类似锤子和魅族的下拉悬浮.但是此功能应该比锤子和魅族的更好用.锤子的单手操作,其触发条件是一定的拇指面积触发,易误操作,要小心翼翼.魅族的...

    电信设备-单手操作触摸屏图标的方法、系统和移动终端.zip

    电信设备-单手操作触摸屏图标的方法、系统和移动终端.zip

    单手打字的键盘布局程序

    标题中的“单手打字的键盘布局程序”指的是专门设计用于单手操作的键盘布局,这种布局优化了键位,使得用户在只使用一只手的情况下也能高效地进行打字。这样的布局通常会将常用字母、数字和标点符号尽可能地集中在...

Global site tag (gtag.js) - Google Analytics