com.urbanairship.api.push.model.notification.ios.IOSMediaOptions Maven / Gradle / Ivy
/*
* Copyright (c) 2013-2016. Urban Airship and Contributors
*/
package com.urbanairship.api.push.model.notification.ios;
import com.google.common.base.Optional;
import com.urbanairship.api.push.model.PushModelObject;
/**
* IOSMediaOptions for iOS specific MediaAttachment push messages.
*/
public final class IOSMediaOptions extends PushModelObject{
private final Optional time;
private final Optional crop;
private final Optional hidden;
private IOSMediaOptions(Optional time, Optional crop, Optional hidden) {
this.time = time;
this.crop = crop;
this.hidden = hidden;
}
/**
* Get a IOSMediaOptions builder
* @return Builder
*/
public static Builder newBuilder() {
return new Builder();
}
/**
* Get the time used for the thumbnail.
* @return Optional Integer representation of the time
*/
public Optional getTime() {
return time;
}
/**
* Get the Crop object that describes the crop parameters to be used in the thumbnail.
* @return Optional Crop object
*/
public Optional getCrop() {
return crop;
}
/**
* Get the hidden value of the thumbnail.
* @return Optional Boolean representation of the hidden value
*/
public Optional getHidden() {
return hidden;
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
IOSMediaOptions that = (IOSMediaOptions)o;
if (time != null ? !time.equals(that.time) : that.time != null) {
return false;
}
if (crop != null ? !crop.equals(that.crop) : that.crop != null) {
return false;
}
return true;
}
@Override
public int hashCode() {
int result = (time != null ? time.hashCode() : 0);
result = 31 * result + (crop != null ? crop.hashCode() : 0);
return result;
}
@Override
public String toString() {
return "IOSMediaOptions{" +
"time=" + time +
", crop=" + crop +
'}';
}
public static class Builder {
private Integer time = null;
private Crop crop= null;
private Boolean hidden = null;
private Builder() { }
/**
* Set the time Integer of the frame of the animated resource that should be used in the thumbnail.
* @param time Integer
* @return Builder
*/
public Builder setTime(Integer time) {
this.time = time;
return this;
}
/**
* Set the Crop object that describes the crop parameters to be used in the thumbnail. Each field is a decimal, normalized from 0 to 1.
* @param crop Crop
* @return Builder
*/
public Builder setCrop(Crop crop) {
this.crop = crop;
return this;
}
/**
* Set the hidden Boolean value, when true, the thumbnail will be hidden
* @param hidden Boolean
* @return Builder
*/
public Builder setHidden(Boolean hidden) {
this.hidden = hidden;
return this;
}
/**
* Build IOSMediaOptions
* @return IOSMediaOptions
*/
public IOSMediaOptions build() {
return new IOSMediaOptions(Optional.fromNullable(time), Optional.fromNullable(crop), Optional.fromNullable(hidden));
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy