本文整理匯總了Python中objc.lookUpClass方法的典型用法代碼示例。如果您正苦於以下問題:Python objc.lookUpClass方法的具體用法?Python objc.lookUpClass怎麽用?Python objc.lookUpClass使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類objc
的用法示例。
在下文中一共展示了objc.lookUpClass方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: _setup
# 需要導入模塊: import objc [as 別名]
# 或者: from objc import lookUpClass [as 別名]
def _setup():
NSDictionary = _objc.lookUpClass("NSDictionary")
NSMutableDictionary = _objc.lookUpClass("NSMutableDictionary")
def CFDictionaryCreate(
allocator, keys, values, numValues, keyCallbacks, valueCallbacks
):
assert keyCallbacks is None
assert valueCallbacks is None
keys = list(keys)[:numValues]
values = list(values)[:numValues]
return NSDictionary.dictionaryWithDictionary_(dict(zip(keys, values)))
def CFDictionaryCreateMutable(allocator, capacity, keyCallbacks, valueCallbacks):
assert keyCallbacks is None
assert valueCallbacks is None
return NSMutableDictionary.dictionary()
return CFDictionaryCreate, CFDictionaryCreateMutable
示例2: ClassNameIncrementer
# 需要導入模塊: import objc [as 別名]
# 或者: from objc import lookUpClass [as 別名]
def ClassNameIncrementer(clsName, bases, dct):
orgName = clsName
counter = 0
while True:
try:
objc.lookUpClass(clsName)
except objc.nosuchclass_error:
break
counter += 1
clsName = orgName + str(counter)
return type(clsName, bases, dct)
示例3: setG
# 需要導入模塊: import objc [as 別名]
# 或者: from objc import lookUpClass [as 別名]
def setG(self, layer):
if layer.isKindOfClass_(objc.lookUpClass("GSControlLayer")):
return
self.output = '\\' + layer.parent.name + '\\\n' + self.output
self.layerID = layer.associatedMasterId
self.master = self.font.masters[self.layerID]
self.glyph = layer.parent
self.layer = layer
self.category = layer.parent.category
self.subCategory = layer.parent.subCategory
self.script = layer.parent.script
self.engine.reference = self.glyph.name
exception = self.findException()
if (exception):
self.engine.factor = exception[3]
item = exception[4]
if item != '*':
self.engine.reference = item
self.engine.newWidth = False
# check reference layer existance and contours
if self.font.glyphs[self.engine.reference]:
self.referenceLayer = self.font.glyphs[self.engine.reference].layers[self.layerID]
if len(self.referenceLayer.paths) < 1:
self.output += "WARNING: The reference glyph declared (" + self.engine.reference + ") doesn't have contours. Glyph " + self.layer.parent.name + " was spaced uses its own vertical range.\n"
self.referenceLayer = self.layer
else:
self.referenceLayer = self.layer
self.output += "WARNING: The reference glyph declared (" + self.engine.reference + ") doesn't exist. Glyph " + self.layer.parent.name + " was spaced uses its own vertical range.\n"
示例4: CFSTR
# 需要導入模塊: import objc [as 別名]
# 或者: from objc import lookUpClass [as 別名]
def CFSTR(strval):
return _objc.lookUpClass("NSString").stringWithString_(strval)
示例5: __getattr__
# 需要導入模塊: import objc [as 別名]
# 或者: from objc import lookUpClass [as 別名]
def __getattr__(self, name):
if name == "__all__":
# Load everything immediately
value = self.__calc_all()
self.__dict__[name] = value
return value
# First try parent module, as if we had done
# 'from parents import *'
for p in self.__parents:
try:
value = getattr(p, name)
except AttributeError:
pass
else:
self.__dict__[name] = value
if "__all__" in self.__dict__:
del self.__dict__["__all__"]
return value
if not _name_re.match(name):
# Name is not a valid identifier and cannot
# match.
raise AttributeError(name)
# Check if the name is a constant from
# the metadata files
try:
value = self.__get_constant(name)
except AttributeError:
pass
else:
self.__dict__[name] = value
if "__all__" in self.__dict__:
del self.__dict__["__all__"]
return value
# Then check if the name is class
try:
value = lookUpClass(name)
except nosuchclass_error:
pass
else:
self.__dict__[name] = value
if "__all__" in self.__dict__:
del self.__dict__["__all__"]
return value
# Finally give up and raise AttributeError
raise AttributeError(name)
示例6: send_OS_X_notify
# 需要導入模塊: import objc [as 別名]
# 或者: from objc import lookUpClass [as 別名]
def send_OS_X_notify(title, content, img_path):
'''發送Mac桌麵通知'''
try:
from Foundation import (
NSDate, NSUserNotification, NSUserNotificationCenter)
from AppKit import NSImage
import objc
except ImportError:
logger.info('failed to init OSX notify!')
return
def swizzle(cls, SEL, func):
old_IMP = getattr(cls, SEL, None)
if old_IMP is None:
old_IMP = cls.instanceMethodForSelector_(SEL)
def wrapper(self, *args, **kwargs):
return func(self, old_IMP, *args, **kwargs)
new_IMP = objc.selector(wrapper, selector=old_IMP.selector,
signature=old_IMP.signature)
objc.classAddMethod(cls, SEL.encode(), new_IMP)
def swizzled_bundleIdentifier(self, original):
# Use iTunes icon for notification
return 'com.apple.itunes'
swizzle(objc.lookUpClass('NSBundle'),
'bundleIdentifier',
swizzled_bundleIdentifier)
notification = NSUserNotification.alloc().init()
notification.setTitle_(title)
notification.setSubtitle_(content)
notification.setInformativeText_('')
notification.setUserInfo_({})
if img_path is not None:
image = NSImage.alloc().initWithContentsOfFile_(img_path)
# notification.setContentImage_(image)
notification.set_identityImage_(image)
notification.setDeliveryDate_(
NSDate.dateWithTimeInterval_sinceDate_(0, NSDate.date())
)
NSUserNotificationCenter.defaultUserNotificationCenter().\
scheduleNotification_(notification)
logger.info('send notify success!')