Giter Site home page Giter Site logo

choosepicture's Introduction

ChoosePicture

android 拍照裁剪照片,从相册选择照片裁剪,android take picture,choose picture from gallery image Gradle: ###build.gradle里面,添加:

compile 'com.ycl.utils:ycllibrary:1.1'

#####集成这个选择照片上传库需要四步 ###第一步: ####将以下代码加入onCreate()方法中:

 YCLTools.getInstance().setOnChoosePictureListener(this);

###第二步: ####调用以下代码显示选取图片方式的dialog:

  new UpLoadHeadImageDialog(MainActivity.this).show();

###第三步: ####重写Activity的onActivityResult方法,并在该方法中加入以下语句:

YCLTools.getInstance().upLoadImage(requestCode, resultCode, data);

###第四步: ####在你项目的Manifest.xml中,注册该Activity:

<activity android:name="com.ycl.chooseavatar.library.CropImageViewActivity"></activity>

#####加入以下权限:

<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"></uses-permission>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>

####到这里就可以把项目跑起来了

####以下是一个简单的例子:

public class MainActivity extends AppCompatActivity implements OnChoosePictureListener {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);


        //must set a listener
        YCLTools.getInstance().setOnChoosePictureListener(this);
        findViewById(R.id.bt_start).setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                //show dialog
             new UpLoadHeadImageDialog(MainActivity.this).show();
            }
        });

    }

    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        //must set like this
        YCLTools.getInstance().upLoadImage(requestCode, resultCode, data);
    }

    @Override
    public void OnChoose(String filePath) {
        Toast.makeText(getApplicationContext(),"filePath:"+filePath,Toast.LENGTH_LONG).show();

    }

    @Override
    public void OnCancel() {
        Toast.makeText(getApplicationContext(),"OnCancel",Toast.LENGTH_LONG).show();

    }
    
}

###注意,在Fragment中,应该这样进行第二步:

 new UpLoadHeadImageDialog(getActivity(),MyFragment.this).show();

####感谢: IsseiAoki/SimpleCropView

choosepicture's People

Contributors

yaochangliang159 avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.