當前位置: 首頁>>代碼示例>>Python>>正文


Python models.Image方法代碼示例

本文整理匯總了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 
開發者ID:wagtail,項目名稱:wagtail,代碼行數:20,代碼來源:test_image_operations.py

示例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 
開發者ID:wagtail,項目名稱:wagtail,代碼行數:18,代碼來源:test_image_operations.py

示例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,
        ] 
開發者ID:wagtail,項目名稱:wagtail,代碼行數:21,代碼來源:test_permission_policies.py

示例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 
開發者ID:APSL,項目名稱:wordpress-to-puput,代碼行數:22,代碼來源:wp2puput.py

示例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() 
開發者ID:neon-jungle,項目名稱:wagtail-metadata,代碼行數:21,代碼來源:test_templates.py

示例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 
開發者ID:tr11,項目名稱:wagtail-graphql,代碼行數:27,代碼來源:images.py

示例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!") 
開發者ID:WesternFriend,項目名稱:WF-website,代碼行數:33,代碼來源:import_issues.py

示例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) 
開發者ID:neon-jungle,項目名稱:wagtail-schema.org,代碼行數:8,代碼來源:encoder.py

示例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 
開發者ID:thelabnyc,項目名稱:wagtail_blog,代碼行數:29,代碼來源:wordpress_import.py

示例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 
開發者ID:thelabnyc,項目名稱:wagtail_blog,代碼行數:40,代碼來源:wordpress_import.py

示例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 
開發者ID:chrisdev,項目名稱:wagtail-cookiecutter-foundation,代碼行數:16,代碼來源:models.py

示例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(),
        ) 
開發者ID:wagtail,項目名稱:wagtail,代碼行數:8,代碼來源:tests.py

示例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',
        ]) 
開發者ID:wagtail,項目名稱:wagtail,代碼行數:15,代碼來源:tests.py

示例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') 
開發者ID:wagtail,項目名稱:wagtail,代碼行數:10,代碼來源:tests.py

示例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') 
開發者ID:wagtail,項目名稱:wagtail,代碼行數:13,代碼來源:tests.py


注:本文中的wagtail.images.models.Image方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。