gwh-backTopIcon.vue 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. <template>
  2. <view>
  3. <cover-image mode="aspectFill" :src="icon_path" class="fixedView icon" @touchstart.stop="touchIcon" @touchmove.stop.prevent="moveIcon" @tap.stop="tapIcon"
  4. :style="{left:iconPosition.left+'px',top:iconPosition.top+'px',width:iconSize.width+'upx',height:iconSize.height+'upx'}">
  5. <!-- <image mode="aspectFill" :src="icon_path" :style="{width:iconSize.width+'upx',height:iconSize.height+'upx'}"></image> -->
  6. </cover-image>
  7. </view>
  8. </template>
  9. <script>
  10. export default {
  11. data() {
  12. return {
  13. icon_path:"",
  14. windowSize:{
  15. width:0,
  16. height:0,
  17. margin:{
  18. left:10,
  19. right:10,
  20. top:10,
  21. bottom:10,
  22. }
  23. },
  24. iconSize:{
  25. width:100,
  26. height:100
  27. },
  28. iconPosition:{
  29. left:0,
  30. top:0,
  31. touchPostion:{
  32. x:0,
  33. y:0
  34. }
  35. },
  36. }
  37. },
  38. props:{
  39. startPostion:{
  40. type:Number,
  41. default:3
  42. },
  43. iconWidth:{
  44. type:Number,
  45. default:100
  46. },
  47. iconHeight:{
  48. type:Number,
  49. default:100
  50. },
  51. marginLeft:{
  52. type:Number,
  53. default:10
  54. },
  55. marginRight:{
  56. type:Number,
  57. default:10
  58. },
  59. marginTop:{
  60. type:Number,
  61. default:10
  62. },
  63. marginBottom:{
  64. type:Number,
  65. default:10
  66. },
  67. iconPath:{
  68. type:String,
  69. default:""
  70. },
  71. /*tapFunction:{
  72. type:Function,
  73. default:this.tapIcon
  74. }*/
  75. },
  76. mounted() {
  77. this.$set(this.iconSize,'width',this.iconWidth);
  78. this.$set(this.iconSize,'height',this.iconHeight);
  79. this.$set(this.windowSize.margin,'left',this.marginLeft);
  80. this.$set(this.windowSize.margin,'right',this.marginRight);
  81. this.$set(this.windowSize.margin,'top',this.marginTop);
  82. this.$set(this.windowSize.margin,'bottom',this.marginBottom);
  83. this.$set(this.windowSize,'width',uni.getSystemInfoSync().windowWidth);
  84. this.$set(this.windowSize,'height',uni.getSystemInfoSync().windowHeight);
  85. switch(this.startPostion){
  86. case 0:
  87. //初始位置左上角
  88. this.$set(this.iconPosition,'left',this.windowSize.margin.left);
  89. this.$set(this.iconPosition,'top',this.windowSize.margin.top);
  90. break;
  91. case 1:
  92. //初始位置右上角
  93. this.$set(this.iconPosition,'left',this.windowSize.width - uni.upx2px(this.iconSize.width) - this.windowSize.margin.right);
  94. this.$set(this.iconPosition,'top',this.windowSize.margin.top);
  95. break;
  96. case 2:
  97. //初始位置左下角
  98. this.$set(this.iconPosition,'left',this.windowSize.margin.left);
  99. this.$set(this.iconPosition,'top',this.windowSize.height - uni.upx2px(this.iconSize.height) - this.windowSize.margin.bottom);
  100. break;
  101. default:
  102. //初始位置右下角
  103. this.$set(this.iconPosition,'left',this.windowSize.width - uni.upx2px(this.iconSize.width) - this.windowSize.margin.right);
  104. this.$set(this.iconPosition,'top',this.windowSize.height - uni.upx2px(this.iconSize.height) - this.windowSize.margin.bottom);
  105. break;
  106. }
  107. var that = this;
  108. console.log(this.iconPath);
  109. if(this.iconPath == ""){
  110. //that.$set(that,'icon_path','../../static/logo.png');
  111. that.$set(that,'icon_path',"");
  112. }
  113. else{
  114. uni.getImageInfo({
  115. src:this.iconPath,
  116. success(err){
  117. that.$set(that,'icon_path',that.iconPath);
  118. },
  119. fail(err) {
  120. that.$set(that,'icon_path','../../static/logo.png');
  121. uni.showModal({
  122. title:'错误',
  123. content:'未知图片:'+that.iconPath,
  124. showCancel:false
  125. })
  126. }
  127. })
  128. }
  129. },
  130. methods: {
  131. touchIcon(e){
  132. //console.log(e);
  133. this.$set(this.iconPosition.touchPostion,'x',e.touches[0].clientX);
  134. this.$set(this.iconPosition.touchPostion,'y',e.touches[0].clientY);
  135. },
  136. moveIcon(e){
  137. //console.log(e)
  138. /*this.iconPosition.left += (e.touches[0].clientX - this.iconPosition.touchPostion.x);
  139. this.iconPosition.top += (e.touches[0].clientY - this.iconPosition.touchPostion.y);
  140. this.iconPosition.touchPostion.x = e.touches[0].clientX;
  141. this.iconPosition.touchPostion.y = e.touches[0].clientY;*/
  142. this.$set(this.iconPosition,'left', e.touches[0].clientX - uni.upx2px(this.iconSize.width / 2));
  143. this.$set(this.iconPosition,'top', e.touches[0].clientY - uni.upx2px(this.iconSize.height / 2) + uni.getSystemInfoSync().windowTop);
  144. //console.log(uni.getSystemInfoSync());
  145. this.$set(this.iconPosition,'left',Math.min(this.windowSize.width - uni.upx2px(this.iconSize.width) - this.windowSize.margin.right, this.iconPosition.left));
  146. this.$set(this.iconPosition,'left',Math.max(this.windowSize.margin.left, this.iconPosition.left));
  147. this.$set(this.iconPosition,'top',Math.min(this.windowSize.height - uni.upx2px(this.iconSize.height) - this.windowSize.margin.bottom, this.iconPosition.top));
  148. this.$set(this.iconPosition,'top',Math.max(this.windowSize.margin.top, this.iconPosition.top));
  149. },
  150. tapIcon(e){
  151. //console.log('you tap icon');
  152. this.$emit('tapIcon');
  153. }
  154. }
  155. }
  156. </script>
  157. <style scoped lang="scss">
  158. .fixedView{
  159. position: fixed;
  160. z-index: 200;
  161. }
  162. .icon{
  163. border-radius: 50%;
  164. overflow: hidden;
  165. border: none;
  166. box-shadow: 0px 2px 5px #C0C0C0 !important;
  167. }
  168. </style>