uploadImgs.vue 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321
  1. <!--
  2. @param keysArr 承接数组
  3. @param readOnly 删除按钮是否显示,上传是否显示
  4. @param max 上传最大数限制
  5. @click change 承接数组发生变化时触发函数
  6. -->
  7. <template>
  8. <div id="sagaUploads">
  9. <div class="saga-upload-images">
  10. <div v-if="type != 'video'" class="point-image" v-for="(item,index) in imagesArr">
  11. <i v-if="!readOnly" class="el-icon-delete" @click="delImage(index,item)"></i>
  12. <img :src="imageGetUrl + '&key=' +item.key" alt v-load>
  13. </div>
  14. <div v-if="type == 'video'" class="point-image" v-for="(item,index) in imagesArr">
  15. <i v-if="!readOnly" class="el-icon-delete" @click="delImage(index,item)"></i>
  16. <video
  17. width="100%"
  18. height="100%;"
  19. :src="imageGetUrl + '&key=' +item.key"
  20. controls="controls"
  21. >您的浏览器不支持 video 标签。</video>
  22. </div>
  23. <div v-if="!readOnly && imagesArr.length < max" style="float:left;">
  24. <el-upload
  25. class="avatar-uploader"
  26. :http-request="uploadAndSubmit"
  27. :show-file-list="false"
  28. :accept="accept"
  29. action
  30. drag
  31. style="position: relation"
  32. >
  33. <i class="el-icon-plus avatar-uploader-icon"></i>
  34. </el-upload>
  35. <video style="display:none;" id="video" controls/>
  36. </div>
  37. </div>
  38. </div>
  39. </template>
  40. <script>
  41. import tools from "@/utils/old-adm/scan/tools";
  42. export default {
  43. props: {
  44. keysArr: {
  45. type: [Array, String]
  46. },
  47. readOnly: {
  48. type: Boolean,
  49. default: false
  50. },
  51. max: {
  52. type: [Number, String],
  53. default: 6
  54. },
  55. accept: {
  56. type: String,
  57. default: "image/*"
  58. },
  59. type: {
  60. type: String,
  61. default: "image"
  62. },
  63. defined: null,
  64. videoPicArr: {
  65. type: Array,
  66. default: function () {
  67. return []
  68. }
  69. }
  70. },
  71. data() {
  72. return {
  73. baseUrl: "",
  74. imageGetUrl: window.__systemConf.baseServiceUrl + "/image-service/common/image_get?systemId=dataPlatform",
  75. imageUploadUrl: window.__systemConf.baseServiceUrl + "/image-service/common/image_upload?systemId=dataPlatform&secret=9e0891a7a8c8e885&overwrite=true",
  76. imagesArr: []
  77. };
  78. },
  79. created() {
  80. this.imageFalg();
  81. },
  82. methods: {
  83. //判断是否为空
  84. imageFalg() {
  85. let type = typeof this.keysArr;
  86. console.log(this.keysArr)
  87. if (type == "string") {
  88. this.imagesArr = [this.keysArr];
  89. } else {
  90. this.imagesArr = tools.deepCopy(this.keysArr);
  91. }
  92. if (!this.keysArr) {
  93. this.imagesArr = [];
  94. }
  95. },
  96. //删除图片
  97. delImage(i, key) {
  98. if (this.type == "video") {
  99. this.videoPicArr = this.videoPicArr.map(item => {
  100. if (item.substring(0, item.length - 3) == this.imagesArr[i].substring(0, this.imagesArr[i].length - 3)) {
  101. return undefined
  102. } else {
  103. return item
  104. }
  105. }).filter(p => p)
  106. }
  107. this.imagesArr.splice(i, 1);
  108. this.$emit("change", this.imagesArr, this.defined, this.videoPicArr);
  109. },
  110. //上传
  111. uploadAndSubmit(item, key) {
  112. // var form = document.forms["demoForm"];
  113. // if (form["file"].files.length > 0) {
  114. // 寻找表单域中的 <input type="file" ... /> 标签
  115. // var file = form["file"].files[0];
  116. console.log("lalala", item)
  117. let file = item.file;
  118. // try sending
  119. let reader = new FileReader();
  120. let vm = this;
  121. let fileType = file.name.split(".");
  122. let type = fileType[fileType.length - 1];
  123. let uploadKey = file.uid
  124. if (!!key) {
  125. uploadKey = key
  126. }
  127. reader.onloadstart = function () {
  128. // 这个事件在读取开始时触发
  129. };
  130. reader.onprogress = function (p) {
  131. // 这个事件在读取进行中定时触发
  132. };
  133. reader.onload = function () {
  134. // 这个事件在读取成功结束后触发
  135. };
  136. reader.onloadend = function () {
  137. // 这个事件在读取结束后,无论成功或者失败都会触发
  138. if (reader.error) {
  139. } else {
  140. // document.getElementById("bytesRead").textContent = file.size;
  141. // 构造 XMLHttpRequest 对象,发送文件 Binary 数据
  142. var xhr = new XMLHttpRequest();
  143. xhr.open(
  144. /* method */
  145. "POST",
  146. /* target url */
  147. vm.imageUploadUrl + "&key=" + uploadKey + "." + type
  148. /*, async, default to true */
  149. );
  150. //xhr.overrideMimeType("application/octet-stream");
  151. xhr.send(reader.result);
  152. xhr.onreadystatechange = function () {
  153. if (xhr.readyState == 4) {
  154. if (xhr.status == 200) {
  155. if (vm.type == 'image') {
  156. vm.imagesArr.push(
  157. uploadKey + "." + type
  158. );
  159. }
  160. if (type == 'mp4') {
  161. vm.imagesArr.push(
  162. uploadKey + "." + type
  163. );
  164. vm.creatImg(vm.imageGetUrl + "&key=" + uploadKey + "." + type, uploadKey)
  165. }
  166. console.log(vm.type, type)
  167. if (vm.type == "video" && type == "png") {
  168. console.log("触发时评上传图片回调")
  169. vm.videoPicArr.push(uploadKey + "." + type)
  170. }
  171. vm.$emit("change", vm.imagesArr, vm.defined, vm.videoPicArr);
  172. }
  173. }
  174. };
  175. }
  176. };
  177. reader.readAsArrayBuffer(file);
  178. },
  179. dataURLtoBlob: function (dataURI, type) {
  180. var binary = atob(dataURI.split(',')[1]);
  181. var array = [];
  182. for (var i = 0; i < binary.length; i++) {
  183. array.push(binary.charCodeAt(i));
  184. }
  185. return new Blob([new Uint8Array(array)], { type: type });
  186. },
  187. creatImg(reader, key) {
  188. var videoDom = document.getElementById('video');
  189. videoDom.src = reader;
  190. let vm = this
  191. videoDom.onloadeddata = function () {
  192. // 这里可以打印视频时长
  193. // 这里取得视频封面
  194. var canvas = document.createElement('canvas');
  195. canvas.width = 300;
  196. canvas.height = 300 * this.videoHeight / this.videoWidth;
  197. canvas.getContext('2d').drawImage(this, 0, 0, canvas.width, canvas.height);
  198. //将canvas的base64位图片转换成图片png的file
  199. var blob = vm.dataURLtoBlob(canvas.toDataURL('image/png'), "image/png")
  200. //将其转换成file对象
  201. var file = new File([blob], "video_image.png", { type: "image/png", lastModified: Date.now() })//blob转file
  202. vm.uploadAndSubmit({ file: file }, key)
  203. }
  204. },
  205. },
  206. watch: {
  207. keysArr: function (val) {
  208. this.imageFalg();
  209. }
  210. },
  211. //自定义指令
  212. directives: {
  213. load: function (el) {
  214. let imgDom = document.createElement("img");
  215. imgDom.style.position = "absolute";
  216. imgDom.style.top = "-999px";
  217. imgDom.style.opacity = 0;
  218. imgDom.src = el.src;
  219. el.src = "";
  220. imgDom.onload = () => {
  221. let width = imgDom.width;
  222. let height = imgDom.height;
  223. if (width > height) {
  224. el.style.height = "100%";
  225. el.style.width = "auto";
  226. el.style.position = "absolute";
  227. el.style.left = "50%";
  228. el.style.top = "0";
  229. el.style.transform = "translateX(-50%)";
  230. el.style.webkitTransform = "translateX(-50%) translateY(0)";
  231. el.style.MozTransform = "translateX(-50%) translateY(0)";
  232. el.style.msTransform = "translateX(-50%) translateY(0)";
  233. el.style.OTransform = "translateX(-50%) translateY(0)";
  234. } else if (width < height) {
  235. el.src = imgDom.src;
  236. el.style.width = "100%";
  237. el.style.height = "auto";
  238. el.style.position = "absolute";
  239. el.style.top = "50%";
  240. el.style.left = "0";
  241. el.style.transform = "translateY(-50%) translateX(0)";
  242. el.style.webkitTransform = "translateY(-50%) translateX(0)";
  243. el.style.MozTransform = "translateY(-50%) translateX(0)";
  244. el.style.msTransform = "translateY(-50%) translateX(0)";
  245. el.style.OTransform = "translateY(-50%) translateX(0)";
  246. } else {
  247. el.style.width = "100%";
  248. el.style.height = "100%";
  249. el.style.position = "absolute";
  250. el.style.top = "0";
  251. el.style.left = "0";
  252. el.style.transform = "translateY(0) translateX(0)";
  253. el.style.webkitTransform = "translateY(0) translateX(0)";
  254. el.style.MozTransform = "translateY(0) translateX(0)";
  255. el.style.msTransform = "translateY(0) translateX(0)";
  256. el.style.OTransform = "translateY(0) translateX(0)";
  257. }
  258. el.src = imgDom.src;
  259. };
  260. }
  261. }
  262. };
  263. </script>
  264. <style lang="less">
  265. #sagaUploads {
  266. overflow: hidden;
  267. .avatar-uploader {
  268. height: 180px;
  269. width: 180px;
  270. overflow: hidden;
  271. .el-upload {
  272. width: 180px;
  273. height: 180px;
  274. .el-upload-dragger {
  275. width: 180px;
  276. height: 180px;
  277. .el-icon-plus {
  278. display: block;
  279. width: 20px;
  280. height: 20px;
  281. font-size: 20px;
  282. margin: 80px;
  283. }
  284. }
  285. }
  286. }
  287. .point-image {
  288. width: 180px;
  289. height: 180px;
  290. float: left;
  291. position: relative;
  292. margin-right: 10px;
  293. margin-bottom: 10px;
  294. border: 1px solid #ccc;
  295. overflow: hidden;
  296. img {
  297. z-index: 11;
  298. }
  299. i {
  300. position: absolute;
  301. bottom: 10px;
  302. right: 10px;
  303. background-color: #fff;
  304. padding: 5px;
  305. cursor: pointer;
  306. z-index: 66;
  307. }
  308. }
  309. }
  310. </style>