|  | 
 
| 本帖最后由 负暄 于 2016-5-15 21:15 编辑 
 感谢版主梁永飞的悉心指导,也感谢论坛高手们的帖子启发,我在参考SimpleFileStore的基础上,实现了用户头像照片的拍照、上传与显示,现分享如下:
 1、拍照
 调用手机拍照用的是cordova插件,所以在你需要拍照的页面中,首先要引用如下代码:
 require("$UI/system/lib/cordova/cordova");
 require("cordova!cordova-plugin-camera");
 
 
 然后是调用相机拍照的函数,我是放在button的click事件中进行的:
 Model.prototype.takePicBtnClick = function(event){
 if(!navigator.camera){
 return;
 }
 var self = this;
 navigator.camera.getPicture(onLoadImageSuccess, onLoadImageFail, {
 destinationType:navigator.camera.DestinationType.DATA_URL,
 allowEdit:true,
 quality:80,
 targetWidth:100,
 targetHeight:100,
 saveToPhotoAlbum:true
 });
 
 //拍照成功后回调
 function onLoadImageSuccess(imageData){
 localStorage.setItem("imageData","data:image/jpeg;base64,"+imageData);
 var smallImage = document.getElementById(self.getIDByXID('image1'));
 //显示图像
 smallImage.style.display = 'block';
 smallImage.src = "data:image/jpeg;base64,"+imageData;
 //图片上传
 self.uploadPic(imageData);
 }
 
 function onLoadImageFail(error){
 alert(error);
 }
 
 };
 
 
 再然后是图片的上传:
 //调用bass实现图片上传
 Model.prototype.uploadPic = function(imageData){
 
 //用户信息,用于上传图片后保存图片链接fImage
 var userid = this._UserID;    //this._UserID是自己定义的变量,在页面打开时被初始化
 var userBaasData = this.comp("userBaasData");
 var storeFileName =  "";
 var imageJson = {};
 
 storeFileName = justep.UUID.createUUID();
 
 justep.Baas.sendRequest({
 "url" : "/summer/classes",  //baas目录,请根据自己的配置进行修改
 "action" : "uploadPicfile",
 "async" : false,
 "params" : {
 "picData" : imageData,
 "ownerID" : userid,
 "storeFileName" : storeFileName
 },
 "success" : function(data) {
 
 justep.Util.hint("图片上传成功");
 
 //修改数据库中的图片链接     这里我的字段名叫fImage,可以根据自己的字段名修改
 userBaasData.setFilter("Idfilter", "fID='"+userid+"'");
 userBaasData.refreshData();
 if(userBaasData.getCount()>0){
 var fImage = '{"ownerID":"'+userid+'","storeFileName":"'+storeFileName+'"}';
 
 userBaasData.setValue("fImage", fImage);
 userBaasData.saveData();
 }
 }
 });
 
 };
 
 
 然后是,后台对应的图片上传baas,将图片保存在UI2/myClassmate/uploadfiles目录下,这里可以自己进行调整:
 public static JSONObject uploadPicfile(JSONObject params, ActionContext context) throws SQLException, NamingException, IOException {
 
 System.out.println("uploadPicfile is running...");
 
 String ownerID = params.getString("ownerID");
 String storeFileName = params.getString("storeFileName");
 String picData = params.getString("picData");
 
 
 String baasPath = Thread.currentThread().getContextClassLoader().getResource("").getPath()  ;
 String docStorePath = baasPath + ".." + File.separator + ".."+ File.separator + "model" +File.separator + "UI2" +File.separator + "myClassmate" +File.separator+"uploadfiles" ;
 File docstoreDir = new File(docStorePath);
 if(!(docstoreDir.exists() && docstoreDir.isDirectory())){
 docstoreDir.mkdirs();
 }
 
 String storePath = docStorePath + File.separator + ownerID;
 File storeDir = new File(storePath);
 if(!(storeDir.exists() && storeDir.isDirectory())){
 storeDir.mkdirs();
 }
 
 System.out.println("后台计算的baasPath的值:"+ baasPath);
 System.out.println("后台计算的docStorePath的值:"+ docStorePath);
 System.out.println("后台计算的storeDir的值:"+ storeDir);
 
 BASE64Decoder decoder = new BASE64Decoder();
 try {
 byte[] decodedBytes = decoder.decodeBuffer(picData);
 
 String imgFile = storePath + File.separator + storeFileName;
 FileOutputStream out = new FileOutputStream(imgFile);
 out.write(decodedBytes);
 out.close();
 System.out.println("图片上传成功!");
 } catch (Exception e) {
 System.out.println("图片上传失败!");
 e.printStackTrace();
 }
 return null;
 }
 
 
 | 
 评分
查看全部评分
 |