Задать вопрос

Как подключить библиотеку CROPIT и настроить у себя на сайте?

Мне нужно подключить эту библиотеку scottcheng.github.io/cropit . Это я сделал, но теперь мне нужно чтобы это изображения которое я обрезаю, потом передавалось через AJAX запрос либо же через XMLHttpRequest, ну а там соответственно записывало название изображения и само изображение добавляло на сервер.
<form id="addForm" method="POST" enctype="multipart/form-data">
    <input name="title" type="text" placeholder="Название">
    <div class="image-editor">
        <input type="file" name="img" class="cropit-image-input">
        <!-- .cropit-image-preview-container is needed for background image to work -->
        <div class="cropit-image-preview-container">
            <div class="cropit-image-preview"></div>
        </div>
        <div class="image-size-label">
            Resize image
        </div>
        <input type="range" class="cropit-image-zoom-input">
    </div>
    <input id="sentAdd" type="submit" value="Добавить">
    <span id="result_sent"></span>
</form>

<script>
    $("#sentAdd").click(function(e){
        e.preventDefault();

        var imageData = $('.image-editor').cropit('export', {
            type: 'image/jpeg',
            quality: .9
        });

        $.confirm({
            'title'		: 'Вы уверенны что хотите добавить статью ?',
            'buttons'	: {
                'Да'	: {
                    'class'	: 'yes',
                    'action': function(){

                        var forms = $('#addForm');
                        var result = $('#result_sent');

                        var form = document.forms.addForm;
                        var formData = new FormData(form);

                        var img = new FormData(imageData);

                        var xhr = new XMLHttpRequest();
                        xhr.open("POST", "/php/addPP.php");

                        xhr.onreadystatechange = function() {
                            if (xhr.readyState == 4) {
                                if(xhr.status == 200) {
                                    data = xhr.responseText;
                                    if(data == 1) {
                                       alert(imageData);

                                    } else {
                                        result.html('<b id="red_res">Ошибка! Вы что то сделали не так</b>');
                                        result.find('b').delay(2000).fadeOut(500);
                                    }
                                }
                            }
                        };
                        xhr.send(formData, img);
                    }
                },
                'Нет'	: {
                    'class'	: 'no',
                    'action': function(){}
                }
            }
        });
    });
</script>
  • Вопрос задан
  • 774 просмотра
Подписаться 3 Оценить 1 комментарий
Пригласить эксперта
Ответы на вопрос 1
oosaulenko
@oosaulenko Автор вопроса
Я нашел решение. Там используется кодировка base64, просто нужно hidden передать этот код, а на стороне php просто перекодировать его и все. Ниже показан код
<form method="POST" enctype="multipart/form-data">
    <div class="image-editor">
        <input name="imgs" type="file" class="cropit-image-input">
        <div class="cropit-image-preview"></div>
        <div class="image-size-label">
            Resize image
        </div>
        <input type="range" class="cropit-image-zoom-input">
        <input type="hidden" name="img" class="hidden-image-data">
    </div>
    <input type="submit" id="submit" value="Отправить">
</form>

<script>
    $(function() {
        $('.image-editor').cropit();
        $('.image-editor').cropit('previewSize', { width: 500, height: 750 });

        $('form').submit(function(e) {
            e.preventDefault();

            var imageData = $('.image-editor').cropit('export',{
                type: 'image/jpeg',
                quality: .6
            });
            var hidden = $('.hidden-image-data').val(imageData);


            var form = $('form');
            var formData = new FormData(form[0]);

            $.ajax({
                type: "POST",
                processData: false,
                contentType: false,
                url: "php/addPP.php",
                data:  formData,
                success: function(data){

                    alert(data);
                }
            })
        });
    });
</script>

<?
session_start();
include("db.php");

$img = $_POST['img'];
$img = str_replace('data:image/jpeg;base64,', '', $img);
$img = str_replace(' ', '+', $img);
$year = time();
$img = file_put_contents('../img/'.$year.'.jpg', base64_decode($img));

$result = mysqli_query ($link, "INSERT INTO test (img) VALUES ('$year');");

echo $result;
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
06 янв. 2025, в 18:21
20000 руб./за проект
06 янв. 2025, в 17:58
500 руб./за проект