/* * Overchan Android (Meta Imageboard Client) * Copyright (C) 2014-2016 miku-nyan <https://github.com/miku-nyan> * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ package nya.miku.wishmaster.api.models; import java.io.Serializable; import com.esotericsoftware.kryo.serializers.TaggedFieldSerializer.Tag; /** * Модель вложения (прикреплённый к посту файл или внешняя ссылка, например, на Youtube) * @author miku-nyan * */ public class AttachmentModel implements Serializable { private static final long serialVersionUID = 1L; /** * Тип вложения, одно из константных значений: * {@link #TYPE_IMAGE_STATIC}, {@link #TYPE_IMAGE_GIF}, {@link #TYPE_IMAGE_SVG}, * {@link #TYPE_VIDEO}, {@link #TYPE_AUDIO}, * {@link #TYPE_OTHER_FILE}, {@link #TYPE_OTHER_NOTFILE} */ @Tag(0) public int type; /** * Размер вложения (если оно является файлом), в килобайтах. * Если вложение не является файлом (или размер не определяется/не предоставляется), должно быть записано значение -1. */ @Tag(1) public int size; /** * Путь (абсолютный или относительный на имиджборде) к картинке-превью (миниатюре) данного вложения. * Может содержать значение null, если миниатюра отсутствует или не предоставляется для данного типа файла/на данной имиджборде. */ @Tag(2) public String thumbnail; /** * Путь (абсолютный или относительный на имиджборде) к оригиналу файла данного вложения, если вложение является файлом; * адрес, по поторому содержится вложение, если является внешней ссылкой. */ @Tag(3) public String path; /** * Ширина изображения или видео, если вложение является изображением или видео. * В противном случае (или если размер не определяется/не предоставляется), должно быть записано значение -1. */ @Tag(4) public int width; /** * Высота изображения или видео, если вложение является изображением или видео. * В противном случае (или если размер не определяется/не предоставляется), должно быть записано значение -1. */ @Tag(5) public int height; /** * Оригинальное имя файла (в случае, если реальное имя файла на имиджборде отличается от оригинального, как загрузил пользователь). * Может содержать null. */ @Tag(6) public String originalName; /** * Должно принимать true, если вложение является спойлером (или nsfw на некоторых чанах) */ @Tag(7) public boolean isSpoiler; /** * Константное значение для обозначения типа вложения - статичное изображение (файл JPG или PNG) */ public static final int TYPE_IMAGE_STATIC = 0; /** * Константное значение для обозначения типа вложения - анимированное изображение (файл GIF) */ public static final int TYPE_IMAGE_GIF = 1; /** * Константное значение для обозначения типа вложения - векторное изображение (файл SVG) */ public static final int TYPE_IMAGE_SVG = 6; /** * Константное значение для обозначения типа вложения - видеофайл (файл WEBM или другой формат) */ public static final int TYPE_VIDEO = 2; /** * Константное значение для обозначения типа вложения - аудиофайл (файл MP3 или другой формат) */ public static final int TYPE_AUDIO = 3; /** * Константное значение для обозначения типа вложения - неопределённый файл (любой файл) */ public static final int TYPE_OTHER_FILE = 4; /** * Константное значение для обозначения типа вложения - ссылка на внешний ресурс (Youtube, Vimeo и т.д.) */ public static final int TYPE_OTHER_NOTFILE = 5; }