index.html 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1">
  7. <meta name="description" content="A basic demo of Cropper.">
  8. <meta name="keywords" content="HTML, CSS, JS, JavaScript, jQuery plugin, image cropping, front-end, frontend, web development">
  9. <meta name="author" content="Fengyuan Chen">
  10. <title>Cropper</title>
  11. <link href="../assets/css/bootstrap.min.css" rel="stylesheet">
  12. <link href="../dist/cropper.css" rel="stylesheet">
  13. <link href="css/main.css" rel="stylesheet">
  14. <!-- HTML5 shim and Respond.js for IE8 support of HTML5 elements and media queries -->
  15. <!--[if lt IE 9]>
  16. <script src="https://oss.maxcdn.com/html5shiv/3.7.2/html5shiv.min.js"></script>
  17. <script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
  18. <![endif]-->
  19. </head>
  20. <body>
  21. <!-- header -->
  22. <header class="navbar navbar-inverse navbar-static-top docs-header" id="top">
  23. <div class="container">
  24. <div class="navbar-header">
  25. <button class="navbar-toggle" data-target="#navbar-collapse-1" data-toggle="collapse" type="button">
  26. <span class="sr-only">Toggle navigation</span>
  27. <span class="icon-bar"></span>
  28. <span class="icon-bar"></span>
  29. <span class="icon-bar"></span>
  30. </button>
  31. <a class="navbar-brand" href="javascript:void(0);">Cropper</a>
  32. </div>
  33. <nav class="collapse navbar-collapse" id="navbar-collapse-1" role="navigation">
  34. <p class="navbar-text">A simple jQuery image cropping plugin.</p>
  35. <ul class="nav navbar-nav navbar-right">
  36. <li><a href="http://github.com/fengyuanchen/cropper/blob/master/README.md">Docs</a></li>
  37. <li><a href="http://github.com/fengyuanchen/cropper">Github</a></li>
  38. <li><a href="http://chenfengyuan.com">About</a></li>
  39. </ul>
  40. </nav>
  41. </div>
  42. </header>
  43. <!-- Content -->
  44. <div class="container">
  45. <div class="row">
  46. <div class="col-md-9">
  47. <!-- <h3 class="page-header">Demo:</h3> -->
  48. <div class="img-container">
  49. <img src="../assets/img/picture.jpg" alt="Picture">
  50. </div>
  51. </div>
  52. <div class="col-md-3">
  53. <!-- <h3 class="page-header">Preview:</h3> -->
  54. <div class="docs-preview clearfix">
  55. <div class="img-preview preview-lg"></div>
  56. <div class="img-preview preview-md"></div>
  57. <div class="img-preview preview-sm"></div>
  58. <div class="img-preview preview-xs"></div>
  59. </div>
  60. <!-- <h3 class="page-header">Data:</h3> -->
  61. <div class="docs-data">
  62. <div class="input-group">
  63. <label class="input-group-addon" for="dataX">X</label>
  64. <input class="form-control" id="dataX" type="text" placeholder="x">
  65. <span class="input-group-addon">px</span>
  66. </div>
  67. <div class="input-group">
  68. <label class="input-group-addon" for="dataY">Y</label>
  69. <input class="form-control" id="dataY" type="text" placeholder="y">
  70. <span class="input-group-addon">px</span>
  71. </div>
  72. <div class="input-group">
  73. <label class="input-group-addon" for="dataWidth">Width</label>
  74. <input class="form-control" id="dataWidth" type="text" placeholder="width">
  75. <span class="input-group-addon">px</span>
  76. </div>
  77. <div class="input-group">
  78. <label class="input-group-addon" for="dataHeight">Height</label>
  79. <input class="form-control" id="dataHeight" type="text" placeholder="height">
  80. <span class="input-group-addon">px</span>
  81. </div>
  82. <div class="input-group">
  83. <label class="input-group-addon" for="dataRotate">Rotate</label>
  84. <input class="form-control" id="dataRotate" type="text" placeholder="rotate">
  85. <span class="input-group-addon">deg</span>
  86. </div>
  87. </div>
  88. </div>
  89. </div>
  90. <div class="row">
  91. <div class="col-md-9 docs-buttons">
  92. <!-- <h3 class="page-header">Toolbar:</h3> -->
  93. <div class="btn-group">
  94. <button class="btn btn-primary" data-method="setDragMode" data-option="move" type="button" title="Move">
  95. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;setDragMode&quot;, &quot;move&quot;)">
  96. <span class="icon icon-move"></span>
  97. </span>
  98. </button>
  99. <button class="btn btn-primary" data-method="setDragMode" data-option="crop" type="button" title="Crop">
  100. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;setDragMode&quot;, &quot;crop&quot;)">
  101. <span class="icon icon-crop"></span>
  102. </span>
  103. </button>
  104. <button class="btn btn-primary" data-method="zoom" data-option="0.1" type="button" title="Zoom In">
  105. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;zoom&quot;, 0.1)">
  106. <span class="icon icon-zoom-in"></span>
  107. </span>
  108. </button>
  109. <button class="btn btn-primary" data-method="zoom" data-option="-0.1" type="button" title="Zoom Out">
  110. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;zoom&quot;, -0.1)">
  111. <span class="icon icon-zoom-out"></span>
  112. </span>
  113. </button>
  114. <button class="btn btn-primary" data-method="rotate" data-option="-45" type="button" title="Rotate Left">
  115. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;rotate&quot;, -45)">
  116. <span class="icon icon-rotate-left"></span>
  117. </span>
  118. </button>
  119. <button class="btn btn-primary" data-method="rotate" data-option="45" type="button" title="Rotate Right">
  120. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;rotate&quot;, 45)">
  121. <span class="icon icon-rotate-right"></span>
  122. </span>
  123. </button>
  124. </div>
  125. <div class="btn-group">
  126. <button class="btn btn-primary" data-method="disable" type="button" title="Disable">
  127. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;disable&quot;)">
  128. <span class="icon icon-lock"></span>
  129. </span>
  130. </button>
  131. <button class="btn btn-primary" data-method="enable" type="button" title="Enable">
  132. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;enable&quot;)">
  133. <span class="icon icon-unlock"></span>
  134. </span>
  135. </button>
  136. <button class="btn btn-primary" data-method="clear" type="button" title="Clear">
  137. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;clear&quot;)">
  138. <span class="icon icon-remove"></span>
  139. </span>
  140. </button>
  141. <button class="btn btn-primary" data-method="reset" type="button" title="Reset">
  142. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;reset&quot;)">
  143. <span class="icon icon-refresh"></span>
  144. </span>
  145. </button>
  146. <label class="btn btn-primary btn-upload" for="inputImage" title="Upload image file">
  147. <input class="sr-only" id="inputImage" name="file" type="file" accept="image/*">
  148. <span class="docs-tooltip" data-toggle="tooltip" title="Import image with Blob URLs">
  149. <span class="icon icon-upload"></span>
  150. </span>
  151. </label>
  152. <button class="btn btn-primary" data-method="destroy" type="button" title="Destroy">
  153. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;destroy&quot;)">
  154. <span class="icon icon-off"></span>
  155. </span>
  156. </button>
  157. </div>
  158. <div class="btn-group btn-group-crop">
  159. <button class="btn btn-primary" data-method="getCroppedCanvas" type="button">
  160. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;getCroppedCanvas&quot;)">
  161. Get Cropped Canvas
  162. </span>
  163. </button>
  164. <button class="btn btn-primary" data-method="getCroppedCanvas" data-option="{ &quot;width&quot;: 160, &quot;height&quot;: 90 }" type="button">
  165. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;getCroppedCanvas&quot;, { &quot;width&quot;: 160, &quot;height&quot;: 90 })">
  166. 160 &times; 90
  167. </span>
  168. </button>
  169. <button class="btn btn-primary" data-method="getCroppedCanvas" data-option="{ &quot;width&quot;: 320, &quot;height&quot;: 180 }" type="button">
  170. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;getCroppedCanvas&quot;, { &quot;width&quot;: 320, &quot;height&quot;: 180 })">
  171. 320 &times; 180
  172. </span>
  173. </button>
  174. </div>
  175. <!-- Show the cropped image in modal -->
  176. <div class="modal fade docs-cropped" id="getCroppedCanvasModal" aria-hidden="true" aria-labelledby="getCroppedCanvasTitle" role="dialog" tabindex="-1">
  177. <div class="modal-dialog">
  178. <div class="modal-content">
  179. <div class="modal-header">
  180. <button class="close" data-dismiss="modal" type="button" aria-hidden="true">&times;</button>
  181. <h4 class="modal-title" id="getCroppedCanvasTitle">Cropped</h4>
  182. </div>
  183. <div class="modal-body"></div>
  184. <!-- <div class="modal-footer">
  185. <button class="btn btn-primary" data-dismiss="modal" type="button">Close</button>
  186. </div> -->
  187. </div>
  188. </div>
  189. </div><!-- /.modal -->
  190. <button class="btn btn-primary" data-method="getData" data-option="" data-target="#putData" type="button">
  191. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;getData&quot;)">
  192. Get Data
  193. </span>
  194. </button>
  195. <button class="btn btn-primary" data-method="getImageData" data-option="" data-target="#putData" type="button">
  196. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;getImageData&quot;)">
  197. Get Image Data
  198. </span>
  199. </button>
  200. <button class="btn btn-primary" data-method="getCanvasData" data-option="" data-target="#putData" type="button">
  201. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;getCanvasData&quot;)">
  202. Get Canvas Data
  203. </span>
  204. </button>
  205. <button class="btn btn-primary" data-method="setCanvasData" data-target="#putData" type="button">
  206. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;setCanvasData&quot;, data)">
  207. Set Canvas Data
  208. </span>
  209. </button>
  210. <button class="btn btn-primary" data-method="getCropBoxData" data-option="" data-target="#putData" type="button">
  211. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;getCropBoxData&quot;)">
  212. Get Crop Box Data
  213. </span>
  214. </button>
  215. <button class="btn btn-primary" data-method="setCropBoxData" data-target="#putData" type="button">
  216. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;setCropBoxData&quot;, data)">
  217. Set Crop Box Data
  218. </span>
  219. </button>
  220. <input class="form-control" id="putData" type="text" placeholder="Get data to here or set data with this value">
  221. </div><!-- /.docs-buttons -->
  222. <div class="col-md-3 docs-toggles">
  223. <!-- <h3 class="page-header">Toggles:</h3> -->
  224. <div class="btn-group btn-group-justified" data-toggle="buttons">
  225. <label class="btn btn-primary active" data-method="setAspectRatio" data-option="1.7777777777777777" title="Set Aspect Ratio">
  226. <input class="sr-only" id="aspestRatio1" name="aspestRatio" value="1.7777777777777777" type="radio">
  227. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;setAspectRatio&quot;, 16 / 9)">
  228. 16:9
  229. </span>
  230. </label>
  231. <label class="btn btn-primary" data-method="setAspectRatio" data-option="1.3333333333333333" title="Set Aspect Ratio">
  232. <input class="sr-only" id="aspestRatio2" name="aspestRatio" value="1.3333333333333333" type="radio">
  233. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;setAspectRatio&quot;, 4 / 3)">
  234. 4:3
  235. </span>
  236. </label>
  237. <label class="btn btn-primary" data-method="setAspectRatio" data-option="1" title="Set Aspect Ratio">
  238. <input class="sr-only" id="aspestRatio3" name="aspestRatio" value="1" type="radio">
  239. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;setAspectRatio&quot;, 1 / 1)">
  240. 1:1
  241. </span>
  242. </label>
  243. <label class="btn btn-primary" data-method="setAspectRatio" data-option="0.6666666666666666" title="Set Aspect Ratio">
  244. <input class="sr-only" id="aspestRatio4" name="aspestRatio" value="0.6666666666666666" type="radio">
  245. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;setAspectRatio&quot;, 2 / 3)">
  246. 2:3
  247. </span>
  248. </label>
  249. <label class="btn btn-primary" data-method="setAspectRatio" data-option="NaN" title="Set Aspect Ratio">
  250. <input class="sr-only" id="aspestRatio5" name="aspestRatio" value="NaN" type="radio">
  251. <span class="docs-tooltip" data-toggle="tooltip" title="$().cropper(&quot;setAspectRatio&quot;, NaN)">
  252. Free
  253. </span>
  254. </label>
  255. </div>
  256. <div class="dropdown dropup docs-options">
  257. <button class="btn btn-primary btn-block dropdown-toggle" id="toggleOptions" type="button" data-toggle="dropdown" aria-expanded="true">
  258. Toggle Options
  259. <span class="caret"></span>
  260. </button>
  261. <ul class="dropdown-menu" role="menu" aria-labelledby="toggleOptions">
  262. <li role="presentation">
  263. <label class="checkbox-inline">
  264. <input type="checkbox" name="option" value="strict" checked>
  265. strict
  266. </label>
  267. </li>
  268. <li role="presentation">
  269. <label class="checkbox-inline">
  270. <input type="checkbox" name="option" value="responsive" checked>
  271. responsive
  272. </label>
  273. </li>
  274. <li role="presentation">
  275. <label class="checkbox-inline">
  276. <input type="checkbox" name="option" value="checkImageOrigin" checked>
  277. checkImageOrigin
  278. </label>
  279. </li>
  280. <li role="presentation">
  281. <label class="checkbox-inline">
  282. <input type="checkbox" name="option" value="modal" checked>
  283. modal
  284. </label>
  285. </li>
  286. <li role="presentation">
  287. <label class="checkbox-inline">
  288. <input type="checkbox" name="option" value="guides" checked>
  289. guides
  290. </label>
  291. </li>
  292. <li role="presentation">
  293. <label class="checkbox-inline">
  294. <input type="checkbox" name="option" value="highlight" checked>
  295. highlight
  296. </label>
  297. </li>
  298. <li role="presentation">
  299. <label class="checkbox-inline">
  300. <input type="checkbox" name="option" value="background" checked>
  301. background
  302. </label>
  303. </li>
  304. <li role="presentation">
  305. <label class="checkbox-inline">
  306. <input type="checkbox" name="option" value="autoCrop" checked>
  307. autoCrop
  308. </label>
  309. </li>
  310. <li role="presentation">
  311. <label class="checkbox-inline">
  312. <input type="checkbox" name="option" value="dragCrop" checked>
  313. dragCrop
  314. </label>
  315. </li>
  316. <li role="presentation">
  317. <label class="checkbox-inline">
  318. <input type="checkbox" name="option" value="movable" checked>
  319. movable
  320. </label>
  321. </li>
  322. <li role="presentation">
  323. <label class="checkbox-inline">
  324. <input type="checkbox" name="option" value="resizable" checked>
  325. resizable
  326. </label>
  327. </li>
  328. <li role="presentation">
  329. <label class="checkbox-inline">
  330. <input type="checkbox" name="option" value="rotatable" checked>
  331. rotatable
  332. </label>
  333. </li>
  334. <li role="presentation">
  335. <label class="checkbox-inline">
  336. <input type="checkbox" name="option" value="zoomable" checked>
  337. zoomable
  338. </label>
  339. </li>
  340. <li role="presentation">
  341. <label class="checkbox-inline">
  342. <input type="checkbox" name="option" value="touchDragZoom" checked>
  343. touchDragZoom
  344. </label>
  345. </li>
  346. <li role="presentation">
  347. <label class="checkbox-inline">
  348. <input type="checkbox" name="option" value="mouseWheelZoom" checked>
  349. mouseWheelZoom
  350. </label>
  351. </li>
  352. </ul>
  353. </div><!-- /.dropdown -->
  354. </div><!-- /.docs-toggles -->
  355. </div>
  356. </div>
  357. <!-- Alert -->
  358. <div class="docs-alert"><span class="warning message"></span></div>
  359. <!-- Scripts -->
  360. <script src="../assets/js/jquery.min.js"></script>
  361. <script src="../assets/js/bootstrap.min.js"></script>
  362. <script src="../dist/cropper.js"></script>
  363. <script src="js/main.js"></script>
  364. </body>
  365. </html>