本文整理匯總了Python中wagtail.images.models.Image方法的典型用法代碼示例。如果您正苦於以下問題:Python models.Image方法的具體用法?Python models.Image怎麽用?Python models.Image使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類wagtail.images.models
的用法示例。
在下文中一共展示了models.Image方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: make_run_test
# 需要導入模塊: from wagtail.images import models [as 別名]
# 或者: from wagtail.images.models import Image [as 別名]
def make_run_test(cls, filter_spec, image_kwargs, expected_output):
def test_run(self):
image = Image(**image_kwargs)
# Make operation
operation = self.operation_class(*filter_spec.split('-'))
# Make operation recorder
operation_recorder = WillowOperationRecorder((image.width, image.height))
# Run
operation.run(operation_recorder, image, {})
# Check
self.assertEqual(operation_recorder.ran_operations, expected_output)
test_run.__name__ = str('test_run_%s' % filter_spec)
return test_run
示例2: make_norun_test
# 需要導入模塊: from wagtail.images import models [as 別名]
# 或者: from wagtail.images.models import Image [as 別名]
def make_norun_test(cls, filter_spec, image_kwargs):
def test_norun(self):
image = Image(**image_kwargs)
# Make operation
operation = self.operation_class(*filter_spec.split('-'))
# Make operation recorder
operation_recorder = WillowOperationRecorder((image.width, image.height))
# Attempt (and hopefully fail) to run
with self.assertRaises(ValueError):
operation.run(operation_recorder, image, {})
test_norun.__name__ = str('test_norun_%s' % filter_spec)
return test_norun
示例3: setUp
# 需要導入模塊: from wagtail.images import models [as 別名]
# 或者: from wagtail.images.models import Image [as 別名]
def setUp(self):
super().setUp()
self.policy = BlanketPermissionPolicy(Image)
self.active_users = [
self.superuser,
self.image_adder,
self.oneoff_image_adder,
self.image_changer,
self.oneoff_image_changer,
self.oneoff_image_deleter,
self.useless_user,
]
self.all_users = self.active_users + [
self.inactive_superuser,
self.inactive_image_adder,
self.inactive_image_changer,
self.anonymous_user,
]
示例4: process_content_image
# 需要導入模塊: from wagtail.images import models [as 別名]
# 或者: from wagtail.images.models import Image [as 別名]
def process_content_image(self, content):
self.stdout.write('\tGenerate and replace entry content images....')
if content:
root = lxml.html.fromstring(content)
for img_node in root.iter('img'):
parent_node = img_node.getparent()
if 'wp-content' in img_node.attrib['src'] or 'files' in img_node.attrib['src']:
image = self._import_image(img_node.attrib['src'])
if image:
title = img_node.attrib.get('title') or img_node.attrib.get('alt')
new_image = WagtailImage(file=File(file=image), title=title)
new_image.save()
if parent_node.tag == 'a':
parent_node.addnext(ET.XML(self._image_to_embed(new_image)))
parent_node.drop_tree()
else:
parent_node.append(ET.XML(self._image_to_embed(new_image)))
img_node.drop_tag()
content = ET.tostring(root)
return content
示例5: setUp
# 需要導入模塊: from wagtail.images import models [as 別名]
# 或者: from wagtail.images.models import Image [as 別名]
def setUp(self):
self.site = Site.objects.first()
self.site.site_name = 'Example site'
self.site.save()
self.factory = RequestFactory()
self.request = self.factory.get('/test/')
self.request.site = self.site
self.image = Image.objects.create(
title='Test Image',
file=get_test_image_file(),
)
self.page = self.site.root_page.add_child(instance=TestPage(
title='Test Page',
search_image=self.image,
search_description='Some test content description',
))
self.test_model = TestModel.objects.create()
示例6: ImageQueryMixin
# 需要導入模塊: from wagtail.images import models [as 別名]
# 或者: from wagtail.images.models import Image [as 別名]
def ImageQueryMixin():
class Mixin:
images = graphene.List(Image)
image = graphene.Field(Image,
id=graphene.Int(required=True))
def resolve_images(self, info: ResolveInfo):
return with_collection_permissions(
info.context,
gql_optimizer.query(
wagtailImage.objects.all(),
info
)
)
def resolve_image(self, info: ResolveInfo, id: int):
image = with_collection_permissions(
info.context,
gql_optimizer.query(
wagtailImage.objects.filter(id=id),
info
)
).first()
return image
return Mixin
示例7: handle
# 需要導入模塊: from wagtail.images import models [as 別名]
# 或者: from wagtail.images.models import Image [as 別名]
def handle(self, *args, **options):
# Get the only instance of Magazine Index Page
magazine_index_page = MagazineIndexPage.objects.get()
with open(options["file"]) as import_file:
issues = csv.DictReader(import_file)
for issue in issues:
response = requests.get(issue["cover_image_url"])
image_file = BytesIO(response.content)
image = Image(
title=issue["title"] + " cover image",
file=ImageFile(image_file, name=issue["cover_image_file_name"]),
)
image.save()
import_issue = MagazineIssue(
title=issue["title"],
publication_date=issue["publication_date"],
first_published_at=issue["publication_date"],
issue_number=issue["issue_number"],
cover_image=image,
)
# Add issue to site page hiererchy
magazine_index_page.add_child(instance=import_issue)
magazine_index_page.save()
self.stdout.write("All done!")
示例8: default
# 需要導入模塊: from wagtail.images import models [as 別名]
# 或者: from wagtail.images.models import Image [as 別名]
def default(self, obj):
if isinstance(obj, Image):
return image_ld(obj)
if isinstance(obj, ThingLD):
return obj.ld_nested_entity()
return super().default(obj)
示例9: set_featured_media
# 需要導入模塊: from wagtail.images import models [as 別名]
# 或者: from wagtail.images.models import Image [as 別名]
def set_featured_media(self, page: BlogPage, post):
featured_media_id: int = post.get("featured_media")
if not featured_media_id:
return
featured_medias: list = post["_embedded"].get("wp:featuredmedia")
if featured_medias is None:
return
for feature_media in featured_medias:
if feature_media.get("id") == featured_media_id:
source_url = feature_media["source_url"]
try: # Wordpress 5.3 API nests title in "rendered"
title = feature_media["title"]["rendered"]
except TypeError: # Fallback for older (or newer?) wordpress
title = feature_media["title"]
details = feature_media["media_details"]
resp = requests.get(source_url, stream=True)
if resp.status_code != requests.codes.ok:
print("Unable to import " + source_url)
continue
fp = BytesIO()
fp.write(resp.content)
image = Image(
title=title, width=details["width"], height=details["height"]
)
image.file.save(details["file"], File(fp))
image.save()
page.header_image = image
示例10: create_images_from_urls_in_content
# 需要導入模塊: from wagtail.images import models [as 別名]
# 或者: from wagtail.images.models import Image [as 別名]
def create_images_from_urls_in_content(self, body):
"""create Image objects and transfer image files to media root"""
from bs4 import BeautifulSoup
soup = BeautifulSoup(body, "html5lib")
for img in soup.findAll("img"):
if "width" in img:
width = img["width"]
if "height" in img:
height = img["height"]
else:
width = 100
height = 100
_, file_name = os.path.split(img["src"])
if not img["src"]:
continue # Blank image
if img["src"].startswith("data:"):
continue # Embedded image
resp = requests.get(self.prepare_url(img["src"]), stream=True)
if resp.status_code != requests.codes.ok:
print("Unable to import " + img["src"])
continue
fp = BytesIO()
fp.write(resp.content)
image = Image(title=file_name, width=width, height=height)
image.file.save(file_name, File(fp))
image.save()
if img.has_attr("srcset"):
img["srcset"] = ""
try:
new_url = image.get_rendition("original").url
img["src"] = new_url
except OSError:
# Avoid https://github.com/wagtail/wagtail/issues/1326 by not importing it
logger.warning(f"image {image} is unable to be imported")
image.delete()
soup.body.hidden = True
return soup.body
示例11: get_gallery_images
# 需要導入模塊: from wagtail.images import models [as 別名]
# 或者: from wagtail.images.models import Image [as 別名]
def get_gallery_images(collection, page=None, tags=None):
images = None
try:
images = Image.objects.filter(collection__name=collection)
if page:
if page.order_images_by == 0:
images = images.order_by('title')
elif page.order_images_by == 1:
images = images.order_by('-created_at')
except Exception as e:
logging.exception(e)
if images and tags:
images = images.filter(tags__name__in=tags).distinct()
return images
示例12: setUp
# 需要導入模塊: from wagtail.images import models [as 別名]
# 或者: from wagtail.images.models import Image [as 別名]
def setUp(self):
# Create an image for running tests on
self.image = Image.objects.create(
title="Test image",
file=get_test_image_file(),
)
示例13: test_fields
# 需要導入模塊: from wagtail.images import models [as 別名]
# 或者: from wagtail.images.models import Image [as 別名]
def test_fields(self):
form = get_image_form(Image)
self.assertEqual(list(form.base_fields.keys()), [
'title',
'file',
'collection',
'tags',
'focal_point_x',
'focal_point_y',
'focal_point_width',
'focal_point_height',
])
示例14: test_fill_filter
# 需要導入模塊: from wagtail.images import models [as 別名]
# 或者: from wagtail.images.models import Image [as 別名]
def test_fill_filter(self):
image = Image.objects.create(
title="Test image",
file=get_test_image_file(filename='test_rf2.png'),
)
rendition = image.get_rendition('fill-100x100')
self.assertEqual(rendition.file.name, 'images/test_rf2.2e16d0ba.fill-100x100.png')
示例15: test_fill_filter_with_focal_point
# 需要導入模塊: from wagtail.images import models [as 別名]
# 或者: from wagtail.images.models import Image [as 別名]
def test_fill_filter_with_focal_point(self):
image = Image.objects.create(
title="Test image",
file=get_test_image_file(filename='test_rf3.png'),
)
image.set_focal_point(Rect(100, 100, 200, 200))
image.save()
rendition = image.get_rendition('fill-100x100')
self.assertEqual(rendition.file.name, 'images/test_rf3.15ee4958.fill-100x100.png')